Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.kernel.org/pub/scm/git/git.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/compat
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2008-02-21 03:13:19 +0300
committerJunio C Hamano <gitster@pobox.com>2008-02-21 03:13:19 +0300
commitc0284cea3149cb20e24ee5e25b475e5f8edba84f (patch)
treec00aefb7e15c7130dc795fb63e81c7a5b194f19a /compat
parent9e7bd0110b41f9bb16377e322300629f8c4d6c12 (diff)
parentcba22528fa897728ebbffb95c05037ec9a20ea7c (diff)
Merge branch 'bc/fopen'
* bc/fopen: Add compat/fopen.c which returns NULL on attempt to open directory
Diffstat (limited to 'compat')
-rw-r--r--compat/fopen.c26
1 files changed, 26 insertions, 0 deletions
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;
+}