Added --keymap command line option
Also, anned more pathes for found standart keymap file. Signed-off-by: Slava Zanko <slavazanko@gmail.com>
Этот коммит содержится в:
родитель
5a397a6b9a
Коммит
07777d282f
10
src/args.c
10
src/args.c
@ -77,6 +77,9 @@ char *mc_args__last_wd_file = NULL;
|
||||
/* when enabled NETCODE, use folowing file as logfile */
|
||||
char *mc_args__netfs_logfile = NULL;
|
||||
|
||||
/* keymap file */
|
||||
char *mc_args__keymap_file = NULL;
|
||||
|
||||
/* Debug level*/
|
||||
int mc_args__debug_level = 0;
|
||||
|
||||
@ -219,6 +222,13 @@ static const GOptionEntry argument_terminal_table[] = {
|
||||
NULL
|
||||
},
|
||||
|
||||
{
|
||||
"keymap", 'K', ARGS_TERM_OPTIONS, G_OPTION_ARG_STRING,
|
||||
&mc_args__keymap_file,
|
||||
N_("Load definitions of key bindings from specified file"),
|
||||
"<file>"
|
||||
},
|
||||
|
||||
{NULL}
|
||||
};
|
||||
#undef ARGS_TERM_OPTIONS
|
||||
|
@ -19,6 +19,7 @@ extern char *mc_args__skin;
|
||||
extern gboolean mc_args__version;
|
||||
extern char *mc_args__last_wd_file;
|
||||
extern char *mc_args__netfs_logfile;
|
||||
extern char *mc_args__keymap_file;
|
||||
extern int mc_args__debug_level;
|
||||
|
||||
/*** declarations of public functions ************************************************************/
|
||||
|
160
src/setup.c
160
src/setup.c
@ -49,6 +49,7 @@
|
||||
#include "cmd.h"
|
||||
#include "file.h" /* safe_delete */
|
||||
#include "keybind.h" /* lookup_action */
|
||||
#include "fileloc.h"
|
||||
|
||||
#ifdef USE_VFS
|
||||
#include "../vfs/gc.h"
|
||||
@ -77,7 +78,6 @@ extern int num_history_items_recorded;
|
||||
char *profile_name; /* .mc/ini */
|
||||
char *global_profile_name; /* mc.lib */
|
||||
char *panels_profile_name; /* .mc/panels.ini */
|
||||
char *global_keymap_name; /* GLOBAL_KEYMAP_FILE */
|
||||
|
||||
char *setup_color_string;
|
||||
char *term_color_string;
|
||||
@ -553,6 +553,154 @@ setup__move_panels_config_into_separate_file(const char*profile)
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
Get name of config file.
|
||||
|
||||
\param subdir
|
||||
if not NULL, then config also search into specified subdir
|
||||
|
||||
\param config_file_name
|
||||
If specified filename is relative, then will search in standart patches.
|
||||
|
||||
\return
|
||||
Newly allocated path to config name or NULL if file not found
|
||||
|
||||
If config_file_name is a relative path, then search config in stantart pathes */
|
||||
static char*
|
||||
load_setup_get_full_config_name(const char *subdir, const char *config_file_name)
|
||||
{
|
||||
/*
|
||||
TODO: IMHO, in future this function must be placed into mc_config module.
|
||||
Also, need to rename stupid mc_home and mc_home_alt to mc_sysconfdir and mc_datadir;
|
||||
home_mc => mc_user_homedir
|
||||
*/
|
||||
char *basename, *ret;
|
||||
|
||||
if (config_file_name == NULL)
|
||||
return NULL;
|
||||
|
||||
if (g_path_is_absolute (config_file_name))
|
||||
return g_strdup(config_file_name);
|
||||
|
||||
|
||||
basename = g_path_get_basename(config_file_name);
|
||||
if (basename == NULL)
|
||||
return NULL;
|
||||
|
||||
|
||||
if (subdir)
|
||||
ret = g_build_filename (home_dir, MC_USERCONF_DIR, subdir, basename, NULL);
|
||||
else
|
||||
ret = g_build_filename (home_dir, MC_USERCONF_DIR, basename, NULL);
|
||||
|
||||
if (exist_file(ret)) {
|
||||
g_free(basename);
|
||||
return ret;
|
||||
}
|
||||
g_free(ret);
|
||||
|
||||
|
||||
if (subdir)
|
||||
ret = g_build_filename (mc_home, subdir, basename, NULL);
|
||||
else
|
||||
ret = g_build_filename (mc_home, basename, NULL);
|
||||
|
||||
if (exist_file(ret)) {
|
||||
g_free(basename);
|
||||
return ret;
|
||||
}
|
||||
g_free(ret);
|
||||
|
||||
if (subdir)
|
||||
ret = g_build_filename (mc_home_alt, subdir, basename, NULL);
|
||||
else
|
||||
ret = g_build_filename (mc_home_alt, basename, NULL);
|
||||
|
||||
if (exist_file(ret)) {
|
||||
g_free(basename);
|
||||
return ret;
|
||||
}
|
||||
g_free(ret);
|
||||
g_free(basename);
|
||||
return NULL;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
Create new mc_config object from specified ini-file or
|
||||
append data to existing mc_config object from ini-file
|
||||
|
||||
*/
|
||||
static void
|
||||
load_setup_init_config_from_file(mc_config_t **config, const char *fname)
|
||||
{
|
||||
/*
|
||||
TODO: IMHO, in future this function must be placed into mc_config module.
|
||||
*/
|
||||
if (exist_file(fname)) {
|
||||
if (*config)
|
||||
mc_config_read_file( *config, fname);
|
||||
else
|
||||
*config = mc_config_init(fname);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
static mc_config_t *
|
||||
load_setup_get_keymap_profile_config(void)
|
||||
{
|
||||
/*
|
||||
TODO: IMHO, in future this function must be placed into mc_config module.
|
||||
*/
|
||||
mc_config_t *keymap_config = NULL ;
|
||||
|
||||
char *fname, *fname2;
|
||||
|
||||
/* 1) /usr/share/mc (mc_home_alt) */
|
||||
fname = g_build_filename (mc_home_alt, GLOBAL_KEYMAP_FILE, NULL);
|
||||
load_setup_init_config_from_file( &keymap_config, fname);
|
||||
g_free(fname);
|
||||
|
||||
/* 2) /etc/mc (mc_home) */
|
||||
fname = g_build_filename (mc_home, GLOBAL_KEYMAP_FILE, NULL);
|
||||
load_setup_init_config_from_file( &keymap_config, fname);
|
||||
g_free(fname);
|
||||
|
||||
/* 3) ~/.mc (home_dir?) */
|
||||
fname = g_build_filename (home_dir, MC_USERCONF_DIR, GLOBAL_KEYMAP_FILE, NULL);
|
||||
load_setup_init_config_from_file( &keymap_config, fname);
|
||||
g_free(fname);
|
||||
|
||||
/* 4) main config; [Midnight Commander] -> keymap*/
|
||||
|
||||
fname2 = mc_config_get_string(mc_main_config, CONFIG_APP_SECTION, "keymap" , GLOBAL_KEYMAP_FILE);
|
||||
fname = load_setup_get_full_config_name(NULL, fname2);
|
||||
if (fname)
|
||||
{
|
||||
load_setup_init_config_from_file( &keymap_config, fname);
|
||||
g_free(fname);
|
||||
}
|
||||
g_free(fname2);
|
||||
|
||||
/* 5) getenv("MC_KEYMAP") */
|
||||
fname = load_setup_get_full_config_name(NULL, g_getenv ("MC_KEYMAP"));
|
||||
if (fname)
|
||||
{
|
||||
load_setup_init_config_from_file( &keymap_config, fname);
|
||||
g_free(fname);
|
||||
}
|
||||
|
||||
/* 6) --keymap=<keymap> */
|
||||
fname = load_setup_get_full_config_name(NULL, mc_args__keymap_file);
|
||||
if (fname)
|
||||
{
|
||||
load_setup_init_config_from_file( &keymap_config, fname);
|
||||
g_free(fname);
|
||||
}
|
||||
|
||||
return keymap_config;
|
||||
}
|
||||
|
||||
char *
|
||||
setup_init (void)
|
||||
@ -602,11 +750,6 @@ load_setup (void)
|
||||
global_profile_name = concat_dir_and_file (mc_home_alt, "mc.lib");
|
||||
}
|
||||
|
||||
global_keymap_name = concat_dir_and_file (mc_home, GLOBAL_KEYMAP_FILE);
|
||||
if (!exist_file(global_keymap_name)) {
|
||||
g_free (global_keymap_name);
|
||||
global_keymap_name = concat_dir_and_file (mc_home_alt, GLOBAL_KEYMAP_FILE);
|
||||
}
|
||||
panels_profile_name = concat_dir_and_file (home_dir, PANELS_PROFILE_NAME);
|
||||
|
||||
mc_main_config = mc_config_init(profile);
|
||||
@ -708,7 +851,6 @@ load_anon_passwd ()
|
||||
|
||||
void done_setup (void)
|
||||
{
|
||||
g_free (global_keymap_name);
|
||||
g_free (profile_name);
|
||||
g_free (global_profile_name);
|
||||
g_free(color_terminal_string);
|
||||
@ -811,7 +953,6 @@ load_keymap_from_section (const char *section_name, GArray *keymap, mc_config_t
|
||||
while (*profile_keys) {
|
||||
curr_values = values = mc_config_get_string_list (cfg, section_name, *profile_keys, &values_len);
|
||||
action = lookup_action (*profile_keys);
|
||||
mc_log ("section: %s, val: %s, action: %i [%s]\n", section_name, *curr_values, action, *profile_keys);
|
||||
if (action>0) {
|
||||
if (curr_values){
|
||||
while (*curr_values){
|
||||
@ -844,7 +985,8 @@ load_keymap_defs (void)
|
||||
*/
|
||||
mc_config_t *mc_global_keymap;
|
||||
|
||||
mc_global_keymap = mc_config_init(global_keymap_name);
|
||||
mc_global_keymap = load_setup_get_keymap_profile_config();
|
||||
|
||||
if (mc_global_keymap != NULL)
|
||||
{
|
||||
editor_keymap = g_array_new(TRUE, FALSE, sizeof(global_key_map_t));
|
||||
|
@ -493,7 +493,6 @@ mcview_handle_key (mcview_t * view, int key)
|
||||
for (i = 0; view->plain_map[i].key; i++) {
|
||||
if (key == view->plain_map[i].key) {
|
||||
res = mcview_execute_cmd (view, view->plain_map[i].command, key);
|
||||
mc_log ("key: %i, command: %i, res: %i\n", key, view->plain_map[i].command, res);
|
||||
if (res == MSG_HANDLED) {
|
||||
return MSG_HANDLED;
|
||||
}
|
||||
|
@ -170,6 +170,7 @@ mcview_real_event (Gpm_Event * event, void *x)
|
||||
static void
|
||||
mcview_set_keymap (mcview_t * view)
|
||||
{
|
||||
int i;
|
||||
view->plain_map = default_keymap;
|
||||
if (viewer_keymap && viewer_keymap->len > 0)
|
||||
view->plain_map = (global_key_map_t *) viewer_keymap->data;
|
||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user