merge(third_party/git): Merge squashed git subtree at v2.23.0
Merge commit '1b593e1ea4' as 'third_party/git'
This commit is contained in:
commit
7ef0d62730
3629 changed files with 1139935 additions and 0 deletions
31
third_party/git/compat/access.c
vendored
Normal file
31
third_party/git/compat/access.c
vendored
Normal file
|
|
@ -0,0 +1,31 @@
|
|||
#define COMPAT_CODE_ACCESS
|
||||
#include "../git-compat-util.h"
|
||||
|
||||
/* Do the same thing access(2) does, but use the effective uid,
|
||||
* and don't make the mistake of telling root that any file is
|
||||
* executable. This version uses stat(2).
|
||||
*/
|
||||
int git_access(const char *path, int mode)
|
||||
{
|
||||
struct stat st;
|
||||
|
||||
/* do not interfere a normal user */
|
||||
if (geteuid())
|
||||
return access(path, mode);
|
||||
|
||||
if (stat(path, &st) < 0)
|
||||
return -1;
|
||||
|
||||
/* Root can read or write any file. */
|
||||
if (!(mode & X_OK))
|
||||
return 0;
|
||||
|
||||
/* Root can execute any file that has any one of the execute
|
||||
* bits set.
|
||||
*/
|
||||
if (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))
|
||||
return 0;
|
||||
|
||||
errno = EACCES;
|
||||
return -1;
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue