2012-07-10 06:23:33 -07: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>
2012-08-10 20:05:20 -07:00
# include <panel.h>
2012-07-10 06:23:33 -07:00
2012-07-12 21:11:55 -07:00
struct registry_key ;
2012-07-10 06:23:33 -07:00
struct tree_node {
char * name ;
2012-07-12 21:11:55 -07:00
struct registry_key * key ;
2012-07-10 06:23:33 -07:00
struct tree_node * parent ;
struct tree_node * child_head ;
struct tree_node * previous ;
struct tree_node * next ;
} ;
2014-06-09 18:29:56 -07:00
struct multilist ;
2012-07-10 06:23:33 -07:00
struct tree_view {
struct tree_node * root ;
WINDOW * window ;
2014-05-20 16:17:42 -07:00
WINDOW * sub ;
2012-08-10 20:05:20 -07:00
PANEL * panel ;
2014-06-09 18:29:56 -07:00
struct multilist * list ;
2012-07-10 06:23:33 -07:00
} ;
2014-06-30 23:19:53 -07:00
struct registry_context ;
2012-07-10 06:23:33 -07:00
struct tree_node * tree_node_new ( TALLOC_CTX * ctx , struct tree_node * parent ,
2012-07-12 21:11:55 -07:00
const char * name , struct registry_key * key ) ;
2014-06-30 23:19:53 -07:00
struct tree_node * tree_node_new_root ( TALLOC_CTX * ctx ,
struct registry_context * regctx ) ;
# define tree_node_is_root(node) ((node)->key == NULL)
# define tree_node_is_top_level(node) tree_node_is_root((node)->parent)
2012-07-10 06:23:33 -07: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-09 18:14:42 -07:00
struct tree_node * tree_node_last ( struct tree_node * list ) ;
2014-07-31 23:24:19 -07:00
bool tree_node_next ( struct tree_node * * node , bool depth , WERROR * err ) ;
2014-08-02 17:29:31 -07:00
bool tree_node_prev ( struct tree_node * * node , bool depth , WERROR * err ) ;
2012-08-09 18:14:42 -07:00
void tree_node_append_last ( struct tree_node * list , struct tree_node * node ) ;
2012-08-11 23:22:06 -07:00
size_t tree_node_print_path ( WINDOW * label , struct tree_node * node ) ;
2014-06-30 23:14:20 -07:00
const char * * tree_node_get_path ( TALLOC_CTX * ctx , struct tree_node * node ) ;
2012-07-10 06:23:33 -07:00
struct tree_view * tree_view_new ( TALLOC_CTX * ctx , struct tree_node * root ,
2012-08-10 20:05:20 -07:00
int nlines , int ncols ,
2012-07-10 06:23:33 -07:00
int begin_y , int begin_x ) ;
2014-05-20 16:17:42 -07:00
void tree_view_set_selected ( struct tree_view * view , bool select ) ;
2012-08-10 20:05:20 -07:00
void tree_view_resize ( struct tree_view * view , int nlines , int ncols ,
int begin_y , int begin_x ) ;
2012-07-10 06:23:33 -07:00
void tree_view_show ( struct tree_view * view ) ;
2012-08-09 18:14:42 -07:00
void tree_view_clear ( struct tree_view * view ) ;
2014-06-30 23:14:20 -07:00
WERROR tree_view_set_root ( struct tree_view * view , struct tree_node * root ) ;
WERROR tree_view_set_path ( struct tree_view * view , const char * * path ) ;
2012-07-10 06:23:33 -07:00
WERROR tree_view_update ( struct tree_view * view , struct tree_node * list ) ;
2014-07-27 17:39:06 -07:00
WERROR tree_node_reopen_key ( struct registry_context * ctx ,
struct tree_node * node ) ;
2012-07-12 21:11:55 -07:00
bool tree_node_has_children ( struct tree_node * node ) ;
WERROR tree_node_load_children ( struct tree_node * node ) ;
2014-06-02 21:50:01 -07:00
void tree_node_insert_sorted ( struct tree_node * list , struct tree_node * node ) ;
bool tree_view_is_node_visible ( struct tree_view * view , struct tree_node * node ) ;
void tree_view_set_current_node ( struct tree_view * view , struct tree_node * node ) ;
struct tree_node * tree_view_get_current_node ( struct tree_view * view ) ;
2014-06-09 18:29:56 -07:00
void tree_view_driver ( struct tree_view * view , int c ) ;
2012-07-10 06:23:33 -07:00
# endif