2012-07-10 17:23:33 +04:00
/*
* Samba Unix / Linux SMB client library
* Registry Editor
* Copyright ( C ) Christopher Davis 2012
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# ifndef _REGEDIT_TREEVIEW_H_
# define _REGEDIT_TREEVIEW_H_
# include "includes.h"
# include <ncurses.h>
# include <menu.h>
2012-08-11 07:05:20 +04:00
# include <panel.h>
2012-07-10 17:23:33 +04:00
2012-07-13 08:11:55 +04:00
struct registry_key ;
2012-07-10 17:23:33 +04:00
struct tree_node {
char * name ;
char * label ;
2012-07-13 08:11:55 +04:00
struct registry_key * key ;
2012-07-10 17:23:33 +04:00
struct tree_node * parent ;
struct tree_node * child_head ;
struct tree_node * previous ;
struct tree_node * next ;
} ;
struct tree_view {
struct tree_node * root ;
WINDOW * window ;
2012-08-11 07:05:20 +04:00
PANEL * panel ;
2012-07-10 17:23:33 +04:00
MENU * menu ;
ITEM * * current_items ;
2012-08-10 05:14:42 +04:00
ITEM * empty [ 2 ] ;
2012-07-10 17:23:33 +04:00
} ;
struct tree_node * tree_node_new ( TALLOC_CTX * ctx , struct tree_node * parent ,
2012-07-13 08:11:55 +04:00
const char * name , struct registry_key * key ) ;
2012-07-10 17:23:33 +04:00
void tree_node_append ( struct tree_node * left , struct tree_node * right ) ;
struct tree_node * tree_node_pop ( struct tree_node * * plist ) ;
struct tree_node * tree_node_first ( struct tree_node * list ) ;
2012-08-10 05:14:42 +04:00
struct tree_node * tree_node_last ( struct tree_node * list ) ;
void tree_node_append_last ( struct tree_node * list , struct tree_node * node ) ;
2012-07-10 17:23:33 +04:00
void tree_node_free_recursive ( struct tree_node * list ) ;
2012-08-12 10:22:06 +04:00
size_t tree_node_print_path ( WINDOW * label , struct tree_node * node ) ;
2012-07-10 17:23:33 +04:00
struct tree_view * tree_view_new ( TALLOC_CTX * ctx , struct tree_node * root ,
2012-08-11 07:05:20 +04:00
int nlines , int ncols ,
2012-07-10 17:23:33 +04:00
int begin_y , int begin_x ) ;
2012-08-11 07:05:20 +04:00
void tree_view_resize ( struct tree_view * view , int nlines , int ncols ,
int begin_y , int begin_x ) ;
2012-07-10 17:23:33 +04:00
void tree_view_show ( struct tree_view * view ) ;
2012-08-10 05:14:42 +04:00
void tree_view_clear ( struct tree_view * view ) ;
2012-07-10 17:23:33 +04:00
WERROR tree_view_update ( struct tree_view * view , struct tree_node * list ) ;
2012-07-13 08:11:55 +04:00
bool tree_node_has_children ( struct tree_node * node ) ;
WERROR tree_node_load_children ( struct tree_node * node ) ;
2012-07-10 17:23:33 +04:00
# endif