From ed70459b4d344323b99f7dbe4d562c365cbd1fdb Mon Sep 17 00:00:00 2001 From: Slava Zanko Date: Thu, 24 Mar 2011 14:28:31 +0200 Subject: [PATCH 1/3] Ticket #2495 (addition info about paths) Added -F option (AKA --datadir-info) for show extended information about used data dirs display info about default used paths by 'mc -V' Signed-off-by: Ilia Maslakov Signed-off-by: Slava Zanko --- src/args.c | 15 +++++++++++++++ src/textconf.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++++ src/textconf.h | 1 + 3 files changed, 65 insertions(+) diff --git a/src/args.c b/src/args.c index 15051622c..332538731 100644 --- a/src/args.c +++ b/src/args.c @@ -92,6 +92,7 @@ static GOptionContext *context; static gboolean mc_args__nouse_subshell = FALSE; static gboolean mc_args__show_datadirs = FALSE; +static gboolean mc_args__show_datadirs_extended = FALSE; static GOptionGroup *main_group; @@ -113,6 +114,14 @@ static const GOptionEntry argument_main_table[] = { NULL }, + /* show extended information about used data directories */ + { + "datadir-info", 'F', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_NONE, + &mc_args__show_datadirs_extended, + N_("Print extended info about used data directories"), + NULL + }, + { "printwd", 'P', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_STRING, &mc_args__last_wd_file, @@ -570,6 +579,12 @@ mc_args_process (int argc, char *argv[]) return FALSE; } + if (mc_args__show_datadirs_extended) + { + show_datadirs_extended (); + return FALSE; + } + if (mc_args__force_colors) mc_global.args.disable_colors = FALSE; diff --git a/src/textconf.c b/src/textconf.c index 3313d3b49..7a230d96b 100644 --- a/src/textconf.c +++ b/src/textconf.c @@ -29,6 +29,9 @@ #include #include "lib/global.h" +#include "lib/fileloc.h" +#include "lib/mcconfig.h" + #include "src/textconf.h" /*** global variables ****************************************************************************/ @@ -158,3 +161,49 @@ show_version (void) } /* --------------------------------------------------------------------------------------------- */ +#define PRINTF_GROUP(a) \ + (void) printf ("[%s]\n", a) +#define PRINTF_SECTION(a,b) \ + (void) printf (" %-17s %s\n", a, b) +#define PRINTF_SECTION2(a,b) \ + (void) printf (" %-17s %s/\n", a, b) +#define PRINTF(a, b, c) \ + (void) printf ("\t%-15s %s/%s\n", a, b, c) +#define PRINTF2(a, b, c) \ + (void) printf ("\t%-15s %s%s\n", a, b, c) + +void +show_datadirs_extended (void) +{ + PRINTF_GROUP (_("System data")); + + PRINTF_SECTION ( _("Config directory:"), mc_global.sysconfig_dir); + PRINTF_SECTION (_("Data directory:"), mc_global.share_data_dir); +#ifdef ENABLE_VFS_EXTFS + PRINTF2 ("extfs.d:", mc_global.share_data_dir, MC_EXTFS_DIR"/"); +#endif +#ifdef ENABLE_VFS_FISH + PRINTF2 ("fish:", mc_global.share_data_dir, FISH_PREFIX"/"); +#endif + (void) puts (""); + + PRINTF_GROUP (_("User data")); + + PRINTF_SECTION2 ( _("Config directory:"), mc_config_get_path ()); + PRINTF_SECTION2 (_("Data directory:"), mc_config_get_data_path ()); + PRINTF ("skins:", mc_config_get_data_path (), MC_SKINS_SUBDIR"/"); +#ifdef ENABLE_VFS_EXTFS + PRINTF ("extfs.d:", mc_config_get_data_path (), MC_EXTFS_DIR"/"); +#endif +#ifdef ENABLE_VFS_FISH + PRINTF ("fish:", mc_config_get_data_path (), FISH_PREFIX"/"); +#endif + + PRINTF_SECTION2 ( _("Cache directory:"), mc_config_get_cache_path ()); + +} +#undef PRINTF +#undef PRINTF_SECTION +#undef PRINTF_GROUP + +/* --------------------------------------------------------------------------------------------- */ diff --git a/src/textconf.h b/src/textconf.h index 0ea1fcfe8..616dc12e2 100644 --- a/src/textconf.h +++ b/src/textconf.h @@ -16,6 +16,7 @@ /*** declarations of public functions ************************************************************/ extern void show_version (void); +extern void show_datadirs_extended (void); /*** inline functions ****************************************************************************/ #endif /* MC__TEXTCONF_H */ From 56c83d03d46f34da2258ff0861a42419bea3d070 Mon Sep 17 00:00:00 2001 From: Slava Zanko Date: Thu, 24 Mar 2011 14:40:18 +0200 Subject: [PATCH 2/3] Added --configure-options for easy update & reconfigure existing mc. Signed-off-by: Slava Zanko --- configure.ac | 2 ++ src/args.c | 15 +++++++++++++++ src/textconf.c | 8 ++++++++ src/textconf.h | 1 + 4 files changed, 26 insertions(+) diff --git a/configure.ac b/configure.ac index 34b227401..d39e684e1 100644 --- a/configure.ac +++ b/configure.ac @@ -25,6 +25,8 @@ AC_CANONICAL_HOST AC_USE_SYSTEM_EXTENSIONS +AC_DEFINE_UNQUOTED([MC_CONFIGURE_ARGS],["$ac_configure_args"],[MC configure arguments]) + AC_PROG_LIBTOOL PKG_PROG_PKG_CONFIG AC_PATH_PROG([PERL], [perl], [/usr/bin/perl]) diff --git a/src/args.c b/src/args.c index 332538731..f6ad04eb1 100644 --- a/src/args.c +++ b/src/args.c @@ -93,6 +93,7 @@ static GOptionContext *context; static gboolean mc_args__nouse_subshell = FALSE; static gboolean mc_args__show_datadirs = FALSE; static gboolean mc_args__show_datadirs_extended = FALSE; +static gboolean mc_args__show_configure_opts = FALSE; static GOptionGroup *main_group; @@ -122,6 +123,14 @@ static const GOptionEntry argument_main_table[] = { NULL }, + /* show configure options */ + { + "configure-options", '\0', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_NONE, + &mc_args__show_configure_opts, + N_("Print configure options"), + NULL + }, + { "printwd", 'P', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_STRING, &mc_args__last_wd_file, @@ -585,6 +594,12 @@ mc_args_process (int argc, char *argv[]) return FALSE; } + if (mc_args__show_configure_opts) + { + show_configure_options (); + return FALSE; + } + if (mc_args__force_colors) mc_global.args.disable_colors = FALSE; diff --git a/src/textconf.c b/src/textconf.c index 7a230d96b..fc8d2e35c 100644 --- a/src/textconf.c +++ b/src/textconf.c @@ -207,3 +207,11 @@ show_datadirs_extended (void) #undef PRINTF_GROUP /* --------------------------------------------------------------------------------------------- */ + +void +show_configure_options (void) +{ + (void) printf ("%s\n", MC_CONFIGURE_ARGS); +} + +/* --------------------------------------------------------------------------------------------- */ diff --git a/src/textconf.h b/src/textconf.h index 616dc12e2..9e039ae14 100644 --- a/src/textconf.h +++ b/src/textconf.h @@ -17,6 +17,7 @@ extern void show_version (void); extern void show_datadirs_extended (void); +extern void show_configure_options (void); /*** inline functions ****************************************************************************/ #endif /* MC__TEXTCONF_H */ From 6cf2cd90556ada086386d5309e533360ed9e3674 Mon Sep 17 00:00:00 2001 From: Slava Zanko Date: Fri, 25 Mar 2011 13:21:08 +0200 Subject: [PATCH 3/3] Describe new command line options (-F and --configure-options) in English and Russian man pages. Signed-off-by: Slava Zanko --- doc/man/mc.1.in | 7 +++++++ doc/man/ru/mc.1.in | 9 ++++++++- 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/doc/man/mc.1.in b/doc/man/mc.1.in index e4f1bd6dd..d3ea307ac 100644 --- a/doc/man/mc.1.in +++ b/doc/man/mc.1.in @@ -55,6 +55,13 @@ startup. See also .I \-f, \-\-datadir Display the compiled\-in search paths for Midnight Commander files. .TP +.I \-F, \-\-datadir\-info +Display extended info about compiled\-in paths for +Midnight Commander. +.TP +.I \-\-configure\-options +Display configure options. +.TP .I \-k, \-\-resetsoft Reset softkeys to their default from the termcap/terminfo database. Only useful on HP terminals when the function keys don't work. diff --git a/doc/man/ru/mc.1.in b/doc/man/ru/mc.1.in index ab246c5e0..6ef100eac 100644 --- a/doc/man/ru/mc.1.in +++ b/doc/man/ru/mc.1.in @@ -62,10 +62,17 @@ UNIX\-подобных операционных системах. будет открыт при старте. Смотрите также .BR mcedit(1) . .TP -.I \-f +.I \-f, \-\-datadir Выводит на экран определенный в процессе компиляции программы путь к файлам программы Midnight Commander. .TP +.I \-F, \-\-datadir\-info +Выводит на экран расширенную информацию о путях, используемых при работе +программы Midnight Commander. +.TP +.I \-\-configure\-options +Выводит опции конфигурирования, с которыми был собран Midnight Commander. +.TP .I \-k Восстанавливает значения команд, назначенных функциональным клавишам в предусмотренные по умолчанию значения, используя базу данных