summaryrefslogtreecommitdiff
path: root/compat/fopen.c
diff options
context:
space:
mode:
authorBrandon Casey <casey@nrlssc.navy.mil>2008-05-07 17:34:18 (GMT)
committerJunio C Hamano <gitster@pobox.com>2008-05-09 00:43:01 (GMT)
commiteb120e699f3faea2d71cd9cb79a8cf4f79ec1d45 (patch)
tree59487237a00782097465f2e92492f84e7f82e1e7 /compat/fopen.c
parentbac59f19b12af12d59582543fbd77af3f1d06f0c (diff)
downloadgit-eb120e699f3faea2d71cd9cb79a8cf4f79ec1d45.zip
git-eb120e699f3faea2d71cd9cb79a8cf4f79ec1d45.tar.gz
git-eb120e699f3faea2d71cd9cb79a8cf4f79ec1d45.tar.bz2
compat/fopen.c: avoid clobbering the system defined fopen macro
Some systems define fopen as a macro based on compiler settings. The previous technique for reverting to the system fopen function by merely undefining fopen is inadequate in this case. Instead, avoid defining fopen entirely when compiling this source file. Signed-off-by: Brandon Casey <casey@nrlssc.navy.mil> Tested-by: Mike Ralphson <mike@abacus.co.uk> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'compat/fopen.c')
-rw-r--r--compat/fopen.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/compat/fopen.c b/compat/fopen.c
index ccb9e89..b5ca142 100644
--- a/compat/fopen.c
+++ b/compat/fopen.c
@@ -1,5 +1,16 @@
+/*
+ * The order of the following two lines is important.
+ *
+ * FREAD_READS_DIRECTORIES is undefined before including git-compat-util.h
+ * to avoid the redefinition of fopen within git-compat-util.h. This is
+ * necessary since fopen is a macro on some platforms which may be set
+ * based on compiler options. For example, on AIX fopen is set to fopen64
+ * when _LARGE_FILES is defined. The previous technique of merely undefining
+ * fopen after including git-compat-util.h is inadequate in this case.
+ */
+#undef FREAD_READS_DIRECTORIES
#include "../git-compat-util.h"
-#undef fopen
+
FILE *git_fopen(const char *path, const char *mode)
{
FILE *fp;