mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-18 09:19:24 +03:00
Merge branch '4535_tmpdir_name'
* 4535_tmpdir_name: Ticket #4535: change name of temporary drirectory.
This commit is contained in:
commit
794823b885
@ -762,7 +762,7 @@ mc_mkstemps (vfs_path_t ** pname_vpath, const char *prefix, const char *suffix)
|
|||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
/**
|
/**
|
||||||
* Return the directory where mc should keep its temporary files.
|
* Return the directory where mc should keep its temporary files.
|
||||||
* This directory is (in Bourne shell terms) "${TMPDIR=/tmp}/mc-$USER"
|
* This directory is (in Bourne shell terms) "${TMPDIR=/tmp}/mc-XXXXXX"
|
||||||
* When called the first time, the directory is created if needed.
|
* When called the first time, the directory is created if needed.
|
||||||
* The first call should be done early, since we are using fprintf()
|
* The first call should be done early, since we are using fprintf()
|
||||||
* and not message() to report possible problems.
|
* and not message() to report possible problems.
|
||||||
@ -774,9 +774,7 @@ mc_tmpdir (void)
|
|||||||
static char buffer[PATH_MAX];
|
static char buffer[PATH_MAX];
|
||||||
static const char *tmpdir = NULL;
|
static const char *tmpdir = NULL;
|
||||||
const char *sys_tmp;
|
const char *sys_tmp;
|
||||||
struct passwd *pwd;
|
|
||||||
struct stat st;
|
struct stat st;
|
||||||
const char *error = NULL;
|
|
||||||
|
|
||||||
/* Check if already correctly initialized */
|
/* Check if already correctly initialized */
|
||||||
if (tmpdir != NULL && lstat (tmpdir, &st) == 0 && S_ISDIR (st.st_mode) &&
|
if (tmpdir != NULL && lstat (tmpdir, &st) == 0 && S_ISDIR (st.st_mode) &&
|
||||||
@ -791,84 +789,20 @@ mc_tmpdir (void)
|
|||||||
sys_tmp = TMPDIR_DEFAULT;
|
sys_tmp = TMPDIR_DEFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
pwd = getpwuid (getuid ());
|
g_snprintf (buffer, sizeof (buffer), "%s/mc-XXXXXX", sys_tmp);
|
||||||
if (pwd != NULL)
|
tmpdir = g_mkdtemp (buffer);
|
||||||
g_snprintf (buffer, sizeof (buffer), "%s/mc-%s", sys_tmp, pwd->pw_name);
|
if (tmpdir != NULL)
|
||||||
|
g_setenv ("MC_TMPDIR", tmpdir, TRUE);
|
||||||
else
|
else
|
||||||
g_snprintf (buffer, sizeof (buffer), "%s/mc-%lu", sys_tmp, (unsigned long) getuid ());
|
|
||||||
|
|
||||||
canonicalize_pathname (buffer);
|
|
||||||
|
|
||||||
/* Try to create directory */
|
|
||||||
if (mkdir (buffer, S_IRWXU) != 0)
|
|
||||||
{
|
{
|
||||||
if (errno == EEXIST && lstat (buffer, &st) == 0)
|
fprintf (stderr, _("Cannot create temporary directory %s: %s.\n"
|
||||||
{
|
"Temporary files will not be created\n"), buffer,
|
||||||
/* Sanity check for existing directory */
|
unix_error_string (errno));
|
||||||
if (!S_ISDIR (st.st_mode))
|
g_snprintf (buffer, sizeof (buffer), "%s", "/dev/null/");
|
||||||
error = _("%s is not a directory\n");
|
|
||||||
else if (st.st_uid != getuid ())
|
|
||||||
error = _("Directory %s is not owned by you\n");
|
|
||||||
else if (((st.st_mode & 0777) != 0700) && (chmod (buffer, 0700) != 0))
|
|
||||||
error = _("Cannot set correct permissions for directory %s\n");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
fprintf (stderr,
|
|
||||||
_("Cannot create temporary directory %s: %s\n"),
|
|
||||||
buffer, unix_error_string (errno));
|
|
||||||
error = "";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (error != NULL)
|
|
||||||
{
|
|
||||||
int test_fd;
|
|
||||||
char *fallback_prefix;
|
|
||||||
gboolean fallback_ok = FALSE;
|
|
||||||
vfs_path_t *test_vpath;
|
|
||||||
|
|
||||||
if (*error != '\0')
|
|
||||||
fprintf (stderr, error, buffer);
|
|
||||||
|
|
||||||
/* Test if sys_tmp is suitable for temporary files */
|
|
||||||
fallback_prefix = g_strdup_printf ("%s/mctest", sys_tmp);
|
|
||||||
test_fd = mc_mkstemps (&test_vpath, fallback_prefix, NULL);
|
|
||||||
g_free (fallback_prefix);
|
|
||||||
if (test_fd != -1)
|
|
||||||
{
|
|
||||||
close (test_fd);
|
|
||||||
test_fd = open (vfs_path_as_str (test_vpath), O_RDONLY);
|
|
||||||
if (test_fd != -1)
|
|
||||||
{
|
|
||||||
close (test_fd);
|
|
||||||
unlink (vfs_path_as_str (test_vpath));
|
|
||||||
fallback_ok = TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (fallback_ok)
|
|
||||||
{
|
|
||||||
fprintf (stderr, _("Temporary files will be created in %s\n"), sys_tmp);
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "%s", sys_tmp);
|
|
||||||
error = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
fprintf (stderr, _("Temporary files will not be created\n"));
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "%s", "/dev/null/");
|
|
||||||
}
|
|
||||||
|
|
||||||
vfs_path_free (test_vpath, TRUE);
|
|
||||||
fprintf (stderr, "%s\n", _("Press any key to continue..."));
|
fprintf (stderr, "%s\n", _("Press any key to continue..."));
|
||||||
getc (stdin);
|
getc (stdin);
|
||||||
}
|
}
|
||||||
|
|
||||||
tmpdir = buffer;
|
|
||||||
|
|
||||||
if (error == NULL)
|
|
||||||
g_setenv ("MC_TMPDIR", tmpdir, TRUE);
|
|
||||||
|
|
||||||
return tmpdir;
|
return tmpdir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
14
src/main.c
14
src/main.c
@ -62,6 +62,7 @@
|
|||||||
#include "filemanager/ext.h" /* flush_extension_file() */
|
#include "filemanager/ext.h" /* flush_extension_file() */
|
||||||
#include "filemanager/command.h" /* cmdline */
|
#include "filemanager/command.h" /* cmdline */
|
||||||
#include "filemanager/panel.h" /* panalized_panel */
|
#include "filemanager/panel.h" /* panalized_panel */
|
||||||
|
#include "filemanager/filenot.h" /* my_rmdir() */
|
||||||
|
|
||||||
#ifdef USE_INTERNAL_EDIT
|
#ifdef USE_INTERNAL_EDIT
|
||||||
#include "editor/edit.h" /* edit_arg_free() */
|
#include "editor/edit.h" /* edit_arg_free() */
|
||||||
@ -257,6 +258,7 @@ main (int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
GError *mcerror = NULL;
|
GError *mcerror = NULL;
|
||||||
int exit_code = EXIT_FAILURE;
|
int exit_code = EXIT_FAILURE;
|
||||||
|
const char *tmpdir = NULL;
|
||||||
|
|
||||||
mc_global.run_from_parent_mc = !check_sid ();
|
mc_global.run_from_parent_mc = !check_sid ();
|
||||||
|
|
||||||
@ -326,12 +328,17 @@ main (int argc, char *argv[])
|
|||||||
vfs_setup_work_dir ();
|
vfs_setup_work_dir ();
|
||||||
|
|
||||||
/* Set up temporary directory after VFS initialization */
|
/* Set up temporary directory after VFS initialization */
|
||||||
mc_tmpdir ();
|
tmpdir = mc_tmpdir ();
|
||||||
|
|
||||||
/* do this after vfs initialization and vfs working directory setup
|
/* do this after vfs initialization and vfs working directory setup
|
||||||
due to mc_setctl() and mcedit_arg_vpath_new() calls in mc_setup_by_args() */
|
due to mc_setctl() and mcedit_arg_vpath_new() calls in mc_setup_by_args() */
|
||||||
if (!mc_setup_by_args (argc, argv, &mcerror))
|
if (!mc_setup_by_args (argc, argv, &mcerror))
|
||||||
{
|
{
|
||||||
|
/* At exit, do this before vfs_shut():
|
||||||
|
normally, temporary directory should be empty */
|
||||||
|
vfs_expire (TRUE);
|
||||||
|
(void) my_rmdir (tmpdir);
|
||||||
|
|
||||||
vfs_shut ();
|
vfs_shut ();
|
||||||
done_setup ();
|
done_setup ();
|
||||||
g_free (saved_other_dir);
|
g_free (saved_other_dir);
|
||||||
@ -470,6 +477,11 @@ main (int argc, char *argv[])
|
|||||||
|
|
||||||
keymap_free ();
|
keymap_free ();
|
||||||
|
|
||||||
|
/* At exit, do this before vfs_shut():
|
||||||
|
normally, temporary directory should be empty */
|
||||||
|
vfs_expire (TRUE);
|
||||||
|
(void) my_rmdir (tmpdir);
|
||||||
|
|
||||||
/* Virtual File System shutdown */
|
/* Virtual File System shutdown */
|
||||||
vfs_shut ();
|
vfs_shut ();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user