Browse Source

mingw: do not crash on open(NULL, ...)

fetch_and_setup_pack_index() apparently pass a NULL-pointer to
parse_pack_index(), which in turn pass it to check_packed_git_idx(),
which again pass it to open(). Since open() already sets errno
correctly for the NULL-case, let's just avoid the problematic strcmp.

[PT: squashed in fix for fopen which was missed first time round]

Acked-by: Johannes Sixt <j6t@kdbg.org>
Signed-off-by: Erik Faye-Lund <kusmabite@gmail.com>
Signed-off-by: Pat Thoyts <patthoyts@users.sourceforge.net>
maint
Erik Faye-Lund 15 years ago committed by Pat Thoyts
parent
commit
1a4042096c
  1. 4
      compat/mingw.c

4
compat/mingw.c

@ -127,7 +127,7 @@ int mingw_open (const char *filename, int oflags, ...) @@ -127,7 +127,7 @@ int mingw_open (const char *filename, int oflags, ...)
mode = va_arg(args, int);
va_end(args);

if (!strcmp(filename, "/dev/null"))
if (filename && !strcmp(filename, "/dev/null"))
filename = "nul";

fd = open(filename, oflags, mode);
@ -160,7 +160,7 @@ ssize_t mingw_write(int fd, const void *buf, size_t count) @@ -160,7 +160,7 @@ ssize_t mingw_write(int fd, const void *buf, size_t count)
#undef fopen
FILE *mingw_fopen (const char *filename, const char *otype)
{
if (!strcmp(filename, "/dev/null"))
if (filename && !strcmp(filename, "/dev/null"))
filename = "nul";
return fopen(filename, otype);
}

Loading…
Cancel
Save