Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
84e1e560
Commit
84e1e560
authored
Jan 30, 2022
by
Edward Thomson
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'boretrk/futils_mktmp'
parents
bc746910
4517a48b
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
52 additions
and
14 deletions
+52
-14
src/futils.c
+14
-12
src/futils.h
+10
-2
src/posix.h
+2
-0
tests/core/futils.c
+26
-0
No files found.
src/futils.c
View file @
84e1e560
...
...
@@ -26,30 +26,32 @@ int git_futils_mkpath2file(const char *file_path, const mode_t mode)
int
git_futils_mktmp
(
git_str
*
path_out
,
const
char
*
filename
,
mode_t
mode
)
{
const
int
open_flags
=
O_RDWR
|
O_CREAT
|
O_EXCL
|
O_BINARY
|
O_CLOEXEC
;
/* TMP_MAX is unrelated to mktemp but should provide a reasonable amount */
unsigned
int
tries
=
TMP_MAX
;
int
fd
;
mode_t
mask
;
p_umask
(
mask
=
p_umask
(
0
));
while
(
tries
--
)
{
git_str_sets
(
path_out
,
filename
);
git_str_puts
(
path_out
,
"_git2_XXXXXX"
);
if
(
git_str_oom
(
path_out
))
return
-
1
;
if
((
fd
=
p_mkstemp
(
path_out
->
ptr
))
<
0
)
{
git_error_set
(
GIT_ERROR_OS
,
"failed to create temporary file '%s'"
,
path_out
->
ptr
);
return
-
1
;
/* Using mktemp is safe when we open with O_CREAT | O_EXCL */
p_mktemp
(
path_out
->
ptr
);
/* mktemp sets template to empty string on failure */
if
(
path_out
->
ptr
[
0
]
==
'\0'
)
break
;
if
((
fd
=
p_open
(
path_out
->
ptr
,
open_flags
,
mode
))
>=
0
)
return
fd
;
}
if
(
p_chmod
(
path_out
->
ptr
,
(
mode
&
~
mask
)))
{
git_error_set
(
GIT_ERROR_OS
,
"failed to set permissions on file '%s'"
,
path_out
->
ptr
);
"failed to create temporary file '%s'"
,
path_out
->
ptr
);
git_str_dispose
(
path_out
);
return
-
1
;
}
return
fd
;
}
int
git_futils_creat_withpath
(
const
char
*
path
,
const
mode_t
dirmode
,
const
mode_t
mode
)
...
...
src/futils.h
View file @
84e1e560
...
...
@@ -173,8 +173,16 @@ typedef enum {
extern
int
git_futils_rmdir_r
(
const
char
*
path
,
const
char
*
base
,
uint32_t
flags
);
/**
* Create and open a temporary file with a `_git2_` suffix.
* Writes the filename into path_out.
* Create and open a temporary file with a `_git2_` suffix in a
* protected directory; the file created will created will honor
* the current `umask`. Writes the filename into path_out.
*
* This function is *NOT* suitable for use in temporary directories
* that are world writable. It uses `mktemp` (for portability) and
* many `mktemp` implementations use weak random characters. It
* should only be assumed to be suitable for atomically writing
* a new file in a directory that you control.
*
* @return On success, an open file descriptor, else an error code < 0.
*/
extern
int
git_futils_mktmp
(
git_str
*
path_out
,
const
char
*
filename
,
mode_t
mode
);
...
...
src/posix.h
View file @
84e1e560
...
...
@@ -9,6 +9,7 @@
#include "common.h"
#include <stdlib.h>
#include <fcntl.h>
#include <time.h>
...
...
@@ -130,6 +131,7 @@ extern ssize_t p_pwrite(int fd, const void *data, size_t size, off64_t offset);
#define p_close(fd) close(fd)
#define p_umask(m) umask(m)
#define p_mktemp(p) mktemp(p)
extern
int
p_open
(
const
char
*
path
,
int
flags
,
...);
extern
int
p_creat
(
const
char
*
path
,
mode_t
mode
);
...
...
tests/core/futils.c
View file @
84e1e560
...
...
@@ -87,3 +87,29 @@ void test_core_futils__recursive_rmdir_keeps_symlink_targets(void)
cl_must_pass
(
p_rmdir
(
"dir-target"
));
cl_must_pass
(
p_unlink
(
"file-target"
));
}
void
test_core_futils__mktmp_umask
(
void
)
{
#ifdef GIT_WIN32
cl_skip
();
#else
git_str
path
=
GIT_STR_INIT
;
struct
stat
st
;
int
fd
;
umask
(
0
);
cl_assert
((
fd
=
git_futils_mktmp
(
&
path
,
"foo"
,
0777
))
>=
0
);
cl_must_pass
(
p_fstat
(
fd
,
&
st
));
cl_assert_equal_i
(
st
.
st_mode
&
0777
,
0777
);
cl_must_pass
(
p_unlink
(
path
.
ptr
));
close
(
fd
);
umask
(
077
);
cl_assert
((
fd
=
git_futils_mktmp
(
&
path
,
"foo"
,
0777
))
>=
0
);
cl_must_pass
(
p_fstat
(
fd
,
&
st
));
cl_assert_equal_i
(
st
.
st_mode
&
0777
,
0700
);
cl_must_pass
(
p_unlink
(
path
.
ptr
));
close
(
fd
);
git_str_dispose
(
&
path
);
#endif
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment