mc/src/setup.c

1051 lines
30 KiB
C
Raw Normal View History

1998-02-27 07:54:42 +03:00
/* Setup loading/saving.
Copyright (C) 1994, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
2006, 2007, 2009 Free Software Foundation, Inc.
1998-02-27 07:54:42 +03:00
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
1998-02-27 07:54:42 +03:00
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
1998-02-27 07:54:42 +03:00
/** \file setup.c
* \brief Source: setup loading/saving
*/
1998-02-27 07:54:42 +03:00
#include <config.h>
2005-02-08 12:04:03 +03:00
#include <stdlib.h>
1998-02-27 07:54:42 +03:00
#include <string.h>
#include <stdio.h>
2005-02-08 12:04:03 +03:00
#include <sys/types.h>
#include <sys/stat.h>
1998-02-27 07:54:42 +03:00
#include "global.h"
#include "../src/tty/tty.h"
#include "../src/tty/key.h"
#include "../src/tty/mouse.h" /* To make view.h happy */
#include "args.h"
#include "dir.h"
1998-02-27 07:54:42 +03:00
#include "panel.h"
#include "main.h"
2002-12-08 07:16:30 +03:00
#include "tree.h" /* xtree_mode */
#include "../src/mcconfig/mcconfig.h"
1998-02-27 07:54:42 +03:00
#include "setup.h"
#include "../src/viewer/mcviewer.h" /* For the externs */
1998-02-27 07:54:42 +03:00
#include "hotlist.h" /* load/save/done hotlist */
#include "panelize.h" /* load/save/done panelize */
#include "layout.h"
#include "menu.h" /* menubar_visible declaration */
#include "cmd.h"
2002-12-08 07:16:30 +03:00
#include "file.h" /* safe_delete */
#include "keybind.h" /* lookup_action */
#include "fileloc.h"
#include "wtools.h"
#ifdef USE_VFS
#include "../vfs/gc.h"
#endif
#ifdef HAVE_CHARSET
#include "charsets.h"
#endif
1998-02-27 07:54:42 +03:00
#ifdef USE_NETCODE
# include "../vfs/ftpfs.h"
# include "../vfs/fish.h"
1998-02-27 07:54:42 +03:00
#endif
#ifdef USE_INTERNAL_EDIT
# include "../edit/edit.h"
#endif
#include "../src/strutil.h" /* str_isutf8 () */
1998-02-27 07:54:42 +03:00
extern char *find_ignore_dirs;
extern int num_history_items_recorded;
char *profile_name; /* .mc/ini */
char *global_profile_name; /* mc.lib */
1998-02-27 07:54:42 +03:00
char *setup_color_string;
char *term_color_string;
char *color_terminal_string;
1998-02-27 07:54:42 +03:00
int startup_left_mode;
int startup_right_mode;
/* Ugly hack to allow panel_save_setup to work as a place holder for */
/* default panel values */
int saving_setup;
int setup_copymove_persistent_attr = 1;
1998-02-27 07:54:42 +03:00
static char *panels_profile_name = NULL; /* .mc/panels.ini */
2000-02-02 19:57:51 +03:00
static const struct {
const char *key;
1998-02-27 07:54:42 +03:00
int list_type;
} list_types [] = {
{ "full", list_full },
1998-02-27 07:54:42 +03:00
{ "brief", list_brief },
{ "long", list_long },
{ "user", list_user },
1998-02-27 07:54:42 +03:00
{ 0, 0 }
};
2000-02-02 19:57:51 +03:00
static const struct {
const char *opt_name;
1998-02-27 07:54:42 +03:00
int opt_type;
} panel_types [] = {
{ "listing", view_listing },
{ "quickview", view_quick },
{ "info", view_info },
{ "tree", view_tree },
{ 0, 0 }
};
2000-02-02 19:57:51 +03:00
static const struct {
const char *opt_name;
1998-02-27 07:54:42 +03:00
int *opt_addr;
} layout [] = {
{ "equal_split", &equal_split },
{ "first_panel_size", &first_panel_size },
{ "message_visible", &message_visible },
{ "keybar_visible", &keybar_visible },
{ "xterm_title", &xterm_title },
1998-02-27 07:54:42 +03:00
{ "output_lines", &output_lines },
{ "command_prompt", &command_prompt },
{ "menubar_visible", &menubar_visible },
1998-02-27 07:54:42 +03:00
{ "show_mini_info", &show_mini_info },
{ "permission_mode", &permission_mode },
{ "filetype_mode", &filetype_mode },
2009-02-04 04:27:36 +03:00
{ "free_space", &free_space },
1998-02-27 07:54:42 +03:00
{ 0, 0 }
};
2000-02-02 19:57:51 +03:00
static const struct {
const char *opt_name;
1998-02-27 07:54:42 +03:00
int *opt_addr;
} int_options [] = {
1998-02-27 07:54:42 +03:00
{ "show_backups", &show_backups },
{ "kilobyte_si", &kilobyte_si },
1998-02-27 07:54:42 +03:00
{ "show_dot_files", &show_dot_files },
{ "verbose", &verbose },
{ "mark_moves_down", &mark_moves_down },
{ "pause_after_run", &pause_after_run },
{ "shell_patterns", &easy_patterns },
{ "auto_save_setup", &auto_save_setup },
{ "auto_menu", &auto_menu },
{ "use_internal_view", &use_internal_view },
{ "use_internal_edit", &use_internal_edit },
{ "clear_before_exec", &clear_before_exec },
{ "mix_all_files", &mix_all_files },
{ "fast_reload", &fast_reload },
{ "fast_reload_msg_shown", &fast_reload_w },
{ "confirm_delete", &confirm_delete },
{ "confirm_overwrite", &confirm_overwrite },
{ "confirm_execute", &confirm_execute },
{ "confirm_exit", &confirm_exit },
{ "confirm_directory_hotlist_delete", &confirm_directory_hotlist_delete },
{ "safe_delete", &safe_delete },
1998-02-27 07:54:42 +03:00
{ "mouse_repeat_rate", &mou_auto_repeat },
{ "double_click_speed", &double_click_speed },
#ifndef HAVE_CHARSET
1998-02-27 07:54:42 +03:00
{ "eight_bit_clean", &eight_bit_clean },
{ "full_eight_bits", &full_eight_bits },
#endif /* !HAVE_CHARSET */
1998-02-27 07:54:42 +03:00
{ "use_8th_bit_as_meta", &use_8th_bit_as_meta },
{ "confirm_view_dir", &confirm_view_dir },
{ "mouse_move_pages", &mouse_move_pages },
{ "mouse_move_pages_viewer", &mcview_mouse_move_pages },
{ "mouse_close_dialog", &mouse_close_dialog},
1998-02-27 07:54:42 +03:00
{ "fast_refresh", &fast_refresh },
{ "navigate_with_arrows", &navigate_with_arrows },
{ "drop_menus", &drop_menus },
{ "wrap_mode", &mcview_global_wrap_mode},
1998-02-27 07:54:42 +03:00
{ "old_esc_mode", &old_esc_mode },
{ "cd_symlinks", &cd_symlinks },
{ "show_all_if_ambiguous", &show_all_if_ambiguous },
{ "max_dirt_limit", &mcview_max_dirt_limit },
1998-02-27 07:54:42 +03:00
{ "torben_fj_mode", &torben_fj_mode },
{ "use_file_to_guess_type", &use_file_to_check_type },
{ "alternate_plus_minus", &alternate_plus_minus },
{ "only_leading_plus_minus", &only_leading_plus_minus },
{ "show_output_starts_shell", &output_starts_shell },
{ "panel_scroll_pages", &panel_scroll_pages },
{ "xtree_mode", &xtree_mode },
{ "num_history_items_recorded", &num_history_items_recorded },
{ "file_op_compute_totals", &file_op_compute_totals },
#ifdef USE_VFS
1998-02-27 07:54:42 +03:00
{ "vfs_timeout", &vfs_timeout },
#ifdef USE_NETCODE
{ "ftpfs_directory_timeout", &ftpfs_directory_timeout },
{ "use_netrc", &use_netrc },
{ "ftpfs_retry_seconds", &ftpfs_retry_seconds },
{ "ftpfs_always_use_proxy", &ftpfs_always_use_proxy },
{ "ftpfs_use_passive_connections", &ftpfs_use_passive_connections },
{ "ftpfs_use_passive_connections_over_proxy", &ftpfs_use_passive_connections_over_proxy },
{ "ftpfs_use_unix_list_options", &ftpfs_use_unix_list_options },
Rerun configure when you have problems with missing slang.h. Sun Jan 31 20:04:13 1999 Norbert Warmuth <nwarmuth@privat.circular.de> * vfs/vfs.c (vfs_strip_suffix_from_filename): Whoever replaces every occurance of 0 with NULL should stop this stupidy. And replacing '\0' with NULL is plain wrong!!. Reverted this replacement. * vfs/ftpfs.c (load_no_proxy_list): ditto Fri Jan 29 22:55:56 1999 Norbert Warmuth <nwarmuth@privat.circular.de> * slang/slang.h: renamed to slang-mc.h * slang/Makefile.in: delete slang.h on "make clean" * configure.in: link slang/slang-mc.h to slang/slang.h when the included slang is used. Problem was that MC's slang.h was used when we compiled with an already installed SLang and the systems header file were included with <slang/slang.h>. Unfortunatly I can't use AC_LINK_FILES to make the links because if we needn't make any links AC_LINK_FILES makes a link from srcdir to top_builddir (builddir != srcdir). Temporary add $LGPM to $LIBS when checking for the resizeterm and keyok functions (ncurses might be linked against GPM). Substitude PACKAGE (intl/Makefile makes use of it) Sun Jan 31 19:42:47 1999 Norbert Warmuth <nwarmuth@privat.circular.de> * gnome/Makefile.in (install_mx): make it work with srcdir != builddir (gmc.gnorba is located in $srcdir) * src/hotlist.c (add_new_entry_input, add_new_group_input): Make the quick_widget arrays static and various changes needed because they are now static. add_widgets_i18n recalculates button positions which get lost when the quick_widget arrays are non static. * src/screen.c (to_buffer): nul terminate string when using strncpy * src/setup.c: Save and restore new option ftpfs_first_cd_then_ls. Sun Jan 31 19:57:24 1999 Norbert Warmuth <nwarmuth@privat.circular.de> * vfs/ftpfs.c (insert_dot): New function. Insert a "." into the linked list. Stat'ing the root directory of a ftpfs fails if the dot is missing. (retrieve_dir): insert "." into the linked list if the ftp server haven't send it. Sun Jan 31 19:50:24 1999 Norbert Warmuth <nwarmuth@privat.circular.de> * The following changes make ftpfs work with a remote AmiTCP server are the result of somehow longish EMail debugging session. I don't know any public server of this kind but I was told the combination Unix/Amiga boxes are often used in intranets. * vfs/ftpfs.c (translate_path): New function. Translate a Unix path, i.e. MC's internal path representation (e.g. /somedir/somefile) to a path valid for the remote server. Every path transfered to the remote server has to be mangled by this function right prior to sending it. Currently only Amiga ftp servers are handled in a special manner. * vfs/ftpfs.c (various places): use translate_path * vfs/ftpfs.c (login_server): Assume we have to mangle pathnames if the greatings string from the server contains the word Amiga. If this assumption is wrong I have to find another way to turn on path translation. * vfs/ftpfs.c (ftpfs_get_current_directory): Prepend a leading slash if it is missing. MC needs it as seperator between hostname and path in its internal url representation.
1999-01-31 23:28:13 +03:00
{ "ftpfs_first_cd_then_ls", &ftpfs_first_cd_then_ls },
{ "fish_directory_timeout", &fish_directory_timeout },
#endif /* USE_NETCODE */
#endif /* USE_VFS */
1998-02-27 07:54:42 +03:00
#ifdef USE_INTERNAL_EDIT
{ "editor_word_wrap_line_length", &option_word_wrap_line_length },
{ "editor_tab_spacing", &option_tab_spacing },
{ "editor_fill_tabs_with_spaces", &option_fill_tabs_with_spaces },
{ "editor_return_does_auto_indent", &option_return_does_auto_indent },
{ "editor_backspace_through_tabs", &option_backspace_through_tabs },
{ "editor_fake_half_tabs", &option_fake_half_tabs },
{ "editor_option_save_mode", &option_save_mode },
{ "editor_option_save_position", &option_save_position },
1998-02-27 07:54:42 +03:00
{ "editor_option_auto_para_formatting", &option_auto_para_formatting },
{ "editor_option_typewriter_wrap", &option_typewriter_wrap },
{ "editor_edit_confirm_save", &edit_confirm_save },
{ "editor_syntax_highlighting", &option_syntax_highlighting },
{ "editor_persistent_selections", &option_persistent_selections },
{ "editor_cursor_beyond_eol", &option_cursor_beyond_eol },
2009-01-20 00:09:54 +03:00
{ "editor_visible_tabs", &visible_tabs },
{ "editor_visible_spaces", &visible_tws },
{ "editor_line_state", &option_line_state },
{ "editor_simple_statusbar", &simple_statusbar },
{ "editor_check_new_line", &option_check_nl_at_eof },
#endif /* USE_INTERNAL_EDIT */
1998-02-27 07:54:42 +03:00
{ "nice_rotating_dash", &nice_rotating_dash },
1999-01-17 07:17:20 +03:00
{ "horizontal_split", &horizontal_split },
{ "mcview_remember_file_position", &mcview_remember_file_position },
{ "auto_fill_mkdir_name", &auto_fill_mkdir_name },
{ "reverse_files_only", &reverse_files_only },
{ "copymove_persistent_attr", &setup_copymove_persistent_attr },
{ "select_flags", &select_flags },
1998-02-27 07:54:42 +03:00
{ 0, 0 }
};
static const struct {
const char *opt_name;
char **opt_addr;
const char *opt_defval;
} str_options [] = {
#ifdef USE_INTERNAL_EDIT
{ "editor_backup_extension", &option_backup_ext, "~" },
#endif
{ NULL, NULL, NULL }
};
void
panel_save_setup (struct WPanel *panel, const char *section)
1998-02-27 07:54:42 +03:00
{
char *buffer;
1998-02-27 07:54:42 +03:00
int i;
mc_config_set_int(mc_panels_config, section, "reverse", panel->reverse);
mc_config_set_int(mc_panels_config, section, "case_sensitive", panel->case_sensitive);
mc_config_set_int(mc_panels_config, section, "exec_first", panel->exec_first);
mc_config_set_string(mc_panels_config, section, "sort_order", panel->current_sort_field->id);
1998-02-27 07:54:42 +03:00
for (i = 0; list_types [i].key; i++)
if (list_types [i].list_type == panel->list_type){
mc_config_set_string(mc_panels_config, section, "list_mode", list_types [i].key);
1998-02-27 07:54:42 +03:00
break;
}
mc_config_set_string(mc_panels_config, section, "user_format", panel->user_format);
1998-02-27 07:54:42 +03:00
for (i = 0; i < LIST_TYPES; i++){
buffer = g_strdup_printf("user_status%d", i);
mc_config_set_string(mc_panels_config, section, buffer, panel->user_status_format [i]);
g_free(buffer);
1998-02-27 07:54:42 +03:00
}
mc_config_set_int(mc_panels_config, section, "user_mini_status", panel->user_mini_status);
1998-02-27 07:54:42 +03:00
}
void
save_layout (void)
{
char *profile;
int i;
1998-02-27 07:54:42 +03:00
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
1998-02-27 07:54:42 +03:00
/* Save integer options */
for (i = 0; layout [i].opt_name; i++){
mc_config_set_int(mc_main_config, "Layout", layout [i].opt_name, *layout [i].opt_addr);
}
mc_config_save_to_file (mc_main_config, profile, NULL);
1998-02-27 07:54:42 +03:00
g_free (profile);
}
1998-02-27 07:54:42 +03:00
void
save_configure (void)
{
char *profile;
GError *error = NULL;
int i;
1998-02-27 07:54:42 +03:00
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
/* Save integer options */
for (i = 0; int_options[i].opt_name; i++)
mc_config_set_int(mc_main_config, CONFIG_APP_SECTION, int_options[i].opt_name, *int_options[i].opt_addr);
/* Save string options */
for (i = 0; str_options[i].opt_name != NULL; i++)
mc_config_set_string(mc_main_config, CONFIG_APP_SECTION, str_options[i].opt_name, *str_options[i].opt_addr);
if (! mc_config_save_to_file (mc_main_config, profile, &error))
setup_save_config_show_error(profile, &error);
g_free (profile);
1998-02-27 07:54:42 +03:00
}
1998-12-03 00:27:27 +03:00
static void
panel_save_type (const char *section, int type)
1998-02-27 07:54:42 +03:00
{
int i;
for (i = 0; panel_types [i].opt_name; i++)
if (panel_types [i].opt_type == type){
mc_config_set_string(mc_panels_config, section,
"display", panel_types [i].opt_name);
break;
1998-02-27 07:54:42 +03:00
}
}
void
save_panel_types (void)
1998-02-27 07:54:42 +03:00
{
int type;
type = get_display_type (0);
panel_save_type ("New Left Panel", type);
if (type == view_listing)
panel_save_setup (left_panel, left_panel->panel_name);
type = get_display_type (1);
panel_save_type ("New Right Panel", type);
if (type == view_listing)
panel_save_setup (right_panel, right_panel->panel_name);
mc_config_set_string (mc_panels_config, "Dirs" , "other_dir",
get_panel_dir_for (other_panel));
if (current_panel != NULL)
mc_config_set_string (mc_panels_config, "Dirs" , "current_is_left",
get_current_index () == 0 ? "1" : "0");
if (mc_panels_config->ini_path == NULL)
mc_panels_config->ini_path = g_strdup(panels_profile_name);
mc_config_del_group (mc_panels_config, "Temporal:New Left Panel");
mc_config_del_group (mc_panels_config, "Temporal:New Right Panel");
mc_config_save_file (mc_panels_config, NULL);
}
gboolean
save_setup (void)
{
char *tmp_profile;
gboolean ret;
1998-02-27 07:54:42 +03:00
saving_setup = 1;
save_configure ();
1998-02-27 07:54:42 +03:00
save_layout ();
1998-02-27 07:54:42 +03:00
save_hotlist ();
1998-02-27 07:54:42 +03:00
save_panelize ();
save_panel_types ();
/* directory_history_save (); */
#if defined(USE_VFS) && defined (USE_NETCODE)
mc_config_set_string(mc_main_config, "Misc" , "ftpfs_password",
ftpfs_anonymous_passwd);
1998-02-27 07:54:42 +03:00
if (ftpfs_proxy_host)
mc_config_set_string(mc_main_config, "Misc" , "ftp_proxy_host",
ftpfs_proxy_host);
#endif /* USE_VFS && USE_NETCODE */
#ifdef HAVE_CHARSET
mc_config_set_string(mc_main_config, "Misc" , "display_codepage",
get_codepage_id( display_codepage ));
mc_config_set_string(mc_main_config, "Misc" , "source_codepage",
get_codepage_id( source_codepage ));
#endif /* HAVE_CHARSET */
tmp_profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
ret = mc_config_save_to_file (mc_main_config, tmp_profile, NULL);
g_free (tmp_profile);
1998-02-27 07:54:42 +03:00
saving_setup = 0;
return ret;
1998-02-27 07:54:42 +03:00
}
1998-12-03 00:27:27 +03:00
void
panel_load_setup (WPanel *panel, const char *section)
1998-02-27 07:54:42 +03:00
{
int i;
char *buffer;
panel->reverse = mc_config_get_int(mc_panels_config, section, "reverse", 0);
panel->case_sensitive = mc_config_get_int(mc_panels_config, section, "case_sensitive", OS_SORT_CASE_SENSITIVE_DEFAULT);
panel->exec_first = mc_config_get_int(mc_panels_config, section, "exec_first", 0);
1998-02-27 07:54:42 +03:00
/* Load sort order */
buffer = mc_config_get_string(mc_panels_config, section, "sort_order", "name");
panel->current_sort_field = panel_get_field_by_id(buffer);
if (panel->current_sort_field == NULL )
panel->current_sort_field = panel_get_field_by_id("name");
g_free(buffer);
1998-02-27 07:54:42 +03:00
/* Load the listing mode */
buffer = mc_config_get_string(mc_panels_config, section, "list_mode", "full");
1998-02-27 07:54:42 +03:00
panel->list_type = list_full;
for (i = 0; list_types [i].key; i++)
if ( g_strcasecmp (list_types [i].key, buffer) == 0){
1998-02-27 07:54:42 +03:00
panel->list_type = list_types [i].list_type;
break;
}
g_free(buffer);
1998-02-27 07:54:42 +03:00
/* User formats */
g_free (panel->user_format);
panel->user_format = mc_config_get_string(mc_panels_config, section, "user_format", DEFAULT_USER_FORMAT);
1998-02-27 07:54:42 +03:00
for (i = 0; i < LIST_TYPES; i++){
g_free (panel->user_status_format [i]);
buffer = g_strdup_printf("user_status%d",i);
panel->user_status_format [i] =
mc_config_get_string(mc_panels_config, section, buffer, DEFAULT_USER_FORMAT);
g_free(buffer);
1998-02-27 07:54:42 +03:00
}
1998-02-27 07:54:42 +03:00
panel->user_mini_status =
mc_config_get_int(mc_panels_config, section, "user_mini_status", 0);
}
static void
load_layout ()
{
int i;
for (i = 0; layout [i].opt_name; i++)
*layout [i].opt_addr =
mc_config_get_int(mc_main_config,"Layout", layout [i].opt_name, *layout [i].opt_addr);
}
static int
setup__load_panel_state (const char *section)
{
char *buffer;
int i;
int mode = view_listing;
/* Load the display mode */
buffer = mc_config_get_string(mc_panels_config, section, "display", "listing");
for (i = 0; panel_types [i].opt_name; i++)
if ( g_strcasecmp (panel_types [i].opt_name, buffer) == 0){
mode = panel_types [i].opt_type;
break;
}
g_free(buffer);
return mode;
1998-02-27 07:54:42 +03:00
}
static const char *
setup__is_cfg_group_must_panel_config(const char *grp)
{
if (
! strcasecmp("Dirs",grp) ||
! strcasecmp("Temporal:New Right Panel",grp) ||
! strcasecmp("Temporal:New Left Panel",grp) ||
! strcasecmp("New Left Panel",grp) ||
! strcasecmp("New Right Panel",grp)
)
return grp;
return NULL;
}
static void
setup__move_panels_config_into_separate_file(const char*profile)
{
mc_config_t *tmp_cfg;
char **groups, **curr_grp;
const char *need_grp;
if (!exist_file(profile))
return;
tmp_cfg = mc_config_init(profile);
if (!tmp_cfg)
return;
curr_grp = groups = mc_config_get_groups (tmp_cfg, NULL);
if (!groups)
{
mc_config_deinit(tmp_cfg);
return;
}
while (*curr_grp)
{
if ( setup__is_cfg_group_must_panel_config(*curr_grp) == NULL)
{
mc_config_del_group (tmp_cfg, *curr_grp);
}
curr_grp++;
}
mc_config_save_to_file (tmp_cfg, panels_profile_name, NULL);
mc_config_deinit(tmp_cfg);
tmp_cfg = mc_config_init(profile);
if (!tmp_cfg)
{
g_strfreev(groups);
return;
}
curr_grp = groups;
while (*curr_grp)
{
need_grp = setup__is_cfg_group_must_panel_config(*curr_grp);
if ( need_grp != NULL)
{
mc_config_del_group (tmp_cfg, need_grp);
}
curr_grp++;
}
g_strfreev(groups);
mc_config_save_file (tmp_cfg, NULL);
mc_config_deinit(tmp_cfg);
}
/**
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 *lc_basename, *ret;
if (config_file_name == NULL)
return NULL;
if (g_path_is_absolute (config_file_name))
return g_strdup(config_file_name);
lc_basename = g_path_get_basename(config_file_name);
if (lc_basename == NULL)
return NULL;
if (subdir)
ret = g_build_filename (home_dir, MC_USERCONF_DIR, subdir, lc_basename, NULL);
else
ret = g_build_filename (home_dir, MC_USERCONF_DIR, lc_basename, NULL);
if (exist_file(ret)) {
g_free(lc_basename);
return ret;
}
g_free(ret);
if (subdir)
ret = g_build_filename (mc_home, subdir, lc_basename, NULL);
else
ret = g_build_filename (mc_home, lc_basename, NULL);
if (exist_file(ret)) {
g_free(lc_basename);
return ret;
}
g_free(ret);
if (subdir)
ret = g_build_filename (mc_home_alt, subdir, lc_basename, NULL);
else
ret = g_build_filename (mc_home_alt, lc_basename, NULL);
if (exist_file(ret)) {
g_free(lc_basename);
return ret;
}
g_free(ret);
g_free(lc_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)
1998-02-27 07:54:42 +03:00
{
char *profile;
char *inifile;
if (profile_name)
return profile_name;
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
if (!exist_file (profile)){
inifile = concat_dir_and_file (mc_home, "mc.ini");
if (exist_file (inifile)){
g_free (profile);
profile = inifile;
} else {
g_free (inifile);
inifile = concat_dir_and_file (mc_home_alt, "mc.ini");
if (exist_file (inifile)) {
g_free (profile);
profile = inifile;
} else
g_free (inifile);
}
1998-02-27 07:54:42 +03:00
}
profile_name = profile;
1998-02-27 07:54:42 +03:00
return profile;
}
void
load_setup (void)
{
char *profile;
int i;
char *buffer;
profile = setup_init ();
/* mc.lib is common for all users, but has priority lower than
~/.mc/ini. FIXME: it's only used for keys and treestore now */
global_profile_name = concat_dir_and_file (mc_home, MC_GLOBAL_CONFIG_FILE);
if (!exist_file(global_profile_name)) {
g_free (global_profile_name);
global_profile_name = concat_dir_and_file (mc_home_alt, MC_GLOBAL_CONFIG_FILE);
}
panels_profile_name = g_build_filename (home_dir, MC_USERCONF_DIR, MC_PANELS_FILE, NULL);
mc_main_config = mc_config_init(profile);
if (!exist_file(panels_profile_name))
setup__move_panels_config_into_separate_file(profile);
mc_panels_config = mc_config_init(panels_profile_name);
1998-02-27 07:54:42 +03:00
/* Load integer boolean options */
for (i = 0; int_options[i].opt_name; i++)
*int_options[i].opt_addr =
mc_config_get_int(mc_main_config, CONFIG_APP_SECTION, int_options[i].opt_name, *int_options[i].opt_addr);
1998-02-27 07:54:42 +03:00
/* Load string options */
for (i = 0; str_options[i].opt_name != NULL; i++)
*str_options[i].opt_addr =
mc_config_get_string (mc_main_config, CONFIG_APP_SECTION, str_options[i].opt_name, str_options[i].opt_defval);
load_layout ();
1998-02-27 07:54:42 +03:00
load_panelize ();
startup_left_mode = setup__load_panel_state ("New Left Panel");
startup_right_mode = setup__load_panel_state ("New Right Panel");
1998-02-27 07:54:42 +03:00
/* At least one of the panels is a listing panel */
if (startup_left_mode != view_listing && startup_right_mode!=view_listing)
startup_left_mode = view_listing;
1998-02-27 07:54:42 +03:00
if (!other_dir){
buffer = mc_config_get_string(mc_panels_config, "Dirs", "other_dir", ".");
1998-02-27 07:54:42 +03:00
if (vfs_file_is_local (buffer))
other_dir = buffer;
else
g_free (buffer);
1998-02-27 07:54:42 +03:00
}
boot_current_is_left =
mc_config_get_int(mc_panels_config, "Dirs", "current_is_left", 1);
1998-02-27 07:54:42 +03:00
#ifdef USE_NETCODE
ftpfs_proxy_host = mc_config_get_string(mc_main_config, "Misc", "ftp_proxy_host", "gate");
1998-02-27 07:54:42 +03:00
#endif
setup_color_string = mc_config_get_string(mc_main_config, "Misc", "find_ignore_dirs", "");
if (setup_color_string [0])
find_ignore_dirs = g_strconcat (":", setup_color_string, ":", (char *) NULL);
g_free(setup_color_string);
1998-02-27 07:54:42 +03:00
/* The default color and the terminal dependent color */
setup_color_string = mc_config_get_string(mc_main_config, "Colors", "base_color", "");
term_color_string = mc_config_get_string(mc_main_config, "Colors", getenv ("TERM"), "");
color_terminal_string = mc_config_get_string(mc_main_config, "Colors", "color_terminals", "");
1998-02-27 07:54:42 +03:00
/* Load the directory history */
/* directory_history_load (); */
1998-02-27 07:54:42 +03:00
/* Remove the temporal entries */
#if defined(USE_VFS) && defined (USE_NETCODE)
2000-02-02 19:57:51 +03:00
ftpfs_init_passwd ();
#endif /* USE_VFS && USE_NETCODE */
#ifdef HAVE_CHARSET
if ( load_codepages_list() > 0 ) {
buffer = mc_config_get_string(mc_main_config, "Misc", "display_codepage", "");
if ( buffer[0] != '\0' )
{
display_codepage = get_codepage_index( buffer );
cp_display = get_codepage_id (display_codepage);
}
g_free(buffer);
buffer = mc_config_get_string(mc_main_config, "Misc", "source_codepage", "");
if ( buffer[0] != '\0' )
{
source_codepage = get_codepage_index( buffer );
cp_source = get_codepage_id (source_codepage);
}
g_free(buffer);
}
init_translation_table( source_codepage, display_codepage );
if ( get_codepage_id( display_codepage ) )
utf8_display = str_isutf8 (get_codepage_id( display_codepage ));
#endif /* HAVE_CHARSET */
1998-02-27 07:54:42 +03:00
}
#if defined(USE_VFS) && defined (USE_NETCODE)
1998-12-03 00:27:27 +03:00
char *
load_anon_passwd ()
1998-02-27 07:54:42 +03:00
{
char *buffer;
1998-02-27 07:54:42 +03:00
buffer = mc_config_get_string(mc_main_config, "Misc", "ftpfs_password", "");
1998-02-27 07:54:42 +03:00
if (buffer [0])
return buffer;
g_free(buffer);
return NULL;
1998-02-27 07:54:42 +03:00
}
#endif /* USE_VFS && USE_NETCODE */
1998-02-27 07:54:42 +03:00
void
done_setup (void)
1998-02-27 07:54:42 +03:00
{
int i;
g_free (profile_name);
g_free (global_profile_name);
g_free (color_terminal_string);
g_free (term_color_string);
g_free (setup_color_string);
g_free (panels_profile_name);
mc_config_deinit (mc_main_config);
mc_config_deinit (mc_panels_config);
for (i = 0; str_options[i].opt_name != NULL; i++)
g_free (*str_options[i].opt_addr);
1998-02-27 07:54:42 +03:00
done_hotlist ();
done_panelize ();
/* directory_history_free (); */
1998-02-27 07:54:42 +03:00
}
static void
load_keys_from_section (const char *terminal, mc_config_t *cfg)
{
char *section_name;
gchar **profile_keys, **keys;
gchar **values, **curr_values;
char *valcopy, *value;
long key_code;
gsize len, values_len;
if (!terminal)
return;
section_name = g_strconcat ("terminal:", terminal, (char *) NULL);
profile_keys = keys = mc_config_get_keys (cfg, section_name, &len);
while (*profile_keys){
/* copy=other causes all keys from [terminal:other] to be loaded. */
if (g_strcasecmp (*profile_keys, "copy") == 0) {
valcopy = mc_config_get_string (cfg, section_name, *profile_keys, "");
load_keys_from_section (valcopy, cfg);
g_free(valcopy);
profile_keys++;
continue;
}
curr_values = values = mc_config_get_string_list (cfg, section_name, *profile_keys, &values_len);
key_code = lookup_key (*profile_keys, NULL);
if (key_code != 0) {
if (curr_values){
while (*curr_values){
valcopy = convert_controls (*curr_values);
define_sequence (key_code, valcopy, MCKEY_NOACTION);
g_free (valcopy);
curr_values++;
}
} else {
value = mc_config_get_string (cfg, section_name, *profile_keys, "");
valcopy = convert_controls (value);
define_sequence (key_code, valcopy, MCKEY_NOACTION);
g_free (valcopy);
g_free (value);
}
}
profile_keys++;
if (values)
g_strfreev (values);
}
g_strfreev (keys);
g_free (section_name);
}
1998-02-27 07:54:42 +03:00
void load_key_defs (void)
{
/*
* Load keys from mc.lib before ~/.mc/ini, so that the user
* definitions override global settings.
*/
mc_config_t *mc_global_config;
mc_global_config = mc_config_init(global_profile_name);
if (mc_global_config != NULL)
{
load_keys_from_section ("general", mc_global_config);
load_keys_from_section (getenv ("TERM"), mc_global_config);
mc_config_deinit(mc_global_config);
}
load_keys_from_section ("general", mc_main_config);
load_keys_from_section (getenv ("TERM"), mc_main_config);
1998-02-27 07:54:42 +03:00
}
static void
load_keymap_from_section (const char *section_name, GArray *keymap, mc_config_t *cfg)
{
gchar **profile_keys, **keys;
gchar **values, **curr_values;
char *valcopy, *value;
int action;
gsize len, values_len;
if (!section_name)
return;
profile_keys = keys = mc_config_get_keys (cfg, section_name, &len);
while (*profile_keys) {
curr_values = values = mc_config_get_string_list (cfg, section_name, *profile_keys, &values_len);
action = lookup_action (*profile_keys);
if (action>0) {
if (curr_values) {
while (*curr_values) {
valcopy = convert_controls (*curr_values);
keybind_cmd_bind (keymap, valcopy, action);
g_free (valcopy);
curr_values++;
}
} else {
value = mc_config_get_string (cfg, section_name, *profile_keys, "");
valcopy = convert_controls (value);
/* define_sequence (key_code, valcopy, MCKEY_NOACTION); */
g_free (valcopy);
g_free (value);
}
}
profile_keys++;
if (values)
g_strfreev(values);
}
g_strfreev(keys);
}
void
load_keymap_defs (void)
{
/*
* Load keymap from GLOBAL_KEYMAP_FILE before ~/.mc/keymap, so that the user
* definitions override global settings.
*/
mc_config_t *mc_global_keymap;
mc_global_keymap = load_setup_get_keymap_profile_config();
if (mc_global_keymap != NULL)
{
#ifdef USE_INTERNAL_EDIT
editor_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("editor", editor_keymap, mc_global_keymap);
editor_x_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("editor:xmap", editor_x_keymap, mc_global_keymap);
#endif
viewer_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("viewer", viewer_keymap, mc_global_keymap);
viewer_hex_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("viewer:hex", viewer_hex_keymap, mc_global_keymap);
main_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("main", main_keymap, mc_global_keymap);
main_x_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("main:xmap", main_x_keymap, mc_global_keymap);
panel_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("panel", panel_keymap, mc_global_keymap);
input_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
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);
help_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
load_keymap_from_section ("help", help_keymap, mc_global_keymap);
mc_config_deinit (mc_global_keymap);
}
}
void
free_keymap_defs (void)
{
#ifdef USE_INTERNAL_EDIT
g_array_free (editor_keymap, TRUE);
g_array_free (editor_x_keymap, TRUE);
#endif
g_array_free (viewer_keymap, TRUE);
g_array_free (viewer_hex_keymap, TRUE);
g_array_free (main_keymap, TRUE);
g_array_free (main_x_keymap, TRUE);
g_array_free (panel_keymap, TRUE);
g_array_free (input_keymap, TRUE);
g_array_free (tree_keymap, TRUE);
g_array_free (help_keymap, TRUE);
}
void
setup_save_config_show_error(const char *filename, GError **error)
{
if (error == NULL || *error == NULL)
return;
message (D_ERROR, MSG_ERROR, _("Cannot save file %s:\n%s"),
filename, (*error)->message);
g_error_free(*error);
*error = NULL;
}