1
0
mirror of https://github.com/git/git.git synced 2024-09-30 13:42:06 +02:00
git/compat/msvc.c
Erik Faye-Lund 17194c1e96 msvc: opendir: allocate enough memory
The defintion of DIR expects the allocating function to extend
dd_name by over-allocating. This is not currently done in our
implementation of opendir. Fix this.

Signed-off-by: Erik Faye-Lund <kusmabite@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2010-11-23 16:06:46 -08:00

35 lines
559 B
C

#include "../git-compat-util.h"
#include "win32.h"
#include <conio.h>
#include "../strbuf.h"
DIR *opendir(const char *name)
{
int len = strlen(name);
DIR *p;
p = malloc(sizeof(DIR) + len + 2);
if (!p)
return NULL;
memset(p, 0, sizeof(DIR) + len + 2);
strcpy(p->dd_name, name);
p->dd_name[len] = '/';
p->dd_name[len+1] = '*';
p->dd_handle = _findfirst(p->dd_name, &p->dd_dta);
if (p->dd_handle == -1) {
free(p);
return NULL;
}
return p;
}
int closedir(DIR *dir)
{
_findclose(dir->dd_handle);
free(dir);
return 0;
}
#include "mingw.c"