mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-05 11:04:42 +03:00
Merge branch '1617_ownership_of_user_home_files'
* 1617_ownership_of_user_home_files: Reorganize work with files. Fixed permissions of files in mc home dir. All file names now accumulated into src/fileloc.h Ticket #1617: ownership of files ~/.mc
This commit is contained in:
commit
705acef312
15
edit/edit.h
15
edit/edit.h
@ -33,6 +33,7 @@
|
|||||||
#define MC_EDIT_H
|
#define MC_EDIT_H
|
||||||
|
|
||||||
#include "../src/global.h" /* PATH_SEP_STR */
|
#include "../src/global.h" /* PATH_SEP_STR */
|
||||||
|
#include "../src/fileloc.h"
|
||||||
|
|
||||||
/* Editor widget */
|
/* Editor widget */
|
||||||
struct WEdit;
|
struct WEdit;
|
||||||
@ -77,18 +78,4 @@ const char *edit_get_file_name (const WEdit *edit);
|
|||||||
int edit_get_curs_col (const WEdit *edit);
|
int edit_get_curs_col (const WEdit *edit);
|
||||||
const char *edit_get_syntax_type (const WEdit *edit);
|
const char *edit_get_syntax_type (const WEdit *edit);
|
||||||
|
|
||||||
/* editor home directory */
|
|
||||||
#define EDIT_DIR ".mc" PATH_SEP_STR "cedit"
|
|
||||||
|
|
||||||
/* file names */
|
|
||||||
#define EDIT_SYNTAX_FILE EDIT_DIR PATH_SEP_STR "Syntax"
|
|
||||||
#define EDIT_CLIP_FILE EDIT_DIR PATH_SEP_STR "cooledit.clip"
|
|
||||||
#define EDIT_MACRO_FILE EDIT_DIR PATH_SEP_STR "cooledit.macros"
|
|
||||||
#define EDIT_BLOCK_FILE EDIT_DIR PATH_SEP_STR "cooledit.block"
|
|
||||||
#define EDIT_TEMP_FILE EDIT_DIR PATH_SEP_STR "cooledit.temp"
|
|
||||||
|
|
||||||
#define EDIT_GLOBAL_MENU "cedit.menu"
|
|
||||||
#define EDIT_LOCAL_MENU ".cedit.menu"
|
|
||||||
#define EDIT_HOME_MENU EDIT_DIR PATH_SEP_STR "menu"
|
|
||||||
|
|
||||||
#endif /* MC_EDIT_H */
|
#endif /* MC_EDIT_H */
|
||||||
|
@ -9,7 +9,6 @@
|
|||||||
#define SHORT_DEF_LEN 30
|
#define SHORT_DEF_LEN 30
|
||||||
#define LONG_DEF_LEN 40
|
#define LONG_DEF_LEN 40
|
||||||
#define LINE_DEF_LEN 16
|
#define LINE_DEF_LEN 16
|
||||||
#define TAGS_NAME "TAGS"
|
|
||||||
|
|
||||||
typedef struct etags_hash_struct {
|
typedef struct etags_hash_struct {
|
||||||
size_t filename_len;
|
size_t filename_len;
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
#include "strutil.h" /* utf-8 functions */
|
#include "strutil.h" /* utf-8 functions */
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "util.h" /* concat_dir_and_file() */
|
#include "util.h" /* concat_dir_and_file() */
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
int n_codepages = 0;
|
int n_codepages = 0;
|
||||||
|
|
||||||
|
@ -10,7 +10,6 @@
|
|||||||
|
|
||||||
#define UNKNCHAR '\001'
|
#define UNKNCHAR '\001'
|
||||||
|
|
||||||
#define CHARSETS_INDEX "mc.charsets"
|
|
||||||
extern int n_codepages;
|
extern int n_codepages;
|
||||||
|
|
||||||
extern unsigned char conv_displ[256];
|
extern unsigned char conv_displ[256];
|
||||||
|
13
src/cmd.c
13
src/cmd.c
@ -81,6 +81,7 @@
|
|||||||
#include "strutil.h"
|
#include "strutil.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
#include "cmddef.h" /* CK_InputHistoryShow */
|
#include "cmddef.h" /* CK_InputHistoryShow */
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
#ifndef MAP_FILE
|
#ifndef MAP_FILE
|
||||||
# define MAP_FILE 0
|
# define MAP_FILE 0
|
||||||
@ -601,7 +602,7 @@ void ext_cmd (void)
|
|||||||
extdir = concat_dir_and_file (mc_home, MC_LIB_EXT);
|
extdir = concat_dir_and_file (mc_home, MC_LIB_EXT);
|
||||||
|
|
||||||
if (dir == 0){
|
if (dir == 0){
|
||||||
buffer = concat_dir_and_file (home_dir, MC_USER_EXT);
|
buffer = g_build_filename (home_dir, MC_USERCONF_DIR, MC_FILEBIND_FILE, NULL);
|
||||||
check_for_default (extdir, buffer);
|
check_for_default (extdir, buffer);
|
||||||
do_edit (buffer);
|
do_edit (buffer);
|
||||||
g_free (buffer);
|
g_free (buffer);
|
||||||
@ -646,7 +647,7 @@ edit_mc_menu_cmd (void)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
buffer = concat_dir_and_file (home_dir, MC_HOME_MENU);
|
buffer = g_build_filename (home_dir, MC_USERCONF_DIR, MC_USERMENU_FILE, NULL);
|
||||||
check_for_default (menufile, buffer);
|
check_for_default (menufile, buffer);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -673,7 +674,6 @@ void edit_fhl_cmd (void)
|
|||||||
{
|
{
|
||||||
char *buffer = NULL;
|
char *buffer = NULL;
|
||||||
char *fhlfile = NULL;
|
char *fhlfile = NULL;
|
||||||
char *user_mc_dir;
|
|
||||||
|
|
||||||
int dir;
|
int dir;
|
||||||
|
|
||||||
@ -686,9 +686,7 @@ void edit_fhl_cmd (void)
|
|||||||
fhlfile = concat_dir_and_file (mc_home, MC_FHL_INI_FILE);
|
fhlfile = concat_dir_and_file (mc_home, MC_FHL_INI_FILE);
|
||||||
|
|
||||||
if (dir == 0){
|
if (dir == 0){
|
||||||
user_mc_dir = concat_dir_and_file (home_dir, MC_BASE);
|
buffer = g_build_filename (home_dir, MC_USERCONF_DIR, MC_FHL_INI_FILE, NULL);
|
||||||
buffer = concat_dir_and_file (user_mc_dir, MC_FHL_INI_FILE);
|
|
||||||
g_free(user_mc_dir);
|
|
||||||
check_for_default (fhlfile, buffer);
|
check_for_default (fhlfile, buffer);
|
||||||
do_edit (buffer);
|
do_edit (buffer);
|
||||||
g_free (buffer);
|
g_free (buffer);
|
||||||
@ -1308,7 +1306,8 @@ void
|
|||||||
save_setup_cmd (void)
|
save_setup_cmd (void)
|
||||||
{
|
{
|
||||||
save_setup ();
|
save_setup ();
|
||||||
message (D_NORMAL, _(" Setup "), _(" Setup saved to ~/%s"), PROFILE_NAME);
|
message (D_NORMAL, _(" Setup "), _(" Setup saved to ~/%s"),
|
||||||
|
MC_USERCONF_DIR PATH_SEP_STR MC_CONFIG_FILE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -449,7 +449,7 @@ regex_command (const char *filename, const char *action, int *move_dir)
|
|||||||
int mc_user_ext = 1;
|
int mc_user_ext = 1;
|
||||||
int home_error = 0;
|
int home_error = 0;
|
||||||
|
|
||||||
extension_file = concat_dir_and_file (home_dir, MC_USER_EXT);
|
extension_file = g_build_filename (home_dir, MC_USERCONF_DIR, MC_FILEBIND_FILE, NULL);
|
||||||
if (!exist_file (extension_file)) {
|
if (!exist_file (extension_file)) {
|
||||||
g_free (extension_file);
|
g_free (extension_file);
|
||||||
check_stock_mc_ext:
|
check_stock_mc_ext:
|
||||||
@ -489,11 +489,11 @@ regex_command (const char *filename, const char *action, int *move_dir)
|
|||||||
}
|
}
|
||||||
if (home_error) {
|
if (home_error) {
|
||||||
char *title =
|
char *title =
|
||||||
g_strdup_printf (_(" ~/%s file error "), MC_USER_EXT);
|
g_strdup_printf (_(" ~/%s file error "), MC_USERCONF_DIR PATH_SEP_STR MC_FILEBIND_FILE);
|
||||||
message (D_ERROR, title, _("The format of the ~/%s file has "
|
message (D_ERROR, title, _("The format of the ~/%s file has "
|
||||||
"changed with version 3.0. You may either want to copy "
|
"changed with version 3.0. You may either want to copy "
|
||||||
"it from %smc.ext or use that file as an example of how "
|
"it from %smc.ext or use that file as an example of how "
|
||||||
"to write it."), MC_USER_EXT, mc_home);
|
"to write it."), MC_USERCONF_DIR PATH_SEP_STR MC_FILEBIND_FILE, mc_home);
|
||||||
g_free (title);
|
g_free (title);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13,7 +13,4 @@ int regex_command (const char *filename, const char *action, int *move_dir);
|
|||||||
*/
|
*/
|
||||||
void flush_extension_file (void);
|
void flush_extension_file (void);
|
||||||
|
|
||||||
#define MC_USER_EXT ".mc/bindings"
|
|
||||||
#define MC_LIB_EXT "mc.ext"
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -5,8 +5,6 @@
|
|||||||
#include "../../src/search/search.h"
|
#include "../../src/search/search.h"
|
||||||
#include "../src/dir.h"
|
#include "../src/dir.h"
|
||||||
|
|
||||||
#define MC_FHL_INI_FILE "filehighlight.ini"
|
|
||||||
|
|
||||||
/*** typedefs(not structures) and defined constants **********************************************/
|
/*** typedefs(not structures) and defined constants **********************************************/
|
||||||
|
|
||||||
/*** enums ***************************************************************************************/
|
/*** enums ***************************************************************************************/
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
|
|
||||||
#include "../src/global.h"
|
#include "../src/global.h"
|
||||||
#include "../src/main.h"
|
#include "../src/main.h"
|
||||||
|
#include "../src/fileloc.h"
|
||||||
#include "../src/strescape.h"
|
#include "../src/strescape.h"
|
||||||
#include "../src/skin/skin.h"
|
#include "../src/skin/skin.h"
|
||||||
#include "fhl.h"
|
#include "fhl.h"
|
||||||
@ -206,7 +207,6 @@ gboolean
|
|||||||
mc_fhl_init_from_standart_files (mc_fhl_t * fhl)
|
mc_fhl_init_from_standart_files (mc_fhl_t * fhl)
|
||||||
{
|
{
|
||||||
gchar *name;
|
gchar *name;
|
||||||
gchar *user_mc_dir;
|
|
||||||
|
|
||||||
/* ${datadir}/mc/filehighlight.ini */
|
/* ${datadir}/mc/filehighlight.ini */
|
||||||
name = concat_dir_and_file (mc_home_alt, MC_FHL_INI_FILE);
|
name = concat_dir_and_file (mc_home_alt, MC_FHL_INI_FILE);
|
||||||
@ -225,9 +225,8 @@ mc_fhl_init_from_standart_files (mc_fhl_t * fhl)
|
|||||||
g_free (name);
|
g_free (name);
|
||||||
|
|
||||||
/* ~/.mc/filehighlight.ini */
|
/* ~/.mc/filehighlight.ini */
|
||||||
user_mc_dir = concat_dir_and_file (home_dir, MC_BASE);
|
name = g_build_filename (home_dir, MC_USERCONF_DIR, MC_FHL_INI_FILE, NULL);
|
||||||
name = concat_dir_and_file (user_mc_dir, MC_FHL_INI_FILE);
|
|
||||||
g_free (user_mc_dir);
|
|
||||||
if (exist_file (name) && (!mc_fhl_read_ini_file (fhl, name))) {
|
if (exist_file (name) && (!mc_fhl_read_ini_file (fhl, name))) {
|
||||||
g_free (name);
|
g_free (name);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -14,7 +14,21 @@
|
|||||||
#ifndef MC_FILELOC_H
|
#ifndef MC_FILELOC_H
|
||||||
#define MC_FILELOC_H
|
#define MC_FILELOC_H
|
||||||
|
|
||||||
|
#ifndef MC_USERCONF_DIR
|
||||||
#define MC_USERCONF_DIR ".mc"
|
#define MC_USERCONF_DIR ".mc"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define TAGS_NAME "TAGS"
|
||||||
|
|
||||||
|
#define MC_GLOBAL_CONFIG_FILE "mc.lib"
|
||||||
|
#define MC_GLOBAL_MENU "mc.menu"
|
||||||
|
#define MC_LOCAL_MENU ".mc.menu"
|
||||||
|
#define MC_HINT "mc.hint"
|
||||||
|
#define GLOBAL_KEYMAP_FILE "mc.keymap"
|
||||||
|
#define CHARSETS_INDEX "mc.charsets"
|
||||||
|
#define MC_LIB_EXT "mc.ext"
|
||||||
|
|
||||||
|
|
||||||
#define MC_BASHRC_FILE "bashrc"
|
#define MC_BASHRC_FILE "bashrc"
|
||||||
#define MC_CONFIG_FILE "ini"
|
#define MC_CONFIG_FILE "ini"
|
||||||
@ -23,5 +37,23 @@
|
|||||||
#define MC_HISTORY_FILE "history"
|
#define MC_HISTORY_FILE "history"
|
||||||
#define MC_HOTLIST_FILE "hotlist"
|
#define MC_HOTLIST_FILE "hotlist"
|
||||||
#define MC_USERMENU_FILE "menu"
|
#define MC_USERMENU_FILE "menu"
|
||||||
|
#define MC_TREESTORE_FILE "Tree"
|
||||||
|
#define MC_PANELS_FILE "panels.ini"
|
||||||
|
#define MC_FHL_INI_FILE "filehighlight.ini"
|
||||||
|
#define MC_SKINS_SUBDIR "skins"
|
||||||
|
|
||||||
|
/* editor home directory */
|
||||||
|
#define EDIT_DIR MC_USERCONF_DIR PATH_SEP_STR "cedit"
|
||||||
|
|
||||||
|
/* file names */
|
||||||
|
#define EDIT_SYNTAX_FILE EDIT_DIR PATH_SEP_STR "Syntax"
|
||||||
|
#define EDIT_CLIP_FILE EDIT_DIR PATH_SEP_STR "cooledit.clip"
|
||||||
|
#define EDIT_MACRO_FILE EDIT_DIR PATH_SEP_STR "cooledit.macros"
|
||||||
|
#define EDIT_BLOCK_FILE EDIT_DIR PATH_SEP_STR "cooledit.block"
|
||||||
|
#define EDIT_TEMP_FILE EDIT_DIR PATH_SEP_STR "cooledit.temp"
|
||||||
|
|
||||||
|
#define EDIT_GLOBAL_MENU "cedit.menu"
|
||||||
|
#define EDIT_LOCAL_MENU ".cedit.menu"
|
||||||
|
#define EDIT_HOME_MENU EDIT_DIR PATH_SEP_STR "menu"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -59,6 +59,8 @@
|
|||||||
#include "glibcompat.h" /* g_strlcpy for glib < 2.0 */
|
#include "glibcompat.h" /* g_strlcpy for glib < 2.0 */
|
||||||
#include "history.h"
|
#include "history.h"
|
||||||
#include "strutil.h"
|
#include "strutil.h"
|
||||||
|
#include "util.h"
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
#define UX 5
|
#define UX 5
|
||||||
#define UY 2
|
#define UY 2
|
||||||
@ -1450,7 +1452,7 @@ load_hotlist (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!hotlist_file_name)
|
if (!hotlist_file_name)
|
||||||
hotlist_file_name = concat_dir_and_file (home_dir, HOTLIST_FILENAME);
|
hotlist_file_name = g_build_filename (home_dir, MC_USERCONF_DIR, MC_HOTLIST_FILE, NULL);
|
||||||
|
|
||||||
hotlist = new_hotlist ();
|
hotlist = new_hotlist ();
|
||||||
hotlist->type = HL_TYPE_GROUP;
|
hotlist->type = HL_TYPE_GROUP;
|
||||||
@ -1477,7 +1479,7 @@ load_hotlist (void)
|
|||||||
} else {
|
} else {
|
||||||
message (D_ERROR, _(" Hotlist Load "),
|
message (D_ERROR, _(" Hotlist Load "),
|
||||||
_("MC was unable to write ~/%s file, your old hotlist entries were not deleted"),
|
_("MC was unable to write ~/%s file, your old hotlist entries were not deleted"),
|
||||||
HOTLIST_FILENAME);
|
MC_USERCONF_DIR PATH_SEP_STR MC_HOTLIST_FILE);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
hot_load_file (hotlist);
|
hot_load_file (hotlist);
|
||||||
@ -1559,14 +1561,9 @@ int save_hotlist (void)
|
|||||||
struct stat stat_buf;
|
struct stat stat_buf;
|
||||||
|
|
||||||
if (!hotlist_state.readonly && hotlist_state.modified && hotlist_file_name) {
|
if (!hotlist_state.readonly && hotlist_state.modified && hotlist_file_name) {
|
||||||
char *fbak = g_strconcat (hotlist_file_name, ".bak", (char *) NULL);
|
mc_util_make_backup_if_possible (hotlist_file_name, ".bak");
|
||||||
|
|
||||||
rename (hotlist_file_name, fbak);
|
|
||||||
if ((hotlist_file = fopen (hotlist_file_name, "w")) != 0) {
|
if ((hotlist_file = fopen (hotlist_file_name, "w")) != 0) {
|
||||||
if (stat (fbak, &stat_buf) == 0)
|
|
||||||
chmod (hotlist_file_name, stat_buf.st_mode);
|
|
||||||
else
|
|
||||||
chmod (hotlist_file_name, S_IRUSR | S_IWUSR);
|
|
||||||
hot_save_group (hotlist);
|
hot_save_group (hotlist);
|
||||||
fclose (hotlist_file);
|
fclose (hotlist_file);
|
||||||
stat (hotlist_file_name, &stat_buf);
|
stat (hotlist_file_name, &stat_buf);
|
||||||
@ -1574,8 +1571,7 @@ int save_hotlist (void)
|
|||||||
saved = 1;
|
saved = 1;
|
||||||
hotlist_state.modified = 0;
|
hotlist_state.modified = 0;
|
||||||
} else
|
} else
|
||||||
rename (fbak, hotlist_file_name);
|
mc_util_restore_from_backup_if_possible (hotlist_file_name, ".bak");
|
||||||
g_free (fbak);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return saved;
|
return saved;
|
||||||
|
@ -4,8 +4,6 @@
|
|||||||
|
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
|
|
||||||
#define GLOBAL_KEYMAP_FILE "mc.keymap"
|
|
||||||
|
|
||||||
typedef struct name_key_map_t {
|
typedef struct name_key_map_t {
|
||||||
const char *name;
|
const char *name;
|
||||||
int val;
|
int val;
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
#include "logging.h"
|
#include "logging.h"
|
||||||
#include "setup.h"
|
#include "setup.h"
|
||||||
#include "../src/mcconfig/mcconfig.h"
|
#include "../src/mcconfig/mcconfig.h"
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
/*** file scope functions **********************************************/
|
/*** file scope functions **********************************************/
|
||||||
|
|
||||||
@ -64,7 +65,7 @@ mc_log(const char *fmt, ...)
|
|||||||
|
|
||||||
if (is_logging_enabled()) {
|
if (is_logging_enabled()) {
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
logfilename = g_strdup_printf("%s/.mc/log", home_dir);
|
logfilename = g_strdup_printf("%s/%s/log", home_dir, MC_USERCONF_DIR);
|
||||||
if ((f = fopen(logfilename, "a")) != NULL) {
|
if ((f = fopen(logfilename, "a")) != NULL) {
|
||||||
(void)vfprintf(f, fmt, args);
|
(void)vfprintf(f, fmt, args);
|
||||||
(void)fclose(f);
|
(void)fclose(f);
|
||||||
|
@ -2051,7 +2051,7 @@ main (int argc, char *argv[])
|
|||||||
|
|
||||||
/* create home directory */
|
/* create home directory */
|
||||||
/* do it after the screen library initialization to show the error message */
|
/* do it after the screen library initialization to show the error message */
|
||||||
mc_dir = concat_dir_and_file (home_dir, MC_BASE);
|
mc_dir = concat_dir_and_file (home_dir, MC_USERCONF_DIR);
|
||||||
canonicalize_pathname (mc_dir);
|
canonicalize_pathname (mc_dir);
|
||||||
if ((stat (mc_dir, &s) != 0) && (errno == ENOENT)
|
if ((stat (mc_dir, &s) != 0) && (errno == ENOENT)
|
||||||
&& mkdir (mc_dir, 0700) != 0)
|
&& mkdir (mc_dir, 0700) != 0)
|
||||||
|
@ -123,8 +123,6 @@ void init_menu (void);
|
|||||||
|
|
||||||
char *remove_encoding_from_path (const char *);
|
char *remove_encoding_from_path (const char *);
|
||||||
|
|
||||||
#define MC_BASE "/.mc/"
|
|
||||||
|
|
||||||
struct WPanel;
|
struct WPanel;
|
||||||
|
|
||||||
void directory_history_add (struct WPanel *panel, const char *dir);
|
void directory_history_add (struct WPanel *panel, const char *dir);
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
|
|
||||||
@ -41,8 +42,47 @@ mc_config_t *mc_panels_config;
|
|||||||
/*** file scope variables **********************************************/
|
/*** file scope variables **********************************************/
|
||||||
|
|
||||||
/*** file scope functions **********************************************/
|
/*** file scope functions **********************************************/
|
||||||
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
mc_config_new_or_override_file (mc_config_t * mc_config, const gchar * ini_path)
|
||||||
|
{
|
||||||
|
gchar *data, *written_data;
|
||||||
|
gsize len, total_written;
|
||||||
|
gboolean ret;
|
||||||
|
int fd;
|
||||||
|
ssize_t cur_written;
|
||||||
|
|
||||||
|
data = g_key_file_to_data (mc_config->handle, &len, NULL);
|
||||||
|
if (!exist_file (ini_path)) {
|
||||||
|
ret = g_file_set_contents (ini_path, data, len, NULL);
|
||||||
|
g_free (data);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
mc_util_make_backup_if_possible (ini_path, "~");
|
||||||
|
|
||||||
|
fd = mc_open (ini_path, O_WRONLY | O_TRUNC | O_SYNC, 0);
|
||||||
|
if (fd == -1)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
for (written_data = data, total_written = len;
|
||||||
|
(cur_written = mc_write (fd, (const void *) written_data, total_written)) > 0;
|
||||||
|
written_data += cur_written, total_written -= cur_written);
|
||||||
|
mc_close (fd);
|
||||||
|
g_free (data);
|
||||||
|
|
||||||
|
if (cur_written == -1) {
|
||||||
|
mc_util_restore_from_backup_if_possible (ini_path, "~");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
mc_util_unlink_backup_if_possible (ini_path, "~");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
/*** public functions **************************************************/
|
/*** public functions **************************************************/
|
||||||
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
|
|
||||||
mc_config_t *
|
mc_config_t *
|
||||||
mc_config_init (const gchar * ini_path)
|
mc_config_init (const gchar * ini_path)
|
||||||
@ -56,21 +96,17 @@ mc_config_init (const gchar * ini_path)
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
mc_config->handle = g_key_file_new ();
|
mc_config->handle = g_key_file_new ();
|
||||||
if (mc_config->handle == NULL)
|
if (mc_config->handle == NULL) {
|
||||||
{
|
|
||||||
g_free (mc_config);
|
g_free (mc_config);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (!ini_path || !exist_file (ini_path))
|
if (!ini_path || !exist_file (ini_path)) {
|
||||||
{
|
|
||||||
return mc_config;
|
return mc_config;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mc_stat (ini_path, &st) && st.st_size)
|
if (!mc_stat (ini_path, &st) && st.st_size) {
|
||||||
{
|
|
||||||
/* file present and not empty */
|
/* file present and not empty */
|
||||||
g_key_file_load_from_file
|
g_key_file_load_from_file (mc_config->handle, ini_path, G_KEY_FILE_KEEP_COMMENTS, NULL);
|
||||||
(mc_config->handle, ini_path, G_KEY_FILE_KEEP_COMMENTS, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
mc_config->ini_path = g_strdup (ini_path);
|
mc_config->ini_path = g_strdup (ini_path);
|
||||||
@ -94,8 +130,7 @@ mc_config_deinit (mc_config_t * mc_config)
|
|||||||
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
mc_config_has_param (mc_config_t * mc_config, const char *group,
|
mc_config_has_param (mc_config_t * mc_config, const char *group, const gchar * param)
|
||||||
const gchar * param)
|
|
||||||
{
|
{
|
||||||
if (!mc_config || !group || !param)
|
if (!mc_config || !group || !param)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -118,8 +153,7 @@ mc_config_has_group (mc_config_t * mc_config, const char *group)
|
|||||||
|
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
mc_config_del_param (mc_config_t * mc_config, const char *group,
|
mc_config_del_param (mc_config_t * mc_config, const char *group, const gchar * param)
|
||||||
const gchar * param)
|
|
||||||
{
|
{
|
||||||
if (!mc_config || !group || !param)
|
if (!mc_config || !group || !param)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -167,11 +201,9 @@ mc_config_read_file (mc_config_t * mc_config, const gchar * ini_path)
|
|||||||
|
|
||||||
groups = mc_config_get_groups (tmp_config, NULL);
|
groups = mc_config_get_groups (tmp_config, NULL);
|
||||||
|
|
||||||
for (curr_grp = groups; *curr_grp != NULL; curr_grp++)
|
for (curr_grp = groups; *curr_grp != NULL; curr_grp++) {
|
||||||
{
|
|
||||||
keys = mc_config_get_keys (tmp_config, *curr_grp, NULL);
|
keys = mc_config_get_keys (tmp_config, *curr_grp, NULL);
|
||||||
for (curr_key = keys; *curr_key != NULL; curr_key++)
|
for (curr_key = keys; *curr_key != NULL; curr_key++) {
|
||||||
{
|
|
||||||
value = g_key_file_get_value (tmp_config->handle, *curr_grp, *curr_key, NULL);
|
value = g_key_file_get_value (tmp_config->handle, *curr_grp, *curr_key, NULL);
|
||||||
if (value == NULL)
|
if (value == NULL)
|
||||||
continue;
|
continue;
|
||||||
@ -191,22 +223,10 @@ mc_config_read_file (mc_config_t * mc_config, const gchar * ini_path)
|
|||||||
gboolean
|
gboolean
|
||||||
mc_config_save_file (mc_config_t * mc_config)
|
mc_config_save_file (mc_config_t * mc_config)
|
||||||
{
|
{
|
||||||
gchar *data;
|
|
||||||
gsize len;
|
|
||||||
gboolean ret;
|
|
||||||
|
|
||||||
if (mc_config == NULL || mc_config->ini_path == NULL) {
|
if (mc_config == NULL || mc_config->ini_path == NULL) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
data = g_key_file_to_data (mc_config->handle,&len,NULL);
|
return mc_config_new_or_override_file (mc_config, mc_config->ini_path);
|
||||||
if (exist_file(mc_config->ini_path))
|
|
||||||
{
|
|
||||||
mc_unlink (mc_config->ini_path);
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = g_file_set_contents(mc_config->ini_path,data,len,NULL);
|
|
||||||
g_free(data);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
@ -214,22 +234,12 @@ mc_config_save_file (mc_config_t * mc_config)
|
|||||||
gboolean
|
gboolean
|
||||||
mc_config_save_to_file (mc_config_t * mc_config, const gchar * ini_path)
|
mc_config_save_to_file (mc_config_t * mc_config, const gchar * ini_path)
|
||||||
{
|
{
|
||||||
gchar *data;
|
|
||||||
gsize len;
|
|
||||||
gboolean ret;
|
|
||||||
|
|
||||||
if (mc_config == NULL) {
|
if (mc_config == NULL) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
data = g_key_file_to_data (mc_config->handle,&len,NULL);
|
return mc_config_new_or_override_file (mc_config, ini_path);
|
||||||
if (exist_file(ini_path))
|
|
||||||
{
|
|
||||||
mc_unlink (ini_path);
|
|
||||||
}
|
|
||||||
ret = g_file_set_contents(ini_path,data,len,NULL);
|
|
||||||
|
|
||||||
g_free(data);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
|
14
src/setup.c
14
src/setup.c
@ -275,7 +275,7 @@ save_layout (void)
|
|||||||
char *profile;
|
char *profile;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
profile = concat_dir_and_file (home_dir, PROFILE_NAME);
|
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
|
||||||
|
|
||||||
/* Save integer options */
|
/* Save integer options */
|
||||||
for (i = 0; layout [i].opt_name; i++){
|
for (i = 0; layout [i].opt_name; i++){
|
||||||
@ -292,7 +292,7 @@ save_configure (void)
|
|||||||
char *profile;
|
char *profile;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
profile = concat_dir_and_file (home_dir, PROFILE_NAME);
|
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
|
||||||
|
|
||||||
/* Save integer options */
|
/* Save integer options */
|
||||||
for (i = 0; int_options[i].opt_name; i++)
|
for (i = 0; int_options[i].opt_name; i++)
|
||||||
@ -380,7 +380,7 @@ save_setup (void)
|
|||||||
mc_config_set_string(mc_main_config, "Misc" , "source_codepage",
|
mc_config_set_string(mc_main_config, "Misc" , "source_codepage",
|
||||||
get_codepage_id( source_codepage ));
|
get_codepage_id( source_codepage ));
|
||||||
#endif /* HAVE_CHARSET */
|
#endif /* HAVE_CHARSET */
|
||||||
tmp_profile = concat_dir_and_file (home_dir, PROFILE_NAME);
|
tmp_profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
|
||||||
mc_config_save_to_file (mc_main_config, tmp_profile);
|
mc_config_save_to_file (mc_main_config, tmp_profile);
|
||||||
g_free (tmp_profile);
|
g_free (tmp_profile);
|
||||||
saving_setup = 0;
|
saving_setup = 0;
|
||||||
@ -687,7 +687,7 @@ setup_init (void)
|
|||||||
if (profile_name)
|
if (profile_name)
|
||||||
return profile_name;
|
return profile_name;
|
||||||
|
|
||||||
profile = concat_dir_and_file (home_dir, PROFILE_NAME);
|
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_CONFIG_FILE, NULL);
|
||||||
if (!exist_file (profile)){
|
if (!exist_file (profile)){
|
||||||
inifile = concat_dir_and_file (mc_home, "mc.ini");
|
inifile = concat_dir_and_file (mc_home, "mc.ini");
|
||||||
if (exist_file (inifile)){
|
if (exist_file (inifile)){
|
||||||
@ -720,13 +720,13 @@ load_setup (void)
|
|||||||
|
|
||||||
/* mc.lib is common for all users, but has priority lower than
|
/* mc.lib is common for all users, but has priority lower than
|
||||||
~/.mc/ini. FIXME: it's only used for keys and treestore now */
|
~/.mc/ini. FIXME: it's only used for keys and treestore now */
|
||||||
global_profile_name = concat_dir_and_file (mc_home, "mc.lib");
|
global_profile_name = concat_dir_and_file (mc_home, MC_GLOBAL_CONFIG_FILE);
|
||||||
if (!exist_file(global_profile_name)) {
|
if (!exist_file(global_profile_name)) {
|
||||||
g_free (global_profile_name);
|
g_free (global_profile_name);
|
||||||
global_profile_name = concat_dir_and_file (mc_home_alt, "mc.lib");
|
global_profile_name = concat_dir_and_file (mc_home_alt, MC_GLOBAL_CONFIG_FILE);
|
||||||
}
|
}
|
||||||
|
|
||||||
panels_profile_name = concat_dir_and_file (home_dir, PANELS_PROFILE_NAME);
|
panels_profile_name = g_build_filename (home_dir, MC_USERCONF_DIR, MC_PANELS_FILE, NULL);
|
||||||
|
|
||||||
mc_main_config = mc_config_init(profile);
|
mc_main_config = mc_config_init(profile);
|
||||||
|
|
||||||
|
@ -35,8 +35,4 @@ extern int verbose;
|
|||||||
extern int mouse_close_dialog;
|
extern int mouse_close_dialog;
|
||||||
extern int reverse_files_only;
|
extern int reverse_files_only;
|
||||||
|
|
||||||
#define PROFILE_NAME ".mc/ini"
|
|
||||||
#define HOTLIST_FILENAME ".mc/hotlist"
|
|
||||||
#define PANELS_PROFILE_NAME ".mc/panels.ini"
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
|
|
||||||
#include "../src/global.h"
|
#include "../src/global.h"
|
||||||
#include "../src/main.h"
|
#include "../src/main.h"
|
||||||
|
#include "../src/fileloc.h"
|
||||||
#include "skin.h"
|
#include "skin.h"
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
|
|
||||||
@ -49,7 +50,7 @@ mc_skin_ini_file_load_search_in_dir (mc_skin_t * mc_skin, const gchar * base_dir
|
|||||||
{
|
{
|
||||||
char *file_name, *file_name2;
|
char *file_name, *file_name2;
|
||||||
|
|
||||||
file_name = g_build_filename (base_dir, "skins", mc_skin->name, NULL);
|
file_name = g_build_filename (base_dir, MC_SKINS_SUBDIR, mc_skin->name, NULL);
|
||||||
if (exist_file (file_name)) {
|
if (exist_file (file_name)) {
|
||||||
mc_skin->config = mc_config_init (file_name);
|
mc_skin->config = mc_config_init (file_name);
|
||||||
g_free (file_name);
|
g_free (file_name);
|
||||||
@ -58,7 +59,7 @@ mc_skin_ini_file_load_search_in_dir (mc_skin_t * mc_skin, const gchar * base_dir
|
|||||||
g_free (file_name);
|
g_free (file_name);
|
||||||
|
|
||||||
file_name2 = g_strdup_printf ("%s.ini", mc_skin->name);
|
file_name2 = g_strdup_printf ("%s.ini", mc_skin->name);
|
||||||
file_name = g_build_filename (base_dir, "skins", file_name2, NULL);
|
file_name = g_build_filename (base_dir, MC_SKINS_SUBDIR, file_name2, NULL);
|
||||||
g_free (file_name2);
|
g_free (file_name2);
|
||||||
|
|
||||||
if (exist_file (file_name)) {
|
if (exist_file (file_name)) {
|
||||||
@ -91,7 +92,7 @@ mc_skin_ini_file_load (mc_skin_t * mc_skin)
|
|||||||
g_free (file_name);
|
g_free (file_name);
|
||||||
|
|
||||||
/* ~/.mc/skins/ */
|
/* ~/.mc/skins/ */
|
||||||
user_home_dir = concat_dir_and_file (home_dir, MC_BASE);
|
user_home_dir = concat_dir_and_file (home_dir, MC_USERCONF_DIR);
|
||||||
if (mc_skin_ini_file_load_search_in_dir (mc_skin, user_home_dir)) {
|
if (mc_skin_ini_file_load_search_in_dir (mc_skin, user_home_dir)) {
|
||||||
g_free (user_home_dir);
|
g_free (user_home_dir);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -58,6 +58,7 @@
|
|||||||
#include "../src/tty/key.h" /* XCTRL */
|
#include "../src/tty/key.h" /* XCTRL */
|
||||||
#include "subshell.h"
|
#include "subshell.h"
|
||||||
#include "strutil.h"
|
#include "strutil.h"
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
#ifndef WEXITSTATUS
|
#ifndef WEXITSTATUS
|
||||||
# define WEXITSTATUS(stat_val) ((unsigned)(stat_val) >> 8)
|
# define WEXITSTATUS(stat_val) ((unsigned)(stat_val) >> 8)
|
||||||
@ -247,7 +248,7 @@ init_subshell_child (const char *pty_name)
|
|||||||
|
|
||||||
switch (subshell_type) {
|
switch (subshell_type) {
|
||||||
case BASH:
|
case BASH:
|
||||||
init_file = ".mc/bashrc";
|
init_file = MC_USERCONF_DIR PATH_SEP_STR "bashrc";
|
||||||
if (access (init_file, R_OK) == -1)
|
if (access (init_file, R_OK) == -1)
|
||||||
init_file = ".bashrc";
|
init_file = ".bashrc";
|
||||||
|
|
||||||
@ -255,8 +256,8 @@ init_subshell_child (const char *pty_name)
|
|||||||
putenv ((char*)"HISTCONTROL=ignorespace");
|
putenv ((char*)"HISTCONTROL=ignorespace");
|
||||||
|
|
||||||
/* Allow alternative readline settings for MC */
|
/* Allow alternative readline settings for MC */
|
||||||
if (access (".mc/inputrc", R_OK) == 0)
|
if (access (MC_USERCONF_DIR PATH_SEP_STR "inputrc", R_OK) == 0)
|
||||||
putenv ((char*)"INPUTRC=.mc/inputrc");
|
putenv ((char*)"INPUTRC=" MC_USERCONF_DIR PATH_SEP_STR "/inputrc");
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -60,6 +60,7 @@
|
|||||||
#include "history.h"
|
#include "history.h"
|
||||||
#include "strutil.h"
|
#include "strutil.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
#define tlines(t) (t->is_panel ? t->widget.lines-2 - (show_mini_info ? 2 : 0) : t->widget.lines)
|
#define tlines(t) (t->is_panel ? t->widget.lines-2 - (show_mini_info ? 2 : 0) : t->widget.lines)
|
||||||
|
|
||||||
@ -154,13 +155,17 @@ static void load_tree (WTree *tree)
|
|||||||
static void save_tree (WTree *tree)
|
static void save_tree (WTree *tree)
|
||||||
{
|
{
|
||||||
int error;
|
int error;
|
||||||
|
char *tree_name;
|
||||||
|
|
||||||
(void) tree;
|
(void) tree;
|
||||||
error = tree_store_save ();
|
error = tree_store_save ();
|
||||||
|
|
||||||
|
|
||||||
if (error){
|
if (error){
|
||||||
fprintf (stderr, _("Cannot open the %s file for writing:\n%s\n"), MC_TREE,
|
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));
|
unix_error_string (error));
|
||||||
|
g_free(tree_name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,6 +51,7 @@
|
|||||||
#include "treestore.h"
|
#include "treestore.h"
|
||||||
#include "../src/mcconfig/mcconfig.h"
|
#include "../src/mcconfig/mcconfig.h"
|
||||||
#include "setup.h"
|
#include "setup.h"
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
#define TREE_SIGNATURE "Midnight Commander TreeStore v 2.0"
|
#define TREE_SIGNATURE "Midnight Commander TreeStore v 2.0"
|
||||||
|
|
||||||
@ -267,7 +268,7 @@ tree_store_load(void)
|
|||||||
char *name;
|
char *name;
|
||||||
int retval;
|
int retval;
|
||||||
|
|
||||||
name = concat_dir_and_file(home_dir, MC_TREE);
|
name = g_build_filename (home_dir, MC_USERCONF_DIR, MC_TREESTORE_FILE, NULL);
|
||||||
retval = tree_store_load_from(name);
|
retval = tree_store_load_from(name);
|
||||||
g_free(name);
|
g_free(name);
|
||||||
|
|
||||||
@ -366,27 +367,20 @@ tree_store_save_to(char *name)
|
|||||||
int
|
int
|
||||||
tree_store_save(void)
|
tree_store_save(void)
|
||||||
{
|
{
|
||||||
char *tmp;
|
|
||||||
char *name;
|
char *name;
|
||||||
int retval;
|
int retval;
|
||||||
|
|
||||||
tmp = concat_dir_and_file(home_dir, MC_TREE_TMP);
|
name = g_build_filename (home_dir, MC_USERCONF_DIR, MC_TREESTORE_FILE, NULL);
|
||||||
retval = tree_store_save_to(tmp);
|
mc_util_make_backup_if_possible (name, ".tmp");
|
||||||
|
|
||||||
if (retval) {
|
if ((retval = tree_store_save_to(name)) != 0) {
|
||||||
g_free(tmp);
|
mc_util_restore_from_backup_if_possible (name, ".tmp");
|
||||||
|
g_free(name);
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
name = concat_dir_and_file(home_dir, MC_TREE);
|
mc_util_unlink_backup_if_possible (name, ".tmp");
|
||||||
retval = rename(tmp, name);
|
|
||||||
|
|
||||||
g_free(tmp);
|
|
||||||
g_free(name);
|
g_free(name);
|
||||||
|
|
||||||
if (retval)
|
|
||||||
return errno;
|
|
||||||
else
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,11 +8,6 @@
|
|||||||
#ifndef MC_TREE_STORE_H
|
#ifndef MC_TREE_STORE_H
|
||||||
#define MC_TREE_STORE_H
|
#define MC_TREE_STORE_H
|
||||||
|
|
||||||
/* Default filenames for the tree */
|
|
||||||
|
|
||||||
#define MC_TREE ".mc/Tree"
|
|
||||||
#define MC_TREE_TMP ".mc/Tree.tmp"
|
|
||||||
|
|
||||||
typedef struct tree_entry {
|
typedef struct tree_entry {
|
||||||
char *name; /* The full path of directory */
|
char *name; /* The full path of directory */
|
||||||
int sublevel; /* Number of parent directories (slashes) */
|
int sublevel; /* Number of parent directories (slashes) */
|
||||||
|
@ -758,8 +758,12 @@ user_menu_cmd (WEdit *edit_widget)
|
|||||||
menu = g_strdup (edit_widget ? EDIT_LOCAL_MENU : MC_LOCAL_MENU);
|
menu = g_strdup (edit_widget ? EDIT_LOCAL_MENU : MC_LOCAL_MENU);
|
||||||
if (!exist_file (menu) || !menu_file_own (menu)){
|
if (!exist_file (menu) || !menu_file_own (menu)){
|
||||||
g_free (menu);
|
g_free (menu);
|
||||||
menu = concat_dir_and_file
|
if (edit_widget)
|
||||||
(home_dir, edit_widget ? EDIT_HOME_MENU : MC_HOME_MENU);
|
menu = concat_dir_and_file (home_dir, EDIT_HOME_MENU);
|
||||||
|
else
|
||||||
|
menu = g_build_filename (home_dir, MC_USERCONF_DIR, MC_USERMENU_FILE, NULL);
|
||||||
|
|
||||||
|
|
||||||
if (!exist_file (menu)){
|
if (!exist_file (menu)){
|
||||||
g_free (menu);
|
g_free (menu);
|
||||||
menu = concat_dir_and_file
|
menu = concat_dir_and_file
|
||||||
|
@ -14,9 +14,4 @@ int check_format_view (const char *);
|
|||||||
int check_format_var (const char *, char **);
|
int check_format_var (const char *, char **);
|
||||||
int check_format_cd (const char *);
|
int check_format_cd (const char *);
|
||||||
|
|
||||||
#define MC_GLOBAL_MENU "mc.menu"
|
|
||||||
#define MC_LOCAL_MENU ".mc.menu"
|
|
||||||
#define MC_HOME_MENU ".mc/menu"
|
|
||||||
#define MC_HINT "mc.hint"
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
137
src/util.c
137
src/util.c
@ -54,6 +54,7 @@
|
|||||||
#include "fileopctx.h"
|
#include "fileopctx.h"
|
||||||
#include "file.h" /* copy_file_file() */
|
#include "file.h" /* copy_file_file() */
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
|
#include "fileloc.h"
|
||||||
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
#include "charsets.h"
|
#include "charsets.h"
|
||||||
@ -1139,6 +1140,30 @@ resolve_symlinks (const char *path)
|
|||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
mc_util_write_backup_content(const char *from_file_name, const char *to_file_name)
|
||||||
|
{
|
||||||
|
FILE *backup_fd;
|
||||||
|
char *contents;
|
||||||
|
gsize length;
|
||||||
|
|
||||||
|
if (!g_file_get_contents (from_file_name, &contents, &length, NULL))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
backup_fd = fopen (to_file_name, "w");
|
||||||
|
if (backup_fd == NULL) {
|
||||||
|
g_free(contents);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
fwrite ( (const void *) contents, length, 1, backup_fd);
|
||||||
|
|
||||||
|
fflush(backup_fd);
|
||||||
|
fclose(backup_fd);
|
||||||
|
g_free(contents);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
/* Finds out a relative path from first to second, i.e. goes as many ..
|
/* Finds out a relative path from first to second, i.e. goes as many ..
|
||||||
* as needed up in first and then goes down using second */
|
* as needed up in first and then goes down using second */
|
||||||
char *
|
char *
|
||||||
@ -1337,7 +1362,7 @@ load_file_position (const char *filename, long *line, long *column)
|
|||||||
*column = 0;
|
*column = 0;
|
||||||
|
|
||||||
/* open file with positions */
|
/* open file with positions */
|
||||||
fn = concat_dir_and_file (home_dir, MC_FILEPOS);
|
fn = g_build_filename (home_dir, MC_USERCONF_DIR, MC_FILEPOS_FILE, NULL);
|
||||||
f = fopen (fn, "r");
|
f = fopen (fn, "r");
|
||||||
g_free (fn);
|
g_free (fn);
|
||||||
if (!f)
|
if (!f)
|
||||||
@ -1376,50 +1401,36 @@ load_file_position (const char *filename, long *line, long *column)
|
|||||||
void
|
void
|
||||||
save_file_position (const char *filename, long line, long column)
|
save_file_position (const char *filename, long line, long column)
|
||||||
{
|
{
|
||||||
char *tmp, *fn;
|
char *fn;
|
||||||
FILE *f, *t;
|
FILE *f;
|
||||||
char buf[MC_MAXPATHLEN + 20];
|
|
||||||
int i = 1;
|
|
||||||
int len;
|
|
||||||
|
|
||||||
len = strlen (filename);
|
|
||||||
|
|
||||||
tmp = concat_dir_and_file (home_dir, MC_FILEPOS_TMP);
|
fn = g_build_filename (home_dir, MC_USERCONF_DIR, MC_FILEPOS_FILE, NULL);
|
||||||
fn = concat_dir_and_file (home_dir, MC_FILEPOS);
|
if (fn == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
/* open temporary file */
|
if (! mc_util_make_backup_if_possible (fn, ".tmp"))
|
||||||
t = fopen (tmp, "w");
|
return;
|
||||||
if (!t) {
|
|
||||||
g_free (tmp);
|
/* open file */
|
||||||
|
f = fopen (fn, "a");
|
||||||
|
if (f == NULL) {
|
||||||
g_free (fn);
|
g_free (fn);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* put the new record */
|
/* put the new record */
|
||||||
if (line != 1 || column != 0) {
|
if (line != 1 || column != 0) {
|
||||||
fprintf (t, "%s %ld;%ld\n", filename, line, column);
|
if (fprintf (f, "%s %ld;%ld\n", filename, line, column) < 0) {
|
||||||
}
|
|
||||||
|
|
||||||
/* copy records from the old file */
|
|
||||||
f = fopen (fn, "r");
|
|
||||||
if (f) {
|
|
||||||
while (fgets (buf, sizeof (buf), f)) {
|
|
||||||
/* Skip entries for the current filename */
|
|
||||||
if (strncmp (buf, filename, len) == 0 && buf[len] == ' '
|
|
||||||
&& !strchr (&buf[len + 1], ' '))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
fprintf (t, "%s", buf);
|
|
||||||
if (++i > MC_FILEPOS_ENTRIES)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
fclose (f);
|
fclose (f);
|
||||||
|
mc_util_restore_from_backup_if_possible (fn, ".tmp");
|
||||||
}
|
}
|
||||||
|
} else
|
||||||
|
fclose (f);
|
||||||
|
|
||||||
fclose (t);
|
mc_util_unlink_backup_if_possible (fn, ".tmp");
|
||||||
rename (tmp, fn);
|
|
||||||
g_free (tmp);
|
|
||||||
g_free (fn);
|
g_free (fn);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
extern const char *
|
extern const char *
|
||||||
@ -1468,3 +1479,65 @@ Q_ (const char *s)
|
|||||||
return (sep != NULL) ? sep + 1 : result;
|
return (sep != NULL) ? sep + 1 : result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
mc_util_make_backup_if_possible (const char *file_name, const char *backup_suffix)
|
||||||
|
{
|
||||||
|
struct stat stat_buf;
|
||||||
|
char *backup_path;
|
||||||
|
gboolean ret;
|
||||||
|
|
||||||
|
if (!exist_file (file_name))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
backup_path = g_strdup_printf("%s%s",file_name,backup_suffix);
|
||||||
|
|
||||||
|
if (backup_path == NULL)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
ret = mc_util_write_backup_content (file_name, backup_path);
|
||||||
|
|
||||||
|
if (ret) {
|
||||||
|
/* Backup file will have same ownership with main file. */
|
||||||
|
if (stat (file_name, &stat_buf) == 0)
|
||||||
|
chmod (backup_path, stat_buf.st_mode);
|
||||||
|
else
|
||||||
|
chmod (backup_path, S_IRUSR | S_IWUSR);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free(backup_path);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
mc_util_restore_from_backup_if_possible (const char *file_name, const char *backup_suffix)
|
||||||
|
{
|
||||||
|
gboolean ret;
|
||||||
|
char *backup_path;
|
||||||
|
|
||||||
|
backup_path = g_strdup_printf("%s%s",file_name,backup_suffix);
|
||||||
|
if (backup_path == NULL)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
ret = mc_util_write_backup_content (backup_path, file_name);
|
||||||
|
g_free(backup_path);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
mc_util_unlink_backup_if_possible (const char *file_name, const char *backup_suffix)
|
||||||
|
{
|
||||||
|
char *backup_path;
|
||||||
|
|
||||||
|
backup_path = g_strdup_printf("%s%s",file_name,backup_suffix);
|
||||||
|
if (backup_path == NULL)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (exist_file (backup_path))
|
||||||
|
mc_unlink (backup_path);
|
||||||
|
|
||||||
|
g_free(backup_path);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
@ -210,10 +210,6 @@ GList *list_append_unique (GList *list, char *text);
|
|||||||
|
|
||||||
/* Position saving and restoring */
|
/* Position saving and restoring */
|
||||||
|
|
||||||
/* file where positions are stored */
|
|
||||||
#define MC_FILEPOS ".mc/filepos"
|
|
||||||
/* temporary file */
|
|
||||||
#define MC_FILEPOS_TMP ".mc/filepos.tmp"
|
|
||||||
/* maximum entries in MC_FILEPOS */
|
/* maximum entries in MC_FILEPOS */
|
||||||
#define MC_FILEPOS_ENTRIES 1024
|
#define MC_FILEPOS_ENTRIES 1024
|
||||||
/* Load position for the given filename */
|
/* Load position for the given filename */
|
||||||
@ -286,6 +282,10 @@ static inline char * str_move(char * dest, const char * src)
|
|||||||
return memmove (dest, src, n);
|
return memmove (dest, src, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean mc_util_make_backup_if_possible (const char *, const char *);
|
||||||
|
gboolean mc_util_restore_from_backup_if_possible (const char *, const char *);
|
||||||
|
gboolean mc_util_unlink_backup_if_possible (const char *, const char *);
|
||||||
|
|
||||||
#define MC_PTR_FREE(ptr) do { g_free(ptr); (ptr) = NULL; } while (0)
|
#define MC_PTR_FREE(ptr) do { g_free(ptr); (ptr) = NULL; } while (0)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -56,8 +56,7 @@
|
|||||||
|
|
||||||
#include "cmddef.h" /* CK_ cmd name const */
|
#include "cmddef.h" /* CK_ cmd name const */
|
||||||
#include "keybind.h" /* global_key_map_t */
|
#include "keybind.h" /* global_key_map_t */
|
||||||
|
#include "fileloc.h"
|
||||||
#define HISTORY_FILE_NAME ".mc/history"
|
|
||||||
|
|
||||||
const global_key_map_t *input_map;
|
const global_key_map_t *input_map;
|
||||||
|
|
||||||
@ -911,7 +910,7 @@ history_get (const char *input_name)
|
|||||||
if (!input_name || !*input_name)
|
if (!input_name || !*input_name)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
profile = concat_dir_and_file (home_dir, HISTORY_FILE_NAME);
|
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_HISTORY_FILE, NULL);
|
||||||
cfg = mc_config_init (profile);
|
cfg = mc_config_init (profile);
|
||||||
|
|
||||||
/* get number of keys */
|
/* get number of keys */
|
||||||
@ -953,7 +952,7 @@ history_put (const char *input_name, GList *h)
|
|||||||
if (!num_history_items_recorded) /* this is how to disable */
|
if (!num_history_items_recorded) /* this is how to disable */
|
||||||
return;
|
return;
|
||||||
|
|
||||||
profile = concat_dir_and_file (home_dir, HISTORY_FILE_NAME);
|
profile = g_build_filename (home_dir, MC_USERCONF_DIR, MC_HISTORY_FILE, NULL);
|
||||||
|
|
||||||
if ((i = open (profile, O_CREAT | O_EXCL, S_IRUSR | S_IWUSR)) != -1)
|
if ((i = open (profile, O_CREAT | O_EXCL, S_IRUSR | S_IWUSR)) != -1)
|
||||||
close (i);
|
close (i);
|
||||||
|
Loading…
Reference in New Issue
Block a user