mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-01 00:54:24 +03:00
src/filemanager/tree.c: fix coding style, minor refactoring.
Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
9bc3f5db29
commit
f28a5ed9e4
@ -109,6 +109,7 @@ struct WTree
|
|||||||
/* Specifies the display mode: 1d or 2d */
|
/* Specifies the display mode: 1d or 2d */
|
||||||
static gboolean tree_navigation_flag = FALSE;
|
static gboolean tree_navigation_flag = FALSE;
|
||||||
|
|
||||||
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
/*** file scope functions ************************************************************************/
|
/*** file scope functions ************************************************************************/
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
@ -119,13 +120,11 @@ static void tree_rescan (void *data);
|
|||||||
static tree_entry *
|
static tree_entry *
|
||||||
back_ptr (tree_entry * ptr, int *count)
|
back_ptr (tree_entry * ptr, int *count)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; ptr != NULL && ptr->prev != NULL && i < *count; ptr = ptr->prev, i++)
|
||||||
|
;
|
||||||
|
|
||||||
while (ptr && ptr->prev && i < *count)
|
|
||||||
{
|
|
||||||
ptr = ptr->prev;
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
*count = i;
|
*count = i;
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
@ -135,13 +134,11 @@ back_ptr (tree_entry * ptr, int *count)
|
|||||||
static tree_entry *
|
static tree_entry *
|
||||||
forw_ptr (tree_entry * ptr, int *count)
|
forw_ptr (tree_entry * ptr, int *count)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; ptr != NULL && ptr->next != NULL && i < *count; ptr = ptr->next, i++)
|
||||||
|
;
|
||||||
|
|
||||||
while (ptr && ptr->next && i < *count)
|
|
||||||
{
|
|
||||||
ptr = ptr->next;
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
*count = i;
|
*count = i;
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
@ -155,7 +152,7 @@ remove_callback (tree_entry * entry, void *data)
|
|||||||
|
|
||||||
if (tree->selected_ptr == entry)
|
if (tree->selected_ptr == entry)
|
||||||
{
|
{
|
||||||
if (tree->selected_ptr->next)
|
if (tree->selected_ptr->next != NULL)
|
||||||
tree->selected_ptr = tree->selected_ptr->next;
|
tree->selected_ptr = tree->selected_ptr->next;
|
||||||
else
|
else
|
||||||
tree->selected_ptr = tree->selected_ptr->prev;
|
tree->selected_ptr = tree->selected_ptr->prev;
|
||||||
@ -171,9 +168,9 @@ save_tree (WTree * tree)
|
|||||||
int error;
|
int error;
|
||||||
|
|
||||||
(void) tree;
|
(void) tree;
|
||||||
error = tree_store_save ();
|
|
||||||
|
|
||||||
if (error)
|
error = tree_store_save ();
|
||||||
|
if (error != 0)
|
||||||
{
|
{
|
||||||
char *tree_name;
|
char *tree_name;
|
||||||
|
|
||||||
@ -201,8 +198,7 @@ tree_destroy (WTree * tree)
|
|||||||
tree_store_remove_entry_remove_hook (remove_callback);
|
tree_store_remove_entry_remove_hook (remove_callback);
|
||||||
save_tree (tree);
|
save_tree (tree);
|
||||||
|
|
||||||
g_free (tree->tree_shown);
|
MC_PTR_FREE (tree->tree_shown);
|
||||||
tree->tree_shown = 0;
|
|
||||||
tree->selected_ptr = NULL;
|
tree->selected_ptr = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -271,7 +267,8 @@ show_tree (WTree * tree)
|
|||||||
Widget *w = WIDGET (tree);
|
Widget *w = WIDGET (tree);
|
||||||
WDialog *h = w->owner;
|
WDialog *h = w->owner;
|
||||||
tree_entry *current;
|
tree_entry *current;
|
||||||
int i, j, topsublevel;
|
int i, j;
|
||||||
|
int topsublevel = 0;
|
||||||
int x = 0, y = 0;
|
int x = 0, y = 0;
|
||||||
int tree_lines, tree_cols;
|
int tree_lines, tree_cols;
|
||||||
|
|
||||||
@ -289,11 +286,10 @@ show_tree (WTree * tree)
|
|||||||
g_free (tree->tree_shown);
|
g_free (tree->tree_shown);
|
||||||
tree->tree_shown = g_new0 (tree_entry *, tree_lines);
|
tree->tree_shown = g_new0 (tree_entry *, tree_lines);
|
||||||
|
|
||||||
if (tree->store->tree_first)
|
if (tree->store->tree_first != NULL)
|
||||||
topsublevel = tree->store->tree_first->sublevel;
|
topsublevel = tree->store->tree_first->sublevel;
|
||||||
else
|
|
||||||
topsublevel = 0;
|
if (tree->selected_ptr == NULL)
|
||||||
if (!tree->selected_ptr)
|
|
||||||
{
|
{
|
||||||
tree->selected_ptr = tree->store->tree_first;
|
tree->selected_ptr = tree->store->tree_first;
|
||||||
tree->topdiff = 0;
|
tree->topdiff = 0;
|
||||||
@ -306,7 +302,8 @@ show_tree (WTree * tree)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
i = 0;
|
i = 0;
|
||||||
while (current->prev && i < tree->topdiff)
|
|
||||||
|
while (current->prev != NULL && i < tree->topdiff)
|
||||||
{
|
{
|
||||||
current = current->prev;
|
current = current->prev;
|
||||||
|
|
||||||
@ -369,7 +366,7 @@ show_tree (WTree * tree)
|
|||||||
if (tree_cols - 8 - 3 * j < 9)
|
if (tree_cols - 8 - 3 * j < 9)
|
||||||
break;
|
break;
|
||||||
tty_print_char (' ');
|
tty_print_char (' ');
|
||||||
if (current->submask & (1 << (j + topsublevel + 1)))
|
if ((current->submask & (1 << (j + topsublevel + 1))) != 0)
|
||||||
tty_print_char (ACS_VLINE);
|
tty_print_char (ACS_VLINE);
|
||||||
else
|
else
|
||||||
tty_print_char (' ');
|
tty_print_char (' ');
|
||||||
@ -377,7 +374,7 @@ show_tree (WTree * tree)
|
|||||||
}
|
}
|
||||||
tty_print_char (' ');
|
tty_print_char (' ');
|
||||||
j++;
|
j++;
|
||||||
if (!current->next || !(current->next->submask & (1 << current->sublevel)))
|
if (current->next == NULL || (current->next->submask & (1 << current->sublevel)) == 0)
|
||||||
tty_print_char (ACS_LLCORNER);
|
tty_print_char (ACS_LLCORNER);
|
||||||
else
|
else
|
||||||
tty_print_char (ACS_LTEE);
|
tty_print_char (ACS_LTEE);
|
||||||
@ -393,8 +390,7 @@ show_tree (WTree * tree)
|
|||||||
/* Calculate the next value for current */
|
/* Calculate the next value for current */
|
||||||
current = current->next;
|
current = current->next;
|
||||||
if (tree_navigation_flag)
|
if (tree_navigation_flag)
|
||||||
{
|
for (; current != NULL; current = current->next)
|
||||||
while (current != NULL)
|
|
||||||
{
|
{
|
||||||
if (current->sublevel < tree->selected_ptr->sublevel)
|
if (current->sublevel < tree->selected_ptr->sublevel)
|
||||||
{
|
{
|
||||||
@ -419,8 +415,6 @@ show_tree (WTree * tree)
|
|||||||
vfs_path_len (tree->selected_ptr->name)))
|
vfs_path_len (tree->selected_ptr->name)))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
current = current->next;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -451,7 +445,8 @@ tree_move_backward (WTree * tree, int i)
|
|||||||
int j = 0;
|
int j = 0;
|
||||||
|
|
||||||
current = tree->selected_ptr;
|
current = tree->selected_ptr;
|
||||||
while (j < i && current->prev && current->prev->sublevel >= tree->selected_ptr->sublevel)
|
while (j < i && current->prev != NULL
|
||||||
|
&& current->prev->sublevel >= tree->selected_ptr->sublevel)
|
||||||
{
|
{
|
||||||
current = current->prev;
|
current = current->prev;
|
||||||
if (current->sublevel == tree->selected_ptr->sublevel)
|
if (current->sublevel == tree->selected_ptr->sublevel)
|
||||||
@ -480,7 +475,8 @@ tree_move_forward (WTree * tree, int i)
|
|||||||
int j = 0;
|
int j = 0;
|
||||||
|
|
||||||
current = tree->selected_ptr;
|
current = tree->selected_ptr;
|
||||||
while (j < i && current->next && current->next->sublevel >= tree->selected_ptr->sublevel)
|
while (j < i && current->next != NULL
|
||||||
|
&& current->next->sublevel >= tree->selected_ptr->sublevel)
|
||||||
{
|
{
|
||||||
current = current->next;
|
current = current->next;
|
||||||
if (current->sublevel == tree->selected_ptr->sublevel)
|
if (current->sublevel == tree->selected_ptr->sublevel)
|
||||||
@ -504,12 +500,13 @@ tree_move_to_child (WTree * tree)
|
|||||||
tree_entry *current;
|
tree_entry *current;
|
||||||
|
|
||||||
/* Do we have a starting point? */
|
/* Do we have a starting point? */
|
||||||
if (!tree->selected_ptr)
|
if (tree->selected_ptr == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* Take the next entry */
|
/* Take the next entry */
|
||||||
current = tree->selected_ptr->next;
|
current = tree->selected_ptr->next;
|
||||||
/* Is it the child of the selected entry */
|
/* Is it the child of the selected entry */
|
||||||
if (current && current->sublevel > tree->selected_ptr->sublevel)
|
if (current != NULL && current->sublevel > tree->selected_ptr->sublevel)
|
||||||
{
|
{
|
||||||
/* Yes -> select this entry */
|
/* Yes -> select this entry */
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
@ -521,7 +518,7 @@ tree_move_to_child (WTree * tree)
|
|||||||
/* No -> rescan and try again */
|
/* No -> rescan and try again */
|
||||||
tree_rescan (tree);
|
tree_rescan (tree);
|
||||||
current = tree->selected_ptr->next;
|
current = tree->selected_ptr->next;
|
||||||
if (current && current->sublevel > tree->selected_ptr->sublevel)
|
if (current != NULL && current->sublevel > tree->selected_ptr->sublevel)
|
||||||
{
|
{
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
tree->topdiff++;
|
tree->topdiff++;
|
||||||
@ -538,17 +535,17 @@ tree_move_to_parent (WTree * tree)
|
|||||||
tree_entry *current;
|
tree_entry *current;
|
||||||
tree_entry *old;
|
tree_entry *old;
|
||||||
|
|
||||||
if (!tree->selected_ptr)
|
if (tree->selected_ptr == NULL)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
old = tree->selected_ptr;
|
old = tree->selected_ptr;
|
||||||
current = tree->selected_ptr->prev;
|
|
||||||
while (current && current->sublevel >= tree->selected_ptr->sublevel)
|
for (current = tree->selected_ptr->prev;
|
||||||
{
|
current != NULL && current->sublevel >= tree->selected_ptr->sublevel;
|
||||||
current = current->prev;
|
current = current->prev)
|
||||||
tree->topdiff--;
|
tree->topdiff--;
|
||||||
}
|
|
||||||
if (!current)
|
if (current == NULL)
|
||||||
current = tree->store->tree_first;
|
current = tree->store->tree_first;
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
tree_check_focus (tree);
|
tree_check_focus (tree);
|
||||||
@ -617,29 +614,31 @@ static int
|
|||||||
search_tree (WTree * tree, char *text)
|
search_tree (WTree * tree, char *text)
|
||||||
{
|
{
|
||||||
tree_entry *current;
|
tree_entry *current;
|
||||||
int len;
|
size_t len;
|
||||||
int wrapped = 0;
|
gboolean wrapped = FALSE;
|
||||||
int found = 0;
|
gboolean found = FALSE;
|
||||||
|
|
||||||
len = strlen (text);
|
len = strlen (text);
|
||||||
current = tree->selected_ptr;
|
current = tree->selected_ptr;
|
||||||
found = 0;
|
|
||||||
while (!wrapped || current != tree->selected_ptr)
|
while (!found && (!wrapped || current != tree->selected_ptr))
|
||||||
{
|
|
||||||
if (strncmp (current->subname, text, len) == 0)
|
if (strncmp (current->subname, text, len) == 0)
|
||||||
{
|
{
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
found = 1;
|
found = TRUE;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
current = current->next;
|
current = current->next;
|
||||||
if (!current)
|
if (current == NULL)
|
||||||
{
|
{
|
||||||
current = tree->store->tree_first;
|
current = tree->store->tree_first;
|
||||||
wrapped = 1;
|
wrapped = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
tree->topdiff++;
|
tree->topdiff++;
|
||||||
}
|
}
|
||||||
|
|
||||||
tree_check_focus (tree);
|
tree_check_focus (tree);
|
||||||
return found;
|
return found;
|
||||||
}
|
}
|
||||||
@ -661,7 +660,7 @@ tree_do_search (WTree * tree, int key)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!search_tree (tree, tree->search_buffer))
|
if (!search_tree (tree, tree->search_buffer))
|
||||||
tree->search_buffer[--l] = 0;
|
tree->search_buffer[--l] = '\0';
|
||||||
|
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
maybe_chdir (tree);
|
maybe_chdir (tree);
|
||||||
@ -696,7 +695,8 @@ static void
|
|||||||
tree_forget (void *data)
|
tree_forget (void *data)
|
||||||
{
|
{
|
||||||
WTree *tree = data;
|
WTree *tree = data;
|
||||||
if (tree->selected_ptr)
|
|
||||||
|
if (tree->selected_ptr != NULL)
|
||||||
tree_remove_entry (tree, tree->selected_ptr->name);
|
tree_remove_entry (tree, tree->selected_ptr->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -794,9 +794,7 @@ tree_mkdir (WTree * tree)
|
|||||||
{
|
{
|
||||||
char old_dir[MC_MAXPATHLEN];
|
char old_dir[MC_MAXPATHLEN];
|
||||||
|
|
||||||
if (!tree->selected_ptr)
|
if (tree->selected_ptr == NULL || chdir (tree->selected_ptr->name) != 0)
|
||||||
return;
|
|
||||||
if (chdir (tree->selected_ptr->name))
|
|
||||||
return;
|
return;
|
||||||
/* FIXME
|
/* FIXME
|
||||||
mkdir_cmd (tree);
|
mkdir_cmd (tree);
|
||||||
@ -815,7 +813,7 @@ tree_rmdir (void *data)
|
|||||||
file_op_context_t *ctx;
|
file_op_context_t *ctx;
|
||||||
file_op_total_context_t *tctx;
|
file_op_total_context_t *tctx;
|
||||||
|
|
||||||
if (!tree->selected_ptr)
|
if (tree->selected_ptr == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (confirm_delete)
|
if (confirm_delete)
|
||||||
@ -941,14 +939,14 @@ tree_move_right (WTree * tree)
|
|||||||
static void
|
static void
|
||||||
tree_start_search (WTree * tree)
|
tree_start_search (WTree * tree)
|
||||||
{
|
{
|
||||||
gboolean i;
|
|
||||||
|
|
||||||
if (tree->searching)
|
if (tree->searching)
|
||||||
{
|
{
|
||||||
if (tree->selected_ptr == tree->store->tree_last)
|
if (tree->selected_ptr == tree->store->tree_last)
|
||||||
tree_move_to_top (tree);
|
tree_move_to_top (tree);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
gboolean i;
|
||||||
|
|
||||||
/* set navigation mode temporarily to 'Static' because in
|
/* set navigation mode temporarily to 'Static' because in
|
||||||
* dynamic navigation mode tree_move_forward will not move
|
* dynamic navigation mode tree_move_forward will not move
|
||||||
* to a lower sublevel if necessary (sequent searches must
|
* to a lower sublevel if necessary (sequent searches must
|
||||||
@ -964,7 +962,7 @@ tree_start_search (WTree * tree)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
tree->searching = TRUE;
|
tree->searching = TRUE;
|
||||||
tree->search_buffer[0] = 0;
|
tree->search_buffer[0] = '\0';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1286,12 +1284,12 @@ tree_new (int y, int x, int lines, int cols, gboolean is_panel)
|
|||||||
widget_init (w, y, x, lines, cols, tree_callback, tree_mouse_callback);
|
widget_init (w, y, x, lines, cols, tree_callback, tree_mouse_callback);
|
||||||
w->options |= WOP_SELECTABLE | WOP_TOP_SELECT;
|
w->options |= WOP_SELECTABLE | WOP_TOP_SELECT;
|
||||||
tree->is_panel = is_panel;
|
tree->is_panel = is_panel;
|
||||||
tree->selected_ptr = 0;
|
tree->selected_ptr = NULL;
|
||||||
|
|
||||||
tree->store = tree_store_get ();
|
tree->store = tree_store_get ();
|
||||||
tree_store_add_entry_remove_hook (remove_callback, tree);
|
tree_store_add_entry_remove_hook (remove_callback, tree);
|
||||||
tree->tree_shown = 0;
|
tree->tree_shown = NULL;
|
||||||
tree->search_buffer[0] = 0;
|
tree->search_buffer[0] = '\0';
|
||||||
tree->topdiff = w->lines / 2;
|
tree->topdiff = w->lines / 2;
|
||||||
tree->searching = FALSE;
|
tree->searching = FALSE;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user