mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-18 17:29:28 +03:00
Implemeted keybindings for Tree widget
Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
9b82c05fca
commit
efdb645468
@ -298,7 +298,7 @@ InputBackwardDelete = backspace
|
|||||||
InputDeleteChar = delete
|
InputDeleteChar = delete
|
||||||
InputKillWord = alt-d
|
InputKillWord = alt-d
|
||||||
InputBackwardKillWord = alt-backspace
|
InputBackwardKillWord = alt-backspace
|
||||||
InputSetMark =
|
InputSetMark =
|
||||||
InputKillRegion = ctrl-w
|
InputKillRegion = ctrl-w
|
||||||
InputXStore = alt-w
|
InputXStore = alt-w
|
||||||
InputXPaste =
|
InputXPaste =
|
||||||
@ -309,3 +309,22 @@ InputHistoryNext = alt-n; ctrl-up
|
|||||||
InputHistoryShow = alt-h
|
InputHistoryShow = alt-h
|
||||||
InputComplete = alt-tab
|
InputComplete = alt-tab
|
||||||
InputClearLine =
|
InputClearLine =
|
||||||
|
|
||||||
|
[tree]
|
||||||
|
TreeHelp = f1
|
||||||
|
TreeForget = f3
|
||||||
|
TreeToggleNav = f4
|
||||||
|
TreeCopy = f5
|
||||||
|
TreeMove = f6
|
||||||
|
TreeMoveUp = up; ctrl-p
|
||||||
|
TreeMoveDown = down; ctrl-n
|
||||||
|
TreeMoveLeft = left
|
||||||
|
TreeMoveRight = right
|
||||||
|
TreeMoveHome = home; alt-lt
|
||||||
|
TreeMoveEnd = end; alt-gt
|
||||||
|
TreeMovePgUp = pgup; alt-v
|
||||||
|
TreeMovePgDn = pgdn; ctrl-v
|
||||||
|
TreeOpen = enter
|
||||||
|
TreeRescan = f2; ctrl-r
|
||||||
|
TreeStartSearch = ctrl-s; alt-s
|
||||||
|
TreeRemove = f8; delete
|
||||||
|
@ -313,3 +313,22 @@ InputHistoryNext = alt-n; ctrl-up
|
|||||||
InputHistoryShow = alt-h
|
InputHistoryShow = alt-h
|
||||||
InputComplete = alt-tab
|
InputComplete = alt-tab
|
||||||
InputClearLine =
|
InputClearLine =
|
||||||
|
|
||||||
|
[tree]
|
||||||
|
TreeHelp = f1
|
||||||
|
TreeForget = f3
|
||||||
|
TreeToggleNav = f4
|
||||||
|
TreeCopy = f5
|
||||||
|
TreeMove = f6
|
||||||
|
TreeMoveUp = up; ctrl-p
|
||||||
|
TreeMoveDown = down; ctrl-n
|
||||||
|
TreeMoveLeft = left
|
||||||
|
TreeMoveRight = right
|
||||||
|
TreeMoveHome = home; alt-lt
|
||||||
|
TreeMoveEnd = end; alt-gt
|
||||||
|
TreeMovePgUp = pgup; alt-v
|
||||||
|
TreeMovePgDn = pgdn; ctrl-v
|
||||||
|
TreeOpen = enter
|
||||||
|
TreeRescan = f2; ctrl-r
|
||||||
|
TreeStartSearch = ctrl-s; alt-s
|
||||||
|
TreeRemove = f8; delete
|
||||||
|
@ -674,6 +674,7 @@ tree_box (const char *current_dir)
|
|||||||
add_widget (dlg, mytree);
|
add_widget (dlg, mytree);
|
||||||
bar = buttonbar_new(1);
|
bar = buttonbar_new(1);
|
||||||
add_widget (dlg, bar);
|
add_widget (dlg, bar);
|
||||||
|
/* restore ButtonBar coordinates after add_widget() */
|
||||||
((Widget *) bar)->x = 0;
|
((Widget *) bar)->x = 0;
|
||||||
((Widget *) bar)->y = LINES - 1;
|
((Widget *) bar)->y = LINES - 1;
|
||||||
|
|
||||||
|
20
src/cmddef.h
20
src/cmddef.h
@ -251,6 +251,26 @@
|
|||||||
#define CK_HexViewToggleNavigationMode 5018
|
#define CK_HexViewToggleNavigationMode 5018
|
||||||
#define CK_ViewQuit 5020
|
#define CK_ViewQuit 5020
|
||||||
|
|
||||||
|
/* Tree */
|
||||||
|
#define CK_TreeHelp 6001
|
||||||
|
#define CK_TreeForget 6003
|
||||||
|
#define CK_TreeToggleNav 6004
|
||||||
|
#define CK_TreeCopy 6005
|
||||||
|
#define CK_TreeMove 6006
|
||||||
|
#define CK_TreeMake 6007
|
||||||
|
#define CK_TreeMoveUp 6011
|
||||||
|
#define CK_TreeMoveDown 6012
|
||||||
|
#define CK_TreeMoveLeft 6013
|
||||||
|
#define CK_TreeMoveRight 6014
|
||||||
|
#define CK_TreeMoveHome 6015
|
||||||
|
#define CK_TreeMoveEnd 6016
|
||||||
|
#define CK_TreeMovePgUp 6017
|
||||||
|
#define CK_TreeMovePgDn 6018
|
||||||
|
#define CK_TreeOpen 6019
|
||||||
|
#define CK_TreeRescan 6020
|
||||||
|
#define CK_TreeStartSearch 6021
|
||||||
|
#define CK_TreeRemove 6022
|
||||||
|
|
||||||
/* main commands */
|
/* main commands */
|
||||||
#define CK_AddHotlist 7001
|
#define CK_AddHotlist 7001
|
||||||
#define CK_ChmodCmd 7002
|
#define CK_ChmodCmd 7002
|
||||||
|
@ -215,7 +215,7 @@ static name_keymap_t command_names[] = {
|
|||||||
{ "EditMaximize", CK_Maximize },
|
{ "EditMaximize", CK_Maximize },
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif /* USE_INTERNAL_EDIT */
|
||||||
|
|
||||||
/* viewer */
|
/* viewer */
|
||||||
{ "ViewSearch", CK_ViewSearch },
|
{ "ViewSearch", CK_ViewSearch },
|
||||||
@ -238,6 +238,26 @@ static name_keymap_t command_names[] = {
|
|||||||
{ "HexViewToggleNavigationMode", CK_HexViewToggleNavigationMode },
|
{ "HexViewToggleNavigationMode", CK_HexViewToggleNavigationMode },
|
||||||
{ "ViewQuit", CK_ViewQuit },
|
{ "ViewQuit", CK_ViewQuit },
|
||||||
|
|
||||||
|
/* tree */
|
||||||
|
{ "TreeHelp", CK_TreeHelp },
|
||||||
|
{ "TreeForget", CK_TreeForget },
|
||||||
|
{ "TreeToggleNav", CK_TreeToggleNav },
|
||||||
|
{ "TreeCopy", CK_TreeCopy },
|
||||||
|
{ "TreeMove", CK_TreeMove },
|
||||||
|
{ "TreeMake", CK_TreeMake },
|
||||||
|
{ "TreeMoveUp", CK_TreeMoveUp },
|
||||||
|
{ "TreeMoveDown", CK_TreeMoveDown },
|
||||||
|
{ "TreeMoveLeft", CK_TreeMoveLeft },
|
||||||
|
{ "TreeMoveRight", CK_TreeMoveRight },
|
||||||
|
{ "TreeMoveHome", CK_TreeMoveHome },
|
||||||
|
{ "TreeMoveEnd", CK_TreeMoveEnd },
|
||||||
|
{ "TreeMovePgUp", CK_TreeMovePgUp },
|
||||||
|
{ "TreeMovePgDn", CK_TreeMovePgDn },
|
||||||
|
{ "TreeOpen", CK_TreeOpen },
|
||||||
|
{ "TreeRescan", CK_TreeRescan },
|
||||||
|
{ "TreeStartSearch", CK_TreeStartSearch },
|
||||||
|
{ "TreeRemove", CK_TreeRemove },
|
||||||
|
|
||||||
/* main commands */
|
/* main commands */
|
||||||
{ "CmdChmod", CK_ChmodCmd },
|
{ "CmdChmod", CK_ChmodCmd },
|
||||||
{ "CmdMenuLastSelected", CK_MenuLastSelectedCmd },
|
{ "CmdMenuLastSelected", CK_MenuLastSelectedCmd },
|
||||||
@ -398,7 +418,7 @@ static name_keymap_t command_names[] = {
|
|||||||
{ "ShowCommandLine", CK_ShowCommandLine },
|
{ "ShowCommandLine", CK_ShowCommandLine },
|
||||||
{ "SelectCodepage", CK_SelectCodepage },
|
{ "SelectCodepage", CK_SelectCodepage },
|
||||||
|
|
||||||
{ NULL, 0 }
|
{ NULL, CK_Ignore_Key }
|
||||||
};
|
};
|
||||||
|
|
||||||
static const size_t num_command_names = sizeof (command_names) /
|
static const size_t num_command_names = sizeof (command_names) /
|
||||||
@ -458,7 +478,7 @@ const global_keymap_t default_viewer_keymap[] = {
|
|||||||
{ ALT ('e'), CK_SelectCodepage, "M-e" },
|
{ ALT ('e'), CK_SelectCodepage, "M-e" },
|
||||||
{ XCTRL ('o'), CK_ShowCommandLine, "C-o" },
|
{ XCTRL ('o'), CK_ShowCommandLine, "C-o" },
|
||||||
|
|
||||||
{ 0, 0, "" }
|
{ 0, CK_Ignore_Key, "" }
|
||||||
};
|
};
|
||||||
|
|
||||||
const global_keymap_t default_viewer_hex_keymap[] = {
|
const global_keymap_t default_viewer_hex_keymap[] = {
|
||||||
@ -480,7 +500,7 @@ const global_keymap_t default_viewer_hex_keymap[] = {
|
|||||||
{ KEY_DOWN, CK_ViewMoveDown, "Down" },
|
{ KEY_DOWN, CK_ViewMoveDown, "Down" },
|
||||||
{ KEY_DC, CK_ViewMoveDown, "Delete" },
|
{ KEY_DC, CK_ViewMoveDown, "Delete" },
|
||||||
|
|
||||||
{ 0, 0, "" }
|
{ 0, CK_Ignore_Key, "" }
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef USE_INTERNAL_EDIT
|
#ifdef USE_INTERNAL_EDIT
|
||||||
@ -604,17 +624,52 @@ const global_keymap_t default_editor_keymap[] = {
|
|||||||
|
|
||||||
{ XCTRL ('x'), CK_Ext_Mode, "C-x" },
|
{ XCTRL ('x'), CK_Ext_Mode, "C-x" },
|
||||||
|
|
||||||
{ 0, 0, "" }
|
{ 0, CK_Ignore_Key, "" }
|
||||||
};
|
};
|
||||||
|
|
||||||
/* emacs keyboard layout emulation */
|
/* emacs keyboard layout emulation */
|
||||||
const global_keymap_t default_editor_x_keymap[] = {
|
const global_keymap_t default_editor_x_keymap[] = {
|
||||||
{ 'k', CK_New, "k"},
|
{ 'k', CK_New, "k"},
|
||||||
{ 'e', CK_Execute_Macro, "e"},
|
{ 'e', CK_Execute_Macro, "e"},
|
||||||
{ 0, 0, "" }
|
{ 0, CK_Ignore_Key, "" }
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* tree */
|
||||||
|
const global_keymap_t default_tree_keymap[] = {
|
||||||
|
{ KEY_F (1), CK_TreeHelp, "F1"},
|
||||||
|
{ KEY_F (2), CK_TreeRescan, "F2" },
|
||||||
|
{ KEY_F (3), CK_TreeForget, "F3" },
|
||||||
|
{ KEY_F (4), CK_TreeToggleNav, "F4" },
|
||||||
|
{ KEY_F (5), CK_TreeCopy, "F5" },
|
||||||
|
{ KEY_F (6), CK_TreeMove, "F6" },
|
||||||
|
#if 0
|
||||||
|
{ KEY_F (7), CK_TreeMake, "F7" },
|
||||||
|
#endif
|
||||||
|
{ KEY_F (8), CK_TreeRemove, "F8" },
|
||||||
|
{ KEY_UP, CK_TreeMoveUp, "Up" },
|
||||||
|
{ XCTRL ('p'), CK_TreeMoveUp, "C-p" },
|
||||||
|
{ KEY_DOWN, CK_TreeMoveDown, "Down" },
|
||||||
|
{ XCTRL ('n'), CK_TreeMoveDown, "C-n" },
|
||||||
|
{ KEY_LEFT, CK_TreeMoveLeft, "Left" },
|
||||||
|
{ KEY_RIGHT, CK_TreeMoveRight, "Right" },
|
||||||
|
{ KEY_HOME, CK_TreeMoveHome, "Home" },
|
||||||
|
{ ALT ('<'), CK_TreeMoveHome, "M-<" },
|
||||||
|
{ KEY_END, CK_TreeMoveEnd , "End" },
|
||||||
|
{ ALT ('>'), CK_TreeMoveEnd , "M->" },
|
||||||
|
{ KEY_PPAGE, CK_TreeMovePgUp, "PgUp" },
|
||||||
|
{ ALT ('v'), CK_TreeMovePgUp, "M-v" },
|
||||||
|
{ KEY_NPAGE, CK_TreeMovePgDn, "PnDn" },
|
||||||
|
{ XCTRL ('v'), CK_TreeMovePgDn, "C-v" },
|
||||||
|
{ '\n', CK_TreeOpen, "Enter" },
|
||||||
|
{ KEY_ENTER, CK_TreeOpen, "Enter" },
|
||||||
|
{ XCTRL ('r'), CK_TreeRescan, "C-r" },
|
||||||
|
{ XCTRL ('s'), CK_TreeStartSearch, "C-s" },
|
||||||
|
{ ALT ('s'), CK_TreeStartSearch, "M-s" },
|
||||||
|
{ KEY_DC, CK_TreeRemove, "Delete" },
|
||||||
|
{ 0, CK_Ignore_Key, ""}
|
||||||
|
};
|
||||||
|
|
||||||
/* screen.c */
|
/* screen.c */
|
||||||
const global_keymap_t default_panel_keymap[] = {
|
const global_keymap_t default_panel_keymap[] = {
|
||||||
{ ALT ('o'), CK_PanelChdirOtherPanel, "M-o" },
|
{ ALT ('o'), CK_PanelChdirOtherPanel, "M-o" },
|
||||||
@ -651,8 +706,7 @@ const global_keymap_t default_panel_keymap[] = {
|
|||||||
{ XCTRL ('s'), CK_PanelStartSearch, "C-s" },
|
{ XCTRL ('s'), CK_PanelStartSearch, "C-s" },
|
||||||
{ ALT ('s'), CK_PanelStartSearch, "M-s" },
|
{ ALT ('s'), CK_PanelStartSearch, "M-s" },
|
||||||
{ ALT ('i'), CK_PanelSyncOtherPanel, "M-i" },
|
{ ALT ('i'), CK_PanelSyncOtherPanel, "M-i" },
|
||||||
|
{ 0, CK_Ignore_Key , "" }
|
||||||
{ 0, 0 , "" }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/* main.c */
|
/* main.c */
|
||||||
@ -696,8 +750,7 @@ const global_keymap_t default_main_map[] = {
|
|||||||
{ ALT ('*'), CK_SelectCmd, "M-*" },
|
{ ALT ('*'), CK_SelectCmd, "M-*" },
|
||||||
{ KEY_KP_ADD, CK_UnselectCmd, "Gray+" },
|
{ KEY_KP_ADD, CK_UnselectCmd, "Gray+" },
|
||||||
{ KEY_KP_SUBTRACT, CK_ReverseSelectionCmd, "Gray-" },
|
{ KEY_KP_SUBTRACT, CK_ReverseSelectionCmd, "Gray-" },
|
||||||
|
{ 0, CK_Ignore_Key, "" }
|
||||||
{ 0, 0, "" }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const global_keymap_t default_main_x_map[] = {
|
const global_keymap_t default_main_x_map[] = {
|
||||||
@ -725,8 +778,7 @@ const global_keymap_t default_main_x_map[] = {
|
|||||||
#ifdef WITH_BACKGROUND
|
#ifdef WITH_BACKGROUND
|
||||||
{ 'j', CK_JobsCmd, "j" },
|
{ 'j', CK_JobsCmd, "j" },
|
||||||
#endif /* WITH_BACKGROUND */
|
#endif /* WITH_BACKGROUND */
|
||||||
|
{ 0, CK_Ignore_Key, "" }
|
||||||
{ 0, 0, "" }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const global_keymap_t default_input_keymap[] = {
|
const global_keymap_t default_input_keymap[] = {
|
||||||
@ -769,7 +821,7 @@ const global_keymap_t default_input_keymap[] = {
|
|||||||
/* Completion */
|
/* Completion */
|
||||||
{ ALT ('\t'), CK_InputComplete, "M-tab" },
|
{ ALT ('\t'), CK_InputComplete, "M-tab" },
|
||||||
|
|
||||||
{ 0, 0, "" }
|
{ 0, CK_Ignore_Key, "" }
|
||||||
};
|
};
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -804,7 +856,7 @@ lookup_action (const char *keyname)
|
|||||||
res = bsearch (&key, command_names, num_command_names,
|
res = bsearch (&key, command_names, num_command_names,
|
||||||
sizeof (command_names[0]), name_keymap_comparator);
|
sizeof (command_names[0]), name_keymap_comparator);
|
||||||
|
|
||||||
return (res != NULL) ? res->val : 0;
|
return (res != NULL) ? res->val : CK_Ignore_Key;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -38,6 +38,9 @@ extern const global_keymap_t default_editor_keymap[];
|
|||||||
extern const global_keymap_t default_editor_x_keymap[];
|
extern const global_keymap_t default_editor_x_keymap[];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* tree.c */
|
||||||
|
extern const global_keymap_t default_tree_keymap[];
|
||||||
|
|
||||||
/* screen.c */
|
/* screen.c */
|
||||||
extern const global_keymap_t default_panel_keymap[];
|
extern const global_keymap_t default_panel_keymap[];
|
||||||
|
|
||||||
|
12
src/main.c
12
src/main.c
@ -316,6 +316,7 @@ GArray *main_keymap = NULL;
|
|||||||
GArray *main_x_keymap = NULL;
|
GArray *main_x_keymap = NULL;
|
||||||
GArray *panel_keymap = NULL;
|
GArray *panel_keymap = NULL;
|
||||||
GArray *input_keymap = NULL;
|
GArray *input_keymap = NULL;
|
||||||
|
GArray *tree_keymap = NULL;
|
||||||
|
|
||||||
const global_keymap_t *main_map;
|
const global_keymap_t *main_map;
|
||||||
const global_keymap_t *main_x_map;
|
const global_keymap_t *main_x_map;
|
||||||
@ -1879,26 +1880,25 @@ do_nc (void)
|
|||||||
check_codeset ();
|
check_codeset ();
|
||||||
|
|
||||||
main_map = default_main_map;
|
main_map = default_main_map;
|
||||||
|
|
||||||
if (main_keymap && main_keymap->len > 0)
|
if (main_keymap && main_keymap->len > 0)
|
||||||
main_map = (global_keymap_t *) main_keymap->data;
|
main_map = (global_keymap_t *) main_keymap->data;
|
||||||
|
|
||||||
main_x_map = default_main_x_map;
|
main_x_map = default_main_x_map;
|
||||||
|
|
||||||
if (main_x_keymap && main_x_keymap->len > 0)
|
if (main_x_keymap && main_x_keymap->len > 0)
|
||||||
main_x_map = (global_keymap_t *) main_x_keymap->data;
|
main_x_map = (global_keymap_t *) main_x_keymap->data;
|
||||||
|
|
||||||
panel_map = default_panel_keymap;
|
panel_map = default_panel_keymap;
|
||||||
|
if (panel_keymap && panel_keymap->len > 0)
|
||||||
if (panel_keymap && panel_keymap->len > 0) {
|
|
||||||
panel_map = (global_keymap_t *) panel_keymap->data;
|
panel_map = (global_keymap_t *) panel_keymap->data;
|
||||||
}
|
|
||||||
|
|
||||||
input_map = default_input_keymap;
|
input_map = default_input_keymap;
|
||||||
|
|
||||||
if (input_keymap && input_keymap->len > 0)
|
if (input_keymap && input_keymap->len > 0)
|
||||||
input_map = (global_keymap_t *) input_keymap->data;
|
input_map = (global_keymap_t *) input_keymap->data;
|
||||||
|
|
||||||
|
tree_map = default_tree_keymap;
|
||||||
|
if (tree_keymap && tree_keymap->len > 0)
|
||||||
|
tree_map = (global_keymap_t *) tree_keymap->data;
|
||||||
|
|
||||||
/* Check if we were invoked as an editor or file viewer */
|
/* Check if we were invoked as an editor or file viewer */
|
||||||
if (!mc_maybe_editor_or_viewer ()) {
|
if (!mc_maybe_editor_or_viewer ()) {
|
||||||
setup_panels_and_run_mc ();
|
setup_panels_and_run_mc ();
|
||||||
|
@ -83,11 +83,13 @@ extern GArray *viewer_keymap;
|
|||||||
extern GArray *viewer_hex_keymap;
|
extern GArray *viewer_hex_keymap;
|
||||||
extern GArray *main_keymap;
|
extern GArray *main_keymap;
|
||||||
extern GArray *main_x_keymap;
|
extern GArray *main_x_keymap;
|
||||||
|
extern GArray *tree_keymap;
|
||||||
extern GArray *panel_keymap;
|
extern GArray *panel_keymap;
|
||||||
extern GArray *input_keymap;
|
extern GArray *input_keymap;
|
||||||
|
|
||||||
extern const global_keymap_t *panel_map;
|
extern const global_keymap_t *panel_map;
|
||||||
extern const global_keymap_t *input_map;
|
extern const global_keymap_t *input_map;
|
||||||
|
extern const global_keymap_t *tree_map;
|
||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
void do_update_prompt (void);
|
void do_update_prompt (void);
|
||||||
|
@ -1011,6 +1011,9 @@ load_keymap_defs (void)
|
|||||||
input_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
input_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
||||||
load_keymap_from_section ("input", input_keymap, mc_global_keymap);
|
load_keymap_from_section ("input", input_keymap, mc_global_keymap);
|
||||||
|
|
||||||
|
tree_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
||||||
|
load_keymap_from_section ("tree", tree_keymap, mc_global_keymap);
|
||||||
|
|
||||||
mc_config_deinit (mc_global_keymap);
|
mc_config_deinit (mc_global_keymap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1028,6 +1031,7 @@ free_keymap_defs (void)
|
|||||||
g_array_free (main_x_keymap, TRUE);
|
g_array_free (main_x_keymap, TRUE);
|
||||||
g_array_free (panel_keymap, TRUE);
|
g_array_free (panel_keymap, TRUE);
|
||||||
g_array_free (input_keymap, TRUE);
|
g_array_free (input_keymap, TRUE);
|
||||||
|
g_array_free (tree_keymap, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
583
src/tree.c
583
src/tree.c
@ -54,23 +54,26 @@
|
|||||||
#include "main-widgets.h" /* the_menubar */
|
#include "main-widgets.h" /* the_menubar */
|
||||||
#include "menu.h" /* menubar_visible */
|
#include "menu.h" /* menubar_visible */
|
||||||
#include "file.h" /* copy_dir_dir(), move_dir_dir(), erase_dir() */
|
#include "file.h" /* copy_dir_dir(), move_dir_dir(), erase_dir() */
|
||||||
|
#include "layout.h" /* command_prompt */
|
||||||
#include "help.h"
|
#include "help.h"
|
||||||
#include "treestore.h"
|
#include "treestore.h"
|
||||||
#include "cmd.h"
|
#include "cmd.h"
|
||||||
|
#include "cmddef.h"
|
||||||
|
#include "keybind.h"
|
||||||
#include "history.h"
|
#include "history.h"
|
||||||
#include "strutil.h"
|
#include "strutil.h"
|
||||||
#include "tree.h"
|
|
||||||
#include "fileloc.h"
|
#include "fileloc.h"
|
||||||
|
#include "tree.h"
|
||||||
|
|
||||||
#define tlines(t) (t->is_panel ? t->widget.lines-2 - (show_mini_info ? 2 : 0) : t->widget.lines)
|
const global_keymap_t *tree_map;
|
||||||
|
|
||||||
extern int command_prompt;
|
#define tlines(t) (t->is_panel ? t->widget.lines - 2 - (show_mini_info ? 2 : 0) : t->widget.lines)
|
||||||
|
|
||||||
/* Use the color of the parent widget for the unselected entries */
|
/* Use the color of the parent widget for the unselected entries */
|
||||||
#define TREE_NORMALC(h) (DLG_NORMALC (h))
|
#define TREE_NORMALC(h) (DLG_NORMALC (h))
|
||||||
|
|
||||||
/* Specifies the display mode: 1d or 2d */
|
/* Specifies the display mode: 1d or 2d */
|
||||||
static int tree_navigation_flag;
|
static gboolean tree_navigation_flag = FALSE;
|
||||||
|
|
||||||
struct WTree {
|
struct WTree {
|
||||||
Widget widget;
|
Widget widget;
|
||||||
@ -86,10 +89,11 @@ struct WTree {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* Forwards */
|
/* Forwards */
|
||||||
static void save_tree (WTree *tree);
|
static void tree_rescan (void *data);
|
||||||
static void tree_rescan_cmd (WTree *);
|
static void tree_toggle_f4 (void *data);
|
||||||
|
|
||||||
static tree_entry *back_ptr (tree_entry *ptr, int *count)
|
static tree_entry *
|
||||||
|
back_ptr (tree_entry *ptr, int *count)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
@ -101,7 +105,8 @@ static tree_entry *back_ptr (tree_entry *ptr, int *count)
|
|||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static tree_entry *forw_ptr (tree_entry *ptr, int *count)
|
static tree_entry *
|
||||||
|
forw_ptr (tree_entry *ptr, int *count)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
@ -116,23 +121,45 @@ static tree_entry *forw_ptr (tree_entry *ptr, int *count)
|
|||||||
static void
|
static void
|
||||||
remove_callback (tree_entry *entry, void *data)
|
remove_callback (tree_entry *entry, void *data)
|
||||||
{
|
{
|
||||||
WTree *tree = data;
|
WTree *tree = data;
|
||||||
|
|
||||||
if (tree->selected_ptr == entry){
|
if (tree->selected_ptr == entry){
|
||||||
if (tree->selected_ptr->next)
|
if (tree->selected_ptr->next)
|
||||||
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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_remove_entry (WTree *tree, char *name)
|
/* Save the ~/.mc/Tree file */
|
||||||
|
static void
|
||||||
|
save_tree (WTree *tree)
|
||||||
|
{
|
||||||
|
int error;
|
||||||
|
char *tree_name;
|
||||||
|
|
||||||
|
(void) tree;
|
||||||
|
error = tree_store_save ();
|
||||||
|
|
||||||
|
|
||||||
|
if (error){
|
||||||
|
tree_name = g_build_filename (home_dir, MC_USERCONF_DIR,
|
||||||
|
MC_TREESTORE_FILE, (char *) NULL);
|
||||||
|
fprintf (stderr, _("Cannot open the %s file for writing:\n%s\n"), tree_name,
|
||||||
|
unix_error_string (error));
|
||||||
|
g_free (tree_name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
tree_remove_entry (WTree *tree, char *name)
|
||||||
{
|
{
|
||||||
(void) tree;
|
(void) tree;
|
||||||
tree_store_remove_entry (name);
|
tree_store_remove_entry (name);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_destroy (WTree *tree)
|
static void
|
||||||
|
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);
|
||||||
@ -143,7 +170,8 @@ static void tree_destroy (WTree *tree)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Loads the .mc.tree file */
|
/* Loads the .mc.tree file */
|
||||||
static void load_tree (WTree *tree)
|
static void
|
||||||
|
load_tree (WTree *tree)
|
||||||
{
|
{
|
||||||
tree_store_load ();
|
tree_store_load ();
|
||||||
|
|
||||||
@ -151,25 +179,8 @@ static void load_tree (WTree *tree)
|
|||||||
tree_chdir (tree, home_dir);
|
tree_chdir (tree, home_dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Save the .mc.tree file */
|
static void
|
||||||
static void save_tree (WTree *tree)
|
tree_show_mini_info (WTree *tree, int tree_lines, int tree_cols)
|
||||||
{
|
|
||||||
int error;
|
|
||||||
char *tree_name;
|
|
||||||
|
|
||||||
(void) tree;
|
|
||||||
error = tree_store_save ();
|
|
||||||
|
|
||||||
|
|
||||||
if (error){
|
|
||||||
tree_name = g_build_filename (home_dir, MC_USERCONF_DIR, MC_TREESTORE_FILE, NULL);
|
|
||||||
fprintf (stderr, _("Cannot open the %s file for writing:\n%s\n"), tree_name,
|
|
||||||
unix_error_string (error));
|
|
||||||
g_free(tree_name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void tree_show_mini_info (WTree *tree, int tree_lines, int tree_cols)
|
|
||||||
{
|
{
|
||||||
Dlg_head *h = tree->widget.parent;
|
Dlg_head *h = tree->widget.parent;
|
||||||
int line;
|
int line;
|
||||||
@ -202,7 +213,8 @@ static void tree_show_mini_info (WTree *tree, int tree_lines, int tree_cols)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void show_tree (WTree *tree)
|
static void
|
||||||
|
show_tree (WTree *tree)
|
||||||
{
|
{
|
||||||
Dlg_head *h = tree->widget.parent;
|
Dlg_head *h = tree->widget.parent;
|
||||||
tree_entry *current;
|
tree_entry *current;
|
||||||
@ -238,7 +250,9 @@ static void show_tree (WTree *tree)
|
|||||||
current = tree->selected_ptr;
|
current = tree->selected_ptr;
|
||||||
|
|
||||||
/* Calculate the directory which is to be shown on the topmost line */
|
/* Calculate the directory which is to be shown on the topmost line */
|
||||||
if (tree_navigation_flag){
|
if (!tree_navigation_flag)
|
||||||
|
current = back_ptr (current, &tree->topdiff);
|
||||||
|
else {
|
||||||
i = 0;
|
i = 0;
|
||||||
while (current->prev && i < tree->topdiff){
|
while (current->prev && i < tree->topdiff){
|
||||||
current = current->prev;
|
current = current->prev;
|
||||||
@ -258,8 +272,7 @@ static void show_tree (WTree *tree)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
tree->topdiff = i;
|
tree->topdiff = i;
|
||||||
} else
|
}
|
||||||
current = back_ptr (current, &tree->topdiff);
|
|
||||||
|
|
||||||
/* Loop for every line */
|
/* Loop for every line */
|
||||||
for (i = 0; i < tree_lines; i++){
|
for (i = 0; i < tree_lines; i++){
|
||||||
@ -348,7 +361,8 @@ static void show_tree (WTree *tree)
|
|||||||
tree_show_mini_info (tree, tree_lines, tree_cols);
|
tree_show_mini_info (tree, tree_lines, tree_cols);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void check_focus (WTree *tree)
|
static void
|
||||||
|
tree_check_focus (WTree *tree)
|
||||||
{
|
{
|
||||||
if (tree->topdiff < 3)
|
if (tree->topdiff < 3)
|
||||||
tree->topdiff = 3;
|
tree->topdiff = 3;
|
||||||
@ -356,34 +370,40 @@ static void check_focus (WTree *tree)
|
|||||||
tree->topdiff = tlines (tree) - 3 - 1;
|
tree->topdiff = tlines (tree) - 3 - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_move_backward (WTree *tree, int i)
|
static void
|
||||||
|
tree_move_backward (WTree *tree, int i)
|
||||||
{
|
{
|
||||||
tree_entry *current;
|
if (!tree_navigation_flag)
|
||||||
int j = 0;
|
tree->selected_ptr = back_ptr (tree->selected_ptr, &i);
|
||||||
|
else {
|
||||||
|
tree_entry *current;
|
||||||
|
int j = 0;
|
||||||
|
|
||||||
if (tree_navigation_flag){
|
|
||||||
current = tree->selected_ptr;
|
current = tree->selected_ptr;
|
||||||
while (j < i && current->prev
|
while (j < i && current->prev
|
||||||
&& current->prev->sublevel >= tree->selected_ptr->sublevel){
|
&& 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){
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
j ++;
|
j++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
i = j;
|
i = j;
|
||||||
} else
|
}
|
||||||
tree->selected_ptr = back_ptr (tree->selected_ptr, &i);
|
|
||||||
tree->topdiff -= i;
|
tree->topdiff -= i;
|
||||||
check_focus (tree);
|
tree_check_focus (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_move_forward (WTree *tree, int i)
|
static void
|
||||||
|
tree_move_forward (WTree *tree, int i)
|
||||||
{
|
{
|
||||||
tree_entry *current;
|
if (!tree_navigation_flag)
|
||||||
int j = 0;
|
tree->selected_ptr = forw_ptr (tree->selected_ptr, &i);
|
||||||
|
else {
|
||||||
|
tree_entry *current;
|
||||||
|
int j = 0;
|
||||||
|
|
||||||
if (tree_navigation_flag){
|
|
||||||
current = tree->selected_ptr;
|
current = tree->selected_ptr;
|
||||||
while (j < i && current->next
|
while (j < i && current->next
|
||||||
&& current->next->sublevel >= tree->selected_ptr->sublevel){
|
&& current->next->sublevel >= tree->selected_ptr->sublevel){
|
||||||
@ -394,13 +414,14 @@ static void tree_move_forward (WTree *tree, int i)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
i = j;
|
i = j;
|
||||||
} else
|
}
|
||||||
tree->selected_ptr = forw_ptr (tree->selected_ptr, &i);
|
|
||||||
tree->topdiff += i;
|
tree->topdiff += i;
|
||||||
check_focus (tree);
|
tree_check_focus (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_move_to_child (WTree *tree)
|
static void
|
||||||
|
tree_move_to_child (WTree *tree)
|
||||||
{
|
{
|
||||||
tree_entry *current;
|
tree_entry *current;
|
||||||
|
|
||||||
@ -414,26 +435,28 @@ static void tree_move_to_child (WTree *tree)
|
|||||||
/* Yes -> select this entry */
|
/* Yes -> select this entry */
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
tree->topdiff++;
|
tree->topdiff++;
|
||||||
check_focus (tree);
|
tree_check_focus (tree);
|
||||||
} else {
|
} else {
|
||||||
/* No -> rescan and try again */
|
/* No -> rescan and try again */
|
||||||
tree_rescan_cmd (tree);
|
tree_rescan (tree);
|
||||||
current = tree->selected_ptr->next;
|
current = tree->selected_ptr->next;
|
||||||
if (current && current->sublevel > tree->selected_ptr->sublevel){
|
if (current && current->sublevel > tree->selected_ptr->sublevel){
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
tree->topdiff++;
|
tree->topdiff++;
|
||||||
check_focus (tree);
|
tree_check_focus (tree);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tree_move_to_parent (WTree *tree)
|
static gboolean
|
||||||
|
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)
|
||||||
return 0;
|
return FALSE;
|
||||||
|
|
||||||
old = tree->selected_ptr;
|
old = tree->selected_ptr;
|
||||||
current = tree->selected_ptr->prev;
|
current = tree->selected_ptr->prev;
|
||||||
while (current && current->sublevel >= tree->selected_ptr->sublevel){
|
while (current && current->sublevel >= tree->selected_ptr->sublevel){
|
||||||
@ -443,39 +466,24 @@ static int tree_move_to_parent (WTree *tree)
|
|||||||
if (!current)
|
if (!current)
|
||||||
current = tree->store->tree_first;
|
current = tree->store->tree_first;
|
||||||
tree->selected_ptr = current;
|
tree->selected_ptr = current;
|
||||||
check_focus (tree);
|
tree_check_focus (tree);
|
||||||
return tree->selected_ptr != old;
|
return tree->selected_ptr != old;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_move_to_top (WTree *tree)
|
static void
|
||||||
|
tree_move_to_top (WTree *tree)
|
||||||
{
|
{
|
||||||
tree->selected_ptr = tree->store->tree_first;
|
tree->selected_ptr = tree->store->tree_first;
|
||||||
tree->topdiff = 0;
|
tree->topdiff = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_move_to_bottom (WTree *tree)
|
static void
|
||||||
|
tree_move_to_bottom (WTree *tree)
|
||||||
{
|
{
|
||||||
tree->selected_ptr = tree->store->tree_last;
|
tree->selected_ptr = tree->store->tree_last;
|
||||||
tree->topdiff = tlines (tree) - 3 - 1;
|
tree->topdiff = tlines (tree) - 3 - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void tree_chdir (WTree *tree, const char *dir)
|
|
||||||
{
|
|
||||||
tree_entry *current;
|
|
||||||
|
|
||||||
current = tree_store_whereis (dir);
|
|
||||||
if (current){
|
|
||||||
tree->selected_ptr = current;
|
|
||||||
check_focus (tree);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
sync_tree (const char *path)
|
|
||||||
{
|
|
||||||
tree_chdir (the_tree, path);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Handle mouse click */
|
/* Handle mouse click */
|
||||||
static void
|
static void
|
||||||
tree_event (WTree *tree, int y)
|
tree_event (WTree *tree, int y)
|
||||||
@ -487,14 +495,29 @@ tree_event (WTree *tree, int y)
|
|||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void chdir_sel (WTree *tree);
|
static void
|
||||||
|
tree_chdir_sel (WTree *tree)
|
||||||
static void maybe_chdir (WTree *tree)
|
|
||||||
{
|
{
|
||||||
if (!(xtree_mode && tree->is_panel))
|
if (!tree->is_panel)
|
||||||
return;
|
return;
|
||||||
if (is_idle ())
|
|
||||||
chdir_sel (tree);
|
change_panel ();
|
||||||
|
|
||||||
|
if (do_cd (tree->selected_ptr->name, cd_exact))
|
||||||
|
select_item (current_panel);
|
||||||
|
else
|
||||||
|
message (D_ERROR, MSG_ERROR, _(" Cannot chdir to \"%s\" \n %s "),
|
||||||
|
tree->selected_ptr->name, unix_error_string (errno));
|
||||||
|
|
||||||
|
change_panel ();
|
||||||
|
show_tree (tree);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
maybe_chdir (WTree *tree)
|
||||||
|
{
|
||||||
|
if (xtree_mode && tree->is_panel && is_idle ())
|
||||||
|
tree_chdir_sel (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Mouse callback */
|
/* Mouse callback */
|
||||||
@ -524,21 +547,21 @@ event_callback (Gpm_Event *event, void *data)
|
|||||||
if (event->y < 0){
|
if (event->y < 0){
|
||||||
tree_move_backward (tree, tlines (tree) - 1);
|
tree_move_backward (tree, tlines (tree) - 1);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
}
|
} else if (event->y >= tlines (tree)){
|
||||||
else if (event->y >= tlines (tree)){
|
|
||||||
tree_move_forward (tree, tlines (tree) - 1);
|
tree_move_forward (tree, tlines (tree) - 1);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
} else {
|
} else {
|
||||||
tree_event (tree, event->y);
|
tree_event (tree, event->y);
|
||||||
if ((event->type & (GPM_UP|GPM_DOUBLE)) == (GPM_UP|GPM_DOUBLE)){
|
if ((event->type & (GPM_UP|GPM_DOUBLE)) == (GPM_UP|GPM_DOUBLE)){
|
||||||
chdir_sel (tree);
|
tree_chdir_sel (tree);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return MOU_NORMAL;
|
return MOU_NORMAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Search tree for text */
|
/* Search tree for text */
|
||||||
static int search_tree (WTree *tree, char *text)
|
static int
|
||||||
|
search_tree (WTree *tree, char *text)
|
||||||
{
|
{
|
||||||
tree_entry *current;
|
tree_entry *current;
|
||||||
int len;
|
int len;
|
||||||
@ -561,23 +584,21 @@ static int search_tree (WTree *tree, char *text)
|
|||||||
}
|
}
|
||||||
tree->topdiff++;
|
tree->topdiff++;
|
||||||
}
|
}
|
||||||
check_focus (tree);
|
tree_check_focus (tree);
|
||||||
return found;
|
return found;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tree_do_search (WTree *tree, int key)
|
static void
|
||||||
|
tree_do_search (WTree *tree, int key)
|
||||||
{
|
{
|
||||||
size_t l;
|
size_t l;
|
||||||
|
|
||||||
l = strlen (tree->search_buffer);
|
l = strlen (tree->search_buffer);
|
||||||
if (l && (key == KEY_BACKSPACE))
|
if ((l != 0) && (key == KEY_BACKSPACE))
|
||||||
tree->search_buffer [--l] = 0;
|
tree->search_buffer [--l] = '\0';
|
||||||
else {
|
else if (key && l < sizeof (tree->search_buffer)){
|
||||||
if (key && l < sizeof (tree->search_buffer)){
|
tree->search_buffer [l] = key;
|
||||||
tree->search_buffer [l] = key;
|
tree->search_buffer [++l] = '\0';
|
||||||
tree->search_buffer [l+1] = 0;
|
|
||||||
l++;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!search_tree (tree, tree->search_buffer))
|
if (!search_tree (tree, tree->search_buffer))
|
||||||
@ -588,9 +609,10 @@ static void tree_do_search (WTree *tree, int key)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tree_rescan_cmd (WTree *tree)
|
tree_rescan (void *data)
|
||||||
{
|
{
|
||||||
char old_dir [MC_MAXPATHLEN];
|
char old_dir [MC_MAXPATHLEN];
|
||||||
|
WTree *tree = data;
|
||||||
|
|
||||||
if (!tree->selected_ptr || !mc_get_current_wd (old_dir, MC_MAXPATHLEN) ||
|
if (!tree->selected_ptr || !mc_get_current_wd (old_dir, MC_MAXPATHLEN) ||
|
||||||
mc_chdir (tree->selected_ptr->name))
|
mc_chdir (tree->selected_ptr->name))
|
||||||
@ -601,7 +623,7 @@ tree_rescan_cmd (WTree *tree)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tree_forget_cmd (void *data)
|
tree_forget (void *data)
|
||||||
{
|
{
|
||||||
WTree *tree = data;
|
WTree *tree = data;
|
||||||
if (tree->selected_ptr)
|
if (tree->selected_ptr)
|
||||||
@ -634,19 +656,6 @@ tree_copy (WTree *tree, const char *default_dest)
|
|||||||
g_free (dest);
|
g_free (dest);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
tree_help_cmd (void)
|
|
||||||
{
|
|
||||||
interactive_display (NULL, "[Directory Tree]");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
tree_copy_cmd (void *data)
|
|
||||||
{
|
|
||||||
WTree *tree = data;
|
|
||||||
tree_copy (tree, "");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tree_move (WTree *tree, const char *default_dest)
|
tree_move (WTree *tree, const char *default_dest)
|
||||||
{
|
{
|
||||||
@ -675,6 +684,7 @@ tree_move (WTree *tree, const char *default_dest)
|
|||||||
g_free (dest);
|
g_free (dest);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!S_ISDIR (buf.st_mode)){
|
if (!S_ISDIR (buf.st_mode)){
|
||||||
file_error (_(" Destination \"%s\" must be a directory \n %s "),
|
file_error (_(" Destination \"%s\" must be a directory \n %s "),
|
||||||
dest);
|
dest);
|
||||||
@ -690,16 +700,9 @@ tree_move (WTree *tree, const char *default_dest)
|
|||||||
g_free (dest);
|
g_free (dest);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
tree_move_cmd (void *data)
|
|
||||||
{
|
|
||||||
WTree *tree = data;
|
|
||||||
tree_move (tree, "");
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
static void
|
static void
|
||||||
tree_mkdir_cmd (WTree *tree)
|
tree_mkdir (WTree *tree)
|
||||||
{
|
{
|
||||||
char old_dir [MC_MAXPATHLEN];
|
char old_dir [MC_MAXPATHLEN];
|
||||||
|
|
||||||
@ -712,14 +715,15 @@ tree_mkdir_cmd (WTree *tree)
|
|||||||
/* FIXME
|
/* FIXME
|
||||||
mkdir_cmd (tree);
|
mkdir_cmd (tree);
|
||||||
*/
|
*/
|
||||||
tree_rescan_cmd (tree);
|
tree_rescan (tree);
|
||||||
chdir (old_dir);
|
chdir (old_dir);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tree_rmdir_cmd (WTree *tree)
|
tree_rmdir (void *data)
|
||||||
{
|
{
|
||||||
|
WTree *tree = data;
|
||||||
off_t count = 0;
|
off_t count = 0;
|
||||||
double bytes = 0;
|
double bytes = 0;
|
||||||
FileOpContext *ctx;
|
FileOpContext *ctx;
|
||||||
@ -743,91 +747,55 @@ tree_rmdir_cmd (WTree *tree)
|
|||||||
|
|
||||||
ctx = file_op_context_new (OP_DELETE);
|
ctx = file_op_context_new (OP_DELETE);
|
||||||
file_op_context_create_ui (ctx, FALSE);
|
file_op_context_create_ui (ctx, FALSE);
|
||||||
if (erase_dir (ctx, tree->selected_ptr->name, &count, &bytes) ==
|
if (erase_dir (ctx, tree->selected_ptr->name, &count, &bytes) == FILE_CONT)
|
||||||
FILE_CONT)
|
tree_forget (tree);
|
||||||
tree_forget_cmd (tree);
|
|
||||||
file_op_context_destroy (ctx);
|
file_op_context_destroy (ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_navig_label (WTree *tree);
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tree_toggle_navig (void *data)
|
tree_toggle_navig (WTree *tree)
|
||||||
{
|
|
||||||
WTree *tree = data;
|
|
||||||
/* FIXME: invalid use of boolean variable */
|
|
||||||
tree_navigation_flag = 1 - tree_navigation_flag;
|
|
||||||
set_navig_label (tree);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
set_navig_label (WTree *tree)
|
|
||||||
{
|
{
|
||||||
|
tree_navigation_flag = !tree_navigation_flag;
|
||||||
buttonbar_set_label_data (tree->widget.parent, 4,
|
buttonbar_set_label_data (tree->widget.parent, 4,
|
||||||
tree_navigation_flag ? Q_("ButtonBar|Static") : Q_("ButtonBar|Dynamc"),
|
tree_navigation_flag ? Q_("ButtonBar|Static")
|
||||||
tree_toggle_navig, tree);
|
: Q_("ButtonBar|Dynamc"),
|
||||||
|
tree_toggle_f4, tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static inline void
|
||||||
move_down (WTree *tree)
|
tree_move_up (WTree *tree)
|
||||||
{
|
|
||||||
tree_move_forward (tree, 1);
|
|
||||||
show_tree (tree);
|
|
||||||
maybe_chdir (tree);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
move_up (WTree *tree)
|
|
||||||
{
|
{
|
||||||
tree_move_backward (tree, 1);
|
tree_move_backward (tree, 1);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
maybe_chdir (tree);
|
maybe_chdir (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static inline void
|
||||||
move_home (WTree *tree)
|
tree_move_down (WTree *tree)
|
||||||
|
{
|
||||||
|
tree_move_forward (tree, 1);
|
||||||
|
show_tree (tree);
|
||||||
|
maybe_chdir (tree);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
tree_move_home (WTree *tree)
|
||||||
{
|
{
|
||||||
tree_move_to_top (tree);
|
tree_move_to_top (tree);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
maybe_chdir (tree);
|
maybe_chdir (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static inline void
|
||||||
move_end (WTree *tree)
|
tree_move_end (WTree *tree)
|
||||||
{
|
{
|
||||||
tree_move_to_bottom (tree);
|
tree_move_to_bottom (tree);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
maybe_chdir (tree);
|
maybe_chdir (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
move_left (WTree *tree)
|
|
||||||
{
|
|
||||||
int v;
|
|
||||||
|
|
||||||
if (tree_navigation_flag){
|
|
||||||
v = tree_move_to_parent (tree);
|
|
||||||
show_tree (tree);
|
|
||||||
maybe_chdir (tree);
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
move_right (WTree *tree)
|
|
||||||
{
|
|
||||||
if (tree_navigation_flag){
|
|
||||||
tree_move_to_child (tree);
|
|
||||||
show_tree (tree);
|
|
||||||
maybe_chdir (tree);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
move_prevp (WTree *tree)
|
tree_move_pgup (WTree *tree)
|
||||||
{
|
{
|
||||||
tree_move_backward (tree, tlines (tree) - 1);
|
tree_move_backward (tree, tlines (tree) - 1);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
@ -835,40 +803,50 @@ move_prevp (WTree *tree)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
move_nextp (WTree *tree)
|
tree_move_pgdn (WTree *tree)
|
||||||
{
|
{
|
||||||
tree_move_forward (tree, tlines (tree) - 1);
|
tree_move_forward (tree, tlines (tree) - 1);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
maybe_chdir (tree);
|
maybe_chdir (tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static gboolean
|
||||||
chdir_sel (WTree *tree)
|
tree_move_left (WTree *tree)
|
||||||
{
|
{
|
||||||
if (!tree->is_panel) {
|
gboolean v = FALSE;
|
||||||
return;
|
|
||||||
|
if (tree_navigation_flag) {
|
||||||
|
v = tree_move_to_parent (tree);
|
||||||
|
show_tree (tree);
|
||||||
|
maybe_chdir (tree);
|
||||||
}
|
}
|
||||||
change_panel ();
|
|
||||||
if (do_cd (tree->selected_ptr->name, cd_exact)) {
|
return v;
|
||||||
select_item (current_panel);
|
}
|
||||||
} else {
|
|
||||||
message (D_ERROR, MSG_ERROR, _(" Cannot chdir to \"%s\" \n %s "),
|
static gboolean
|
||||||
tree->selected_ptr->name, unix_error_string (errno));
|
tree_move_right (WTree *tree)
|
||||||
|
{
|
||||||
|
gboolean v = FALSE;
|
||||||
|
|
||||||
|
if (tree_navigation_flag) {
|
||||||
|
tree_move_to_child (tree);
|
||||||
|
show_tree (tree);
|
||||||
|
maybe_chdir (tree);
|
||||||
|
v = TRUE;
|
||||||
}
|
}
|
||||||
change_panel ();
|
|
||||||
show_tree (tree);
|
return v;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tree_start_search (WTree *tree)
|
tree_start_search (WTree *tree)
|
||||||
{
|
{
|
||||||
int i;
|
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 {
|
||||||
/* 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
|
||||||
@ -881,67 +859,116 @@ tree_start_search (WTree *tree)
|
|||||||
tree_navigation_flag = i;
|
tree_navigation_flag = i;
|
||||||
}
|
}
|
||||||
tree_do_search (tree, 0);
|
tree_do_search (tree, 0);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
tree->searching = 1;
|
tree->searching = 1;
|
||||||
tree->search_buffer[0] = 0;
|
tree->search_buffer[0] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef void (*tree_key_action) (WTree *);
|
static cb_ret_t
|
||||||
typedef struct {
|
tree_execute_cmd (WTree *tree, int command)
|
||||||
int key_code;
|
{
|
||||||
tree_key_action fn;
|
cb_ret_t res = MSG_HANDLED;
|
||||||
} tree_key_map;
|
|
||||||
|
|
||||||
static const tree_key_map tree_keymap [] = {
|
if (command != CK_TreeStartSearch)
|
||||||
{ XCTRL('n'), move_down },
|
tree->searching = 0;
|
||||||
{ XCTRL('p'), move_up },
|
|
||||||
{ KEY_DOWN, move_down },
|
switch (command) {
|
||||||
{ KEY_UP, move_up },
|
case CK_TreeHelp:
|
||||||
{ '\n', chdir_sel },
|
interactive_display (NULL, "[Directory Tree]");
|
||||||
{ KEY_ENTER, chdir_sel },
|
break;
|
||||||
{ KEY_HOME, move_home },
|
case CK_TreeForget:
|
||||||
{ KEY_A1, move_home },
|
tree_forget (tree);
|
||||||
{ ALT ('<'), move_home },
|
break;
|
||||||
{ KEY_END, move_end },
|
case CK_TreeToggleNav:
|
||||||
{ KEY_C1, move_end },
|
tree_toggle_navig (tree);
|
||||||
{ ALT ('>'), move_end },
|
break;
|
||||||
{ KEY_NPAGE, move_nextp },
|
case CK_TreeCopy:
|
||||||
{ KEY_PPAGE, move_prevp },
|
tree_copy (tree, "");
|
||||||
{ XCTRL('v'), move_nextp },
|
break;
|
||||||
{ ALT('v'), move_prevp },
|
case CK_TreeMove:
|
||||||
{ XCTRL('p'), move_up },
|
tree_move (tree, "");
|
||||||
{ XCTRL('p'), move_down },
|
break;
|
||||||
{ XCTRL('s'), tree_start_search },
|
case CK_TreeMoveUp:
|
||||||
{ ALT('s'), tree_start_search },
|
tree_move_up (tree);
|
||||||
{ XCTRL('r'), tree_rescan_cmd },
|
break;
|
||||||
{ KEY_DC, tree_rmdir_cmd },
|
case CK_TreeMoveDown:
|
||||||
{ 0, 0 }
|
tree_move_down (tree);
|
||||||
};
|
break;
|
||||||
|
case CK_TreeMoveHome:
|
||||||
|
tree_move_home (tree);
|
||||||
|
break;
|
||||||
|
case CK_TreeMoveEnd:
|
||||||
|
tree_move_end (tree);
|
||||||
|
break;
|
||||||
|
case CK_TreeMovePgUp:
|
||||||
|
tree_move_pgup (tree);
|
||||||
|
break;
|
||||||
|
case CK_TreeMovePgDn:
|
||||||
|
tree_move_pgdn (tree);
|
||||||
|
break;
|
||||||
|
case CK_TreeOpen:
|
||||||
|
tree_chdir_sel (tree);
|
||||||
|
break;
|
||||||
|
case CK_TreeRescan:
|
||||||
|
tree_rescan (tree);
|
||||||
|
break;
|
||||||
|
case CK_TreeStartSearch:
|
||||||
|
tree_start_search (tree);
|
||||||
|
break;
|
||||||
|
case CK_TreeRemove:
|
||||||
|
tree_rmdir (tree);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
res = MSG_NOT_HANDLED;
|
||||||
|
}
|
||||||
|
|
||||||
|
show_tree (tree);
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* temporary wrappers */
|
||||||
|
void
|
||||||
|
tree_help (void *data)
|
||||||
|
{
|
||||||
|
tree_execute_cmd ((WTree *) data, CK_TreeHelp);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
tree_toggle_f4 (void *data)
|
||||||
|
{
|
||||||
|
tree_execute_cmd ((WTree *) data, CK_TreeToggleNav);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
tree_copy_cmd (void *data)
|
||||||
|
{
|
||||||
|
tree_execute_cmd ((WTree *) data, CK_TreeCopy);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
tree_move_cmd (void *data)
|
||||||
|
{
|
||||||
|
tree_execute_cmd ((WTree *) data, CK_TreeMove);
|
||||||
|
}
|
||||||
|
|
||||||
static cb_ret_t
|
static cb_ret_t
|
||||||
tree_key (WTree *tree, int key)
|
tree_key (WTree *tree, int key)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; tree_keymap [i].key_code; i++){
|
for (i = 0; tree_map [i].key != 0; i++)
|
||||||
if (key == tree_keymap [i].key_code){
|
if (key == tree_map [i].key)
|
||||||
if (tree_keymap [i].fn != tree_start_search)
|
switch (tree_map [i].command) {
|
||||||
tree->searching = 0;
|
case CK_TreeMoveLeft:
|
||||||
(*tree_keymap [i].fn)(tree);
|
return tree_move_left (tree) ? MSG_HANDLED : MSG_NOT_HANDLED;
|
||||||
show_tree (tree);
|
case CK_TreeMoveRight:
|
||||||
return MSG_HANDLED;
|
return tree_move_right (tree) ? MSG_HANDLED : MSG_NOT_HANDLED;
|
||||||
}
|
default:
|
||||||
}
|
tree_execute_cmd (tree, tree_map [i].command);
|
||||||
|
return MSG_HANDLED;
|
||||||
/* We do not want to use them if we do not need to */
|
}
|
||||||
/* Input line may want to take the motion key event */
|
|
||||||
if (key == KEY_LEFT)
|
|
||||||
return move_left (tree) ? MSG_HANDLED : MSG_NOT_HANDLED;
|
|
||||||
|
|
||||||
if (key == KEY_RIGHT)
|
|
||||||
return move_right (tree) ? MSG_HANDLED : MSG_NOT_HANDLED;
|
|
||||||
|
|
||||||
if (is_abort_char (key)) {
|
if (is_abort_char (key)) {
|
||||||
if (tree->is_panel) {
|
if (tree->is_panel) {
|
||||||
@ -989,20 +1016,6 @@ tree_frame (Dlg_head *h, WTree *tree)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
tree_rescan_command (void *data)
|
|
||||||
{
|
|
||||||
WTree *tree = data;
|
|
||||||
tree_rescan_cmd (tree);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
tree_rmdir_command (void *data)
|
|
||||||
{
|
|
||||||
WTree *tree = data;
|
|
||||||
tree_rmdir_cmd (tree);
|
|
||||||
}
|
|
||||||
|
|
||||||
static cb_ret_t
|
static cb_ret_t
|
||||||
tree_callback (Widget *w, widget_msg_t msg, int parm)
|
tree_callback (Widget *w, widget_msg_t msg, int parm)
|
||||||
{
|
{
|
||||||
@ -1020,23 +1033,23 @@ tree_callback (Widget *w, widget_msg_t msg, int parm)
|
|||||||
|
|
||||||
case WIDGET_FOCUS:
|
case WIDGET_FOCUS:
|
||||||
tree->active = 1;
|
tree->active = 1;
|
||||||
buttonbar_set_label (h, 1, Q_("ButtonBar|Help"), tree_help_cmd);
|
buttonbar_set_label_data (h, 1, Q_("ButtonBar|Help"), tree_help, tree);
|
||||||
buttonbar_set_label_data (h, 2, Q_("ButtonBar|Rescan"),
|
buttonbar_set_label_data (h, 2, Q_("ButtonBar|Rescan"), tree_rescan, tree);
|
||||||
tree_rescan_command, tree);
|
buttonbar_set_label_data (h, 3, Q_("ButtonBar|Forget"), tree_forget, tree);
|
||||||
buttonbar_set_label_data (h, 3, Q_("ButtonBar|Forget"), tree_forget_cmd, tree);
|
buttonbar_set_label_data (h, 4, tree_navigation_flag ? Q_("ButtonBar|Static")
|
||||||
|
: Q_("ButtonBar|Dynamc"),
|
||||||
|
tree_toggle_f4, tree);
|
||||||
buttonbar_set_label_data (h, 5, Q_("ButtonBar|Copy"), tree_copy_cmd, tree);
|
buttonbar_set_label_data (h, 5, Q_("ButtonBar|Copy"), tree_copy_cmd, tree);
|
||||||
buttonbar_set_label_data (h, 6, Q_("ButtonBar|RenMov"), tree_move_cmd, tree);
|
buttonbar_set_label_data (h, 6, Q_("ButtonBar|RenMov"), tree_move_cmd, tree);
|
||||||
#if 0
|
#if 0
|
||||||
/* FIXME: mkdir is currently defunct */
|
/* FIXME: mkdir is currently defunct */
|
||||||
buttonbar_set_label_data (h, 7, Q_("ButtonBar|Mkdir"), tree_mkdir_cmd, tree);
|
buttonbar_set_label_data (h, 7, Q_("ButtonBar|Mkdir"), tree_mkdir, tree);
|
||||||
#else
|
#else
|
||||||
buttonbar_clear_label (h, 7);
|
buttonbar_clear_label (h, 7);
|
||||||
#endif
|
#endif
|
||||||
buttonbar_set_label_data (h, 8, Q_("ButtonBar|Rmdir"), tree_rmdir_command, tree);
|
buttonbar_set_label_data (h, 8, Q_("ButtonBar|Rmdir"), tree_rmdir, tree);
|
||||||
set_navig_label (tree);
|
|
||||||
buttonbar_redraw (h);
|
buttonbar_redraw (h);
|
||||||
|
|
||||||
|
|
||||||
/* FIXME: Should find a better way of only displaying the
|
/* FIXME: Should find a better way of only displaying the
|
||||||
currently selected item */
|
currently selected item */
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
@ -1083,10 +1096,28 @@ tree_new (int is_panel, int y, int x, int lines, int cols)
|
|||||||
return tree;
|
return tree;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
tree_chdir (WTree *tree, const char *dir)
|
||||||
|
{
|
||||||
|
tree_entry *current;
|
||||||
|
|
||||||
|
current = tree_store_whereis (dir);
|
||||||
|
|
||||||
|
if (current != NULL) {
|
||||||
|
tree->selected_ptr = current;
|
||||||
|
tree_check_focus (tree);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Return name of the currently selected entry */
|
/* Return name of the currently selected entry */
|
||||||
char *
|
char *
|
||||||
tree_selected_name (WTree *tree)
|
tree_selected_name (const WTree *tree)
|
||||||
{
|
{
|
||||||
return tree->selected_ptr->name;
|
return tree->selected_ptr->name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
sync_tree (const char *path)
|
||||||
|
{
|
||||||
|
tree_chdir (the_tree, path);
|
||||||
|
}
|
||||||
|
16
src/tree.h
16
src/tree.h
@ -6,18 +6,16 @@
|
|||||||
#ifndef MC_TREE_H
|
#ifndef MC_TREE_H
|
||||||
#define MC_TREE_H
|
#define MC_TREE_H
|
||||||
|
|
||||||
struct WTree;
|
|
||||||
typedef struct WTree WTree;
|
typedef struct WTree WTree;
|
||||||
|
|
||||||
int tree_init (const char *current_dir, int lines);
|
extern WTree *the_tree;
|
||||||
void tree_chdir (WTree *tree, const char *dir);
|
|
||||||
char *tree_selected_name (WTree *tree);
|
|
||||||
|
|
||||||
void sync_tree (const char *pathname);
|
|
||||||
|
|
||||||
extern int xtree_mode;
|
extern int xtree_mode;
|
||||||
|
|
||||||
WTree *tree_new (int is_panel, int y, int x, int lines, int cols);
|
WTree *tree_new (int is_panel, int y, int x, int lines, int cols);
|
||||||
extern WTree *the_tree;
|
|
||||||
|
|
||||||
#endif
|
void tree_chdir (WTree *tree, const char *dir);
|
||||||
|
char *tree_selected_name (const WTree *tree);
|
||||||
|
|
||||||
|
void sync_tree (const char *pathname);
|
||||||
|
|
||||||
|
#endif /* MC_TREE_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user