diff options
| -rw-r--r-- | Makefile | 7 | ||||
| -rw-r--r-- | compat/fopen.c | 26 | ||||
| -rw-r--r-- | git-compat-util.h | 5 | 
3 files changed, 38 insertions, 0 deletions
| @@ -3,6 +3,9 @@ all::  # Define V=1 to have a more verbose compile.  # +# Define FREAD_READS_DIRECTORIES if your are on a system which succeeds +# when attempting to read from an fopen'ed directory. +#  # Define NO_OPENSSL environment variable if you do not have OpenSSL.  # This also implies MOZILLA_SHA1.  # @@ -622,6 +625,10 @@ endif  ifdef NO_C99_FORMAT  	BASIC_CFLAGS += -DNO_C99_FORMAT  endif +ifdef FREAD_READS_DIRECTORIES +	COMPAT_CFLAGS += -DFREAD_READS_DIRECTORIES +	COMPAT_OBJS += compat/fopen.o +endif  ifdef NO_SYMLINK_HEAD  	BASIC_CFLAGS += -DNO_SYMLINK_HEAD  endif diff --git a/compat/fopen.c b/compat/fopen.c new file mode 100644 index 0000000000..ccb9e89fa4 --- /dev/null +++ b/compat/fopen.c @@ -0,0 +1,26 @@ +#include "../git-compat-util.h" +#undef fopen +FILE *git_fopen(const char *path, const char *mode) +{ +	FILE *fp; +	struct stat st; + +	if (mode[0] == 'w' || mode[0] == 'a') +		return fopen(path, mode); + +	if (!(fp = fopen(path, mode))) +		return NULL; + +	if (fstat(fileno(fp), &st)) { +		fclose(fp); +		return NULL; +	} + +	if (S_ISDIR(st.st_mode)) { +		fclose(fp); +		errno = EISDIR; +		return NULL; +	} + +	return fp; +} diff --git a/git-compat-util.h b/git-compat-util.h index 05146047e0..2a40703c85 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -204,6 +204,11 @@ void *gitmemmem(const void *haystack, size_t haystacklen,                  const void *needle, size_t needlelen);  #endif +#ifdef FREAD_READS_DIRECTORIES +#define fopen(a,b) git_fopen(a,b) +extern FILE *git_fopen(const char*, const char*); +#endif +  #ifdef __GLIBC_PREREQ  #if __GLIBC_PREREQ(2, 1)  #define HAVE_STRCHRNUL | 
