mirror of
https://github.com/netsurf-browser/netsurf
synced 2024-11-22 14:31:20 +03:00
Improve treeview documentation comments
This commit is contained in:
parent
1f19fe05cf
commit
e72b89ac3d
File diff suppressed because it is too large
Load Diff
@ -37,6 +37,10 @@ struct core_window_callback_table;
|
|||||||
typedef struct treeview treeview;
|
typedef struct treeview treeview;
|
||||||
typedef struct treeview_node treeview_node;
|
typedef struct treeview_node treeview_node;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* treeview node type
|
||||||
|
*/
|
||||||
enum treeview_node_type {
|
enum treeview_node_type {
|
||||||
TREE_NODE_NONE = 0, /**< No node */
|
TREE_NODE_NONE = 0, /**< No node */
|
||||||
TREE_NODE_ROOT = (1 << 0), /**< Node is treeview's root */
|
TREE_NODE_ROOT = (1 << 0), /**< Node is treeview's root */
|
||||||
@ -44,18 +48,29 @@ enum treeview_node_type {
|
|||||||
TREE_NODE_ENTRY = (1 << 2) /**< Node is an entry */
|
TREE_NODE_ENTRY = (1 << 2) /**< Node is an entry */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Relationship between nodes
|
||||||
|
*/
|
||||||
enum treeview_relationship {
|
enum treeview_relationship {
|
||||||
TREE_REL_FIRST_CHILD,
|
TREE_REL_FIRST_CHILD,
|
||||||
TREE_REL_NEXT_SIBLING
|
TREE_REL_NEXT_SIBLING
|
||||||
}; /**< Relationship between nodes */
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Node change handling options
|
||||||
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
TREE_OPTION_NONE = (0), /* No flags set */
|
TREE_OPTION_NONE = (0), /* No flags set */
|
||||||
TREE_OPTION_SPECIAL_DIR = (1 << 0), /* Special folder */
|
TREE_OPTION_SPECIAL_DIR = (1 << 0), /* Special folder */
|
||||||
TREE_OPTION_SUPPRESS_RESIZE = (1 << 1), /* Suppress callback */
|
TREE_OPTION_SUPPRESS_RESIZE = (1 << 1), /* Suppress callback */
|
||||||
TREE_OPTION_SUPPRESS_REDRAW = (1 << 2) /* Suppress callback */
|
TREE_OPTION_SUPPRESS_REDRAW = (1 << 2) /* Suppress callback */
|
||||||
} treeview_node_options_flags; /**< Node change handling options */
|
} treeview_node_options_flags;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* treeview control flags
|
||||||
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
TREEVIEW_NO_FLAGS = (0), /**< No flags set */
|
TREEVIEW_NO_FLAGS = (0), /**< No flags set */
|
||||||
TREEVIEW_NO_MOVES = (1 << 0), /**< No node drags */
|
TREEVIEW_NO_MOVES = (1 << 0), /**< No node drags */
|
||||||
@ -64,20 +79,28 @@ typedef enum {
|
|||||||
TREEVIEW_DEL_EMPTY_DIRS = (1 << 2) /**< Delete dirs on empty */
|
TREEVIEW_DEL_EMPTY_DIRS = (1 << 2) /**< Delete dirs on empty */
|
||||||
} treeview_flags;
|
} treeview_flags;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* treeview message types
|
||||||
|
*/
|
||||||
enum treeview_msg {
|
enum treeview_msg {
|
||||||
TREE_MSG_NODE_DELETE, /**< Node to be deleted */
|
TREE_MSG_NODE_DELETE, /**< Node to be deleted */
|
||||||
TREE_MSG_NODE_EDIT, /**< Node to be edited */
|
TREE_MSG_NODE_EDIT, /**< Node to be edited */
|
||||||
TREE_MSG_NODE_LAUNCH /**< Node to be launched */
|
TREE_MSG_NODE_LAUNCH /**< Node to be launched */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* treeview message
|
||||||
|
*/
|
||||||
struct treeview_node_msg {
|
struct treeview_node_msg {
|
||||||
enum treeview_msg msg; /**< The message type */
|
enum treeview_msg msg; /**< The message type */
|
||||||
union {
|
union {
|
||||||
struct {
|
struct {
|
||||||
bool user; /* True iff delete by user interaction */
|
bool user; /**< True iff delete by user interaction */
|
||||||
} delete;
|
} delete;
|
||||||
struct {
|
struct {
|
||||||
lwc_string *field; /* The field being edited */
|
lwc_string *field; /**< The field being edited */
|
||||||
const char *text; /* The proposed new value */
|
const char *text; /**< The proposed new value */
|
||||||
} node_edit; /* Client may call treeview_update_node_* */
|
} node_edit; /* Client may call treeview_update_node_* */
|
||||||
struct {
|
struct {
|
||||||
browser_mouse_state mouse; /* Button / modifier used */
|
browser_mouse_state mouse; /* Button / modifier used */
|
||||||
@ -85,6 +108,10 @@ struct treeview_node_msg {
|
|||||||
} data; /**< The message data. */
|
} data; /**< The message data. */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* treeview field flags
|
||||||
|
*/
|
||||||
enum treeview_field_flags {
|
enum treeview_field_flags {
|
||||||
TREE_FLAG_NONE = 0, /**< No flags set */
|
TREE_FLAG_NONE = 0, /**< No flags set */
|
||||||
TREE_FLAG_ALLOW_EDIT = (1 << 0), /**< Whether allow edit field */
|
TREE_FLAG_ALLOW_EDIT = (1 << 0), /**< Whether allow edit field */
|
||||||
@ -92,11 +119,20 @@ enum treeview_field_flags {
|
|||||||
TREE_FLAG_SHOW_NAME = (1 << 2), /**< Whether field name shown */
|
TREE_FLAG_SHOW_NAME = (1 << 2), /**< Whether field name shown */
|
||||||
TREE_FLAG_COPY_TEXT = (1 << 3) /**< Whether to copy to clipb */
|
TREE_FLAG_COPY_TEXT = (1 << 3) /**< Whether to copy to clipb */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Treeview field description
|
||||||
|
*/
|
||||||
struct treeview_field_desc {
|
struct treeview_field_desc {
|
||||||
lwc_string *field; /**< A treeview field name */
|
lwc_string *field; /**< A treeview field name */
|
||||||
enum treeview_field_flags flags; /**< Flags for field */
|
enum treeview_field_flags flags; /**< Flags for field */
|
||||||
}; /**< Treeview field description */
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Treeview field data
|
||||||
|
*/
|
||||||
struct treeview_field_data {
|
struct treeview_field_data {
|
||||||
lwc_string *field; /**< Field name */
|
lwc_string *field; /**< Field name */
|
||||||
const char *value; /**< Field value */
|
const char *value; /**< Field value */
|
||||||
@ -104,10 +140,14 @@ struct treeview_field_data {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Client callbacks for events concerning nodes
|
||||||
|
*/
|
||||||
struct treeview_callback_table {
|
struct treeview_callback_table {
|
||||||
nserror (*folder)(struct treeview_node_msg msg, void *data);
|
nserror (*folder)(struct treeview_node_msg msg, void *data);
|
||||||
nserror (*entry)(struct treeview_node_msg msg, void *data);
|
nserror (*entry)(struct treeview_node_msg msg, void *data);
|
||||||
}; /**< Client callbacks for events concerning nodes */
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Prepare treeview module for treeview usage
|
* Prepare treeview module for treeview usage
|
||||||
@ -116,6 +156,7 @@ struct treeview_callback_table {
|
|||||||
*/
|
*/
|
||||||
nserror treeview_init(void);
|
nserror treeview_init(void);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Finalise the treeview module (all treeviews must have been destroyed first)
|
* Finalise the treeview module (all treeviews must have been destroyed first)
|
||||||
*
|
*
|
||||||
@ -123,9 +164,18 @@ nserror treeview_init(void);
|
|||||||
*/
|
*/
|
||||||
nserror treeview_fini(void);
|
nserror treeview_fini(void);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a treeview
|
* Create a treeview
|
||||||
*
|
*
|
||||||
|
* The fields array order is as follows (N = n_fields):
|
||||||
|
*
|
||||||
|
* fields[0] Main field for entries (shown when not expanded)
|
||||||
|
* fields[1]...fields[N-2] Additional fields for entries
|
||||||
|
* fields[N-1] Field for folder nodes
|
||||||
|
*
|
||||||
|
* So fields[0] and fields[N-1] have TREE_FLAG_DEFAULT set.
|
||||||
|
*
|
||||||
* \param tree Returns created treeview object
|
* \param tree Returns created treeview object
|
||||||
* \param callbacks Treeview client node event callbacks
|
* \param callbacks Treeview client node event callbacks
|
||||||
* \param n_fields Number of treeview fields (see description)
|
* \param n_fields Number of treeview fields (see description)
|
||||||
@ -134,14 +184,6 @@ nserror treeview_fini(void);
|
|||||||
* \param cw The core_window in which the treeview is shown
|
* \param cw The core_window in which the treeview is shown
|
||||||
* \param flags Treeview behaviour flags
|
* \param flags Treeview behaviour flags
|
||||||
* \return NSERROR_OK on success, appropriate error otherwise
|
* \return NSERROR_OK on success, appropriate error otherwise
|
||||||
*
|
|
||||||
* The fields array order is as follows (N = n_fields):
|
|
||||||
*
|
|
||||||
* fields[0] Main field for entries (shown when not expanded)
|
|
||||||
* fields[1]...fields[N-2] Additional fields for entries
|
|
||||||
* fields[N-1] Field for folder nodes
|
|
||||||
*
|
|
||||||
* So fields[0] and fields[N-1] have TREE_FLAG_DEFAULT set.
|
|
||||||
*/
|
*/
|
||||||
nserror treeview_create(treeview **tree,
|
nserror treeview_create(treeview **tree,
|
||||||
const struct treeview_callback_table *callbacks,
|
const struct treeview_callback_table *callbacks,
|
||||||
@ -149,6 +191,7 @@ nserror treeview_create(treeview **tree,
|
|||||||
const struct core_window_callback_table *cw_t,
|
const struct core_window_callback_table *cw_t,
|
||||||
struct core_window *cw, treeview_flags flags);
|
struct core_window *cw, treeview_flags flags);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Attach a treeview to a corewindow.
|
* Attach a treeview to a corewindow.
|
||||||
*
|
*
|
||||||
@ -163,6 +206,7 @@ nserror treeview_cw_attach(treeview *tree,
|
|||||||
const struct core_window_callback_table *cw_t,
|
const struct core_window_callback_table *cw_t,
|
||||||
struct core_window *cw);
|
struct core_window *cw);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Detach a treeview from a corewindow
|
* Detach a treeview from a corewindow
|
||||||
*
|
*
|
||||||
@ -171,34 +215,38 @@ nserror treeview_cw_attach(treeview *tree,
|
|||||||
*/
|
*/
|
||||||
nserror treeview_cw_detach(treeview *tree);
|
nserror treeview_cw_detach(treeview *tree);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Destroy a treeview object
|
* Destroy a treeview object
|
||||||
*
|
*
|
||||||
|
* Will emit folder and entry deletion msg callbacks for all nodes in treeview.
|
||||||
|
*
|
||||||
* \param tree Treeview object to destroy
|
* \param tree Treeview object to destroy
|
||||||
* \return NSERROR_OK on success, appropriate error otherwise
|
* \return NSERROR_OK on success, appropriate error otherwise
|
||||||
*
|
|
||||||
* Will emit folder and entry deletion msg callbacks for all nodes in treeview.
|
|
||||||
*/
|
*/
|
||||||
nserror treeview_destroy(treeview *tree);
|
nserror treeview_destroy(treeview *tree);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find a releation for node creation.
|
* Find a releation for node creation.
|
||||||
*
|
*
|
||||||
|
* If at_y is set, we find a relation that will put the created node at that
|
||||||
|
* position.
|
||||||
|
*
|
||||||
|
* If at_y is unset, we find a relation that would put the node below the first
|
||||||
|
* selected node, or at the end of the treeview if no nodes selected.
|
||||||
|
*
|
||||||
* \param tree Treeview object in which to create folder
|
* \param tree Treeview object in which to create folder
|
||||||
* \param relation Existing node to insert as relation of, or NULL
|
* \param relation Existing node to insert as relation of, or NULL
|
||||||
* \param rel Folder's relationship to relation
|
* \param rel Folder's relationship to relation
|
||||||
* \param at_y Iff true, insert at y-offest
|
* \param at_y Iff true, insert at y-offest
|
||||||
* \param y Y-offset in px from top of hotlist. Ignored if (!at_y).
|
* \param y Y-offset in px from top of hotlist. Ignored if (!at_y).
|
||||||
* \return NSERROR_OK on success, appropriate error otherwise
|
* \return NSERROR_OK on success, appropriate error otherwise
|
||||||
*
|
|
||||||
* If at_y is set, we find a relation that will put the created node at that
|
|
||||||
* position.
|
|
||||||
*
|
|
||||||
* If at_y is unset, we find a relation that would put the node below the first
|
|
||||||
* selected node, or at the end of the treeview if no nodes selected.
|
|
||||||
*/
|
*/
|
||||||
nserror treeview_get_relation(treeview *tree, treeview_node **relation,
|
nserror treeview_get_relation(treeview *tree, treeview_node **relation,
|
||||||
enum treeview_relationship *rel, bool at_y, int y);
|
enum treeview_relationship *rel,
|
||||||
|
bool at_y, int y);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a folder node in given treeview
|
* Create a folder node in given treeview
|
||||||
@ -221,7 +269,9 @@ nserror treeview_create_node_folder(treeview *tree,
|
|||||||
treeview_node *relation,
|
treeview_node *relation,
|
||||||
enum treeview_relationship rel,
|
enum treeview_relationship rel,
|
||||||
const struct treeview_field_data *field,
|
const struct treeview_field_data *field,
|
||||||
void *data, treeview_node_options_flags flags);
|
void *data,
|
||||||
|
treeview_node_options_flags flags);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create an entry node in given treeview
|
* Create an entry node in given treeview
|
||||||
@ -244,7 +294,9 @@ nserror treeview_create_node_entry(treeview *tree,
|
|||||||
treeview_node *relation,
|
treeview_node *relation,
|
||||||
enum treeview_relationship rel,
|
enum treeview_relationship rel,
|
||||||
const struct treeview_field_data fields[],
|
const struct treeview_field_data fields[],
|
||||||
void *data, treeview_node_options_flags flags);
|
void *data,
|
||||||
|
treeview_node_options_flags flags);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update an folder node in given treeview
|
* Update an folder node in given treeview
|
||||||
@ -262,6 +314,7 @@ nserror treeview_update_node_folder(treeview *tree,
|
|||||||
const struct treeview_field_data *field,
|
const struct treeview_field_data *field,
|
||||||
void *data);
|
void *data);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update an entry node in given treeview
|
* Update an entry node in given treeview
|
||||||
*
|
*
|
||||||
@ -291,10 +344,17 @@ nserror treeview_update_node_entry(treeview *tree,
|
|||||||
typedef nserror (*treeview_walk_cb)(void *ctx, void *node_data,
|
typedef nserror (*treeview_walk_cb)(void *ctx, void *node_data,
|
||||||
enum treeview_node_type type, bool *abort);
|
enum treeview_node_type type, bool *abort);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Walk (depth first) a treeview subtree, calling a callback at each node of
|
* Walk (depth first) a treeview subtree, calling a callback at each node of
|
||||||
* required type.
|
* required type.
|
||||||
*
|
*
|
||||||
|
* Example usage: To export a treeview as XML, XML elements can be opened in
|
||||||
|
* enter_cb, and closed in leave_cb.
|
||||||
|
*
|
||||||
|
* Note, if deleting returned node in enter_cb, the walk must be terminated by
|
||||||
|
* setting abort to true.
|
||||||
|
*
|
||||||
* \param tree Treeview object to walk
|
* \param tree Treeview object to walk
|
||||||
* \param root Root node to walk tree from (or NULL for tree root)
|
* \param root Root node to walk tree from (or NULL for tree root)
|
||||||
* \param enter_cb Function to call on entering nodes, or NULL
|
* \param enter_cb Function to call on entering nodes, or NULL
|
||||||
@ -302,17 +362,12 @@ typedef nserror (*treeview_walk_cb)(void *ctx, void *node_data,
|
|||||||
* \param ctx Client context, passed back to callback function
|
* \param ctx Client context, passed back to callback function
|
||||||
* \param type The node type(s) of interest
|
* \param type The node type(s) of interest
|
||||||
* \return NSERROR_OK on success, or appropriate error otherwise
|
* \return NSERROR_OK on success, or appropriate error otherwise
|
||||||
*
|
|
||||||
* Example usage: To export a treeview as XML, XML elements can be opened in
|
|
||||||
* enter_cb, and closed in leave_cb.
|
|
||||||
*
|
|
||||||
* Note, if deleting returned node in enter_cb, the walk must be terminated by
|
|
||||||
* setting abort to true.
|
|
||||||
*/
|
*/
|
||||||
nserror treeview_walk(treeview *tree, treeview_node *root,
|
nserror treeview_walk(treeview *tree, treeview_node *root,
|
||||||
treeview_walk_cb enter_cb, treeview_walk_cb leave_cb,
|
treeview_walk_cb enter_cb, treeview_walk_cb leave_cb,
|
||||||
void *ctx, enum treeview_node_type type);
|
void *ctx, enum treeview_node_type type);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Delete a treeview node
|
* Delete a treeview node
|
||||||
*
|
*
|
||||||
@ -326,6 +381,7 @@ nserror treeview_walk(treeview *tree, treeview_node *root,
|
|||||||
nserror treeview_delete_node(treeview *tree, treeview_node *n,
|
nserror treeview_delete_node(treeview *tree, treeview_node *n,
|
||||||
treeview_node_options_flags flags);
|
treeview_node_options_flags flags);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Expand a treeview node
|
* Expand a treeview node
|
||||||
*
|
*
|
||||||
@ -335,6 +391,7 @@ nserror treeview_delete_node(treeview *tree, treeview_node *n,
|
|||||||
*/
|
*/
|
||||||
nserror treeview_node_expand(treeview *tree, treeview_node *node);
|
nserror treeview_node_expand(treeview *tree, treeview_node *node);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Contract a treeview node
|
* Contract a treeview node
|
||||||
*
|
*
|
||||||
@ -344,6 +401,7 @@ nserror treeview_node_expand(treeview *tree, treeview_node *node);
|
|||||||
*/
|
*/
|
||||||
nserror treeview_node_contract(treeview *tree, treeview_node *node);
|
nserror treeview_node_contract(treeview *tree, treeview_node *node);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Expand a treeview's nodes
|
* Expand a treeview's nodes
|
||||||
*
|
*
|
||||||
@ -353,6 +411,7 @@ nserror treeview_node_contract(treeview *tree, treeview_node *node);
|
|||||||
*/
|
*/
|
||||||
nserror treeview_expand(treeview *tree, bool only_folders);
|
nserror treeview_expand(treeview *tree, bool only_folders);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Contract a treeview's nodes
|
* Contract a treeview's nodes
|
||||||
*
|
*
|
||||||
@ -362,6 +421,7 @@ nserror treeview_expand(treeview *tree, bool only_folders);
|
|||||||
*/
|
*/
|
||||||
nserror treeview_contract(treeview *tree, bool all);
|
nserror treeview_contract(treeview *tree, bool all);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Redraw a treeview object
|
* Redraw a treeview object
|
||||||
*
|
*
|
||||||
@ -374,6 +434,7 @@ nserror treeview_contract(treeview *tree, bool all);
|
|||||||
void treeview_redraw(treeview *tree, int x, int y, struct rect *clip,
|
void treeview_redraw(treeview *tree, int x, int y, struct rect *clip,
|
||||||
const struct redraw_context *ctx);
|
const struct redraw_context *ctx);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Key press handling for treeviews.
|
* Key press handling for treeviews.
|
||||||
*
|
*
|
||||||
@ -383,6 +444,7 @@ void treeview_redraw(treeview *tree, int x, int y, struct rect *clip,
|
|||||||
*/
|
*/
|
||||||
bool treeview_keypress(treeview *tree, uint32_t key);
|
bool treeview_keypress(treeview *tree, uint32_t key);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles all kinds of mouse action
|
* Handles all kinds of mouse action
|
||||||
*
|
*
|
||||||
@ -394,6 +456,7 @@ bool treeview_keypress(treeview *tree, uint32_t key);
|
|||||||
void treeview_mouse_action(treeview *tree,
|
void treeview_mouse_action(treeview *tree,
|
||||||
browser_mouse_state mouse, int x, int y);
|
browser_mouse_state mouse, int x, int y);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Determine whether treeview has a selection
|
* Determine whether treeview has a selection
|
||||||
*
|
*
|
||||||
@ -402,6 +465,7 @@ void treeview_mouse_action(treeview *tree,
|
|||||||
*/
|
*/
|
||||||
bool treeview_has_selection(treeview *tree);
|
bool treeview_has_selection(treeview *tree);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the first selected node
|
* Get the first selected node
|
||||||
*
|
*
|
||||||
@ -412,6 +476,7 @@ bool treeview_has_selection(treeview *tree);
|
|||||||
enum treeview_node_type treeview_get_selection(treeview *tree,
|
enum treeview_node_type treeview_get_selection(treeview *tree,
|
||||||
void **node_data);
|
void **node_data);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Edit the first selected node
|
* Edit the first selected node
|
||||||
*
|
*
|
||||||
@ -419,6 +484,7 @@ enum treeview_node_type treeview_get_selection(treeview *tree,
|
|||||||
*/
|
*/
|
||||||
void treeview_edit_selection(treeview *tree);
|
void treeview_edit_selection(treeview *tree);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find current height of a treeview
|
* Find current height of a treeview
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user