mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
Merge pull request #1034 'Implement os_mkdtemp
on top of uv_fs_mkdtemp
'
This commit is contained in:
commit
17e6000007
@ -566,11 +566,9 @@ attack or other people reading your file). When Vim exits the directory and
|
||||
all files in it are deleted. When Vim has the setuid bit set this may cause
|
||||
problems, the temp file is owned by the setuid user but the filter command
|
||||
probably runs as the original user.
|
||||
On MS-DOS and OS/2 the first of these directories that works is used: $TMP,
|
||||
$TEMP, c:\TMP, c:\TEMP.
|
||||
For Unix the list of directories is: $TMPDIR, /tmp, current-dir, $HOME.
|
||||
For MS-Windows the GetTempFileName() system function is used.
|
||||
For other systems the tmpnam() library function is used.
|
||||
Directory for temporary files is created in the first suitable directory of:
|
||||
For Unix: $TMPDIR, /tmp, current-dir, $HOME.
|
||||
For MS-Windows: $TMP, $TEMP, $USERPROFILE, current-dir.
|
||||
|
||||
|
||||
|
||||
|
@ -6212,8 +6212,7 @@ taglist({expr}) *taglist()*
|
||||
|
||||
tempname() *tempname()* *temp-file-name*
|
||||
The result is a String, which is the name of a file that
|
||||
doesn't exist. It can be used for a temporary file. The name
|
||||
is different for at least 26 consecutive calls. Example: >
|
||||
doesn't exist. It can be used for a temporary file. Example: >
|
||||
:let tmpfile = tempname()
|
||||
:exe "redir > " . tmpfile
|
||||
< For Unix, the file will be in a private directory |tempfile|.
|
||||
|
@ -3,13 +3,6 @@
|
||||
|
||||
#include <assert.h>
|
||||
|
||||
// TODO(hinidu): remove after implementing `os_mkdtemp` on top of libuv
|
||||
#ifdef WIN32
|
||||
# include <io.h>
|
||||
#else
|
||||
# include <stdlib.h>
|
||||
#endif
|
||||
|
||||
#include "nvim/os/os.h"
|
||||
#include "nvim/ascii.h"
|
||||
#include "nvim/memory.h"
|
||||
@ -293,18 +286,21 @@ int os_mkdir(const char *path, int32_t mode)
|
||||
}
|
||||
|
||||
/// Create a unique temporary directory.
|
||||
/// TODO(hinidu): Implement on top of libuv. ref #850
|
||||
///
|
||||
/// @param[in,out] template Template of the path to the directory with XXXXXX
|
||||
/// which would be replaced by random chars.
|
||||
/// @return Pointer to changed `template` for success, `NULL` for failure.
|
||||
char *os_mkdtemp(char *template)
|
||||
/// @param[in] template Template of the path to the directory with XXXXXX
|
||||
/// which would be replaced by random chars.
|
||||
/// @param[out] path Path to created directory for success, undefined for
|
||||
/// failure.
|
||||
/// @return `0` for success, non-zero for failure.
|
||||
int os_mkdtemp(const char *template, char *path)
|
||||
{
|
||||
#ifdef WIN32
|
||||
return _mktemp(template) && os_mkdir(template, 0700) == 0 ? template : NULL;
|
||||
#else
|
||||
return mkdtemp(template);
|
||||
#endif
|
||||
uv_fs_t request;
|
||||
int result = uv_fs_mkdtemp(uv_default_loop(), &request, template, NULL);
|
||||
if (result == kLibuvSuccess) {
|
||||
strcpy(path, request.path);
|
||||
}
|
||||
uv_fs_req_cleanup(&request);
|
||||
return result;
|
||||
}
|
||||
|
||||
/// Remove a directory.
|
||||
|
@ -28,26 +28,29 @@ static void vim_maketempdir(void)
|
||||
{
|
||||
static const char *temp_dirs[] = TEMP_DIR_NAMES;
|
||||
// Try the entries in `TEMP_DIR_NAMES` to create the temp directory.
|
||||
char_u itmp[TEMP_FILE_PATH_MAXLEN];
|
||||
char_u template[TEMP_FILE_PATH_MAXLEN];
|
||||
char_u path[TEMP_FILE_PATH_MAXLEN];
|
||||
for (size_t i = 0; i < sizeof(temp_dirs) / sizeof(char *); ++i) {
|
||||
// Expand environment variables, leave room for "/nvimXXXXXX/999999999"
|
||||
expand_env((char_u *)temp_dirs[i], itmp, TEMP_FILE_PATH_MAXLEN - 22);
|
||||
if (!os_isdir(itmp)) { // directory doesn't exist
|
||||
expand_env((char_u *)temp_dirs[i], template, TEMP_FILE_PATH_MAXLEN - 22);
|
||||
if (!os_isdir(template)) { // directory doesn't exist
|
||||
continue;
|
||||
}
|
||||
|
||||
add_pathsep(itmp);
|
||||
add_pathsep(template);
|
||||
// Concatenate with temporary directory name pattern
|
||||
STRCAT(itmp, "nvimXXXXXX");
|
||||
if (!os_mkdtemp((char *)itmp)) {
|
||||
STRCAT(template, "nvimXXXXXX");
|
||||
|
||||
if (os_mkdtemp((const char *)template, (char *)path) != 0) {
|
||||
continue;
|
||||
}
|
||||
if (vim_settempdir(itmp)) {
|
||||
|
||||
if (vim_settempdir(path)) {
|
||||
// Successfully created and set temporary directory so stop trying.
|
||||
break;
|
||||
} else {
|
||||
// Couldn't set `vim_tempdir` to itmp so remove created directory.
|
||||
os_rmdir((char *)itmp);
|
||||
// Couldn't set `vim_tempdir` to `path` so remove created directory.
|
||||
os_rmdir((char *)path);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -128,8 +131,8 @@ char_u *vim_tempname(void)
|
||||
|
||||
// There is no need to check if the file exists, because we own the directory
|
||||
// and nobody else creates a file in it.
|
||||
char_u itmp[TEMP_FILE_PATH_MAXLEN];
|
||||
snprintf((char *)itmp, TEMP_FILE_PATH_MAXLEN,
|
||||
char_u template[TEMP_FILE_PATH_MAXLEN];
|
||||
snprintf((char *)template, TEMP_FILE_PATH_MAXLEN,
|
||||
"%s%" PRIu32, tempdir, temp_count++);
|
||||
return vim_strsave(itmp);
|
||||
return vim_strsave(template);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user