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>
This commit is contained in:
parent
599b0bf438
commit
17194c1e96
@ -5,15 +5,14 @@
|
||||
|
||||
DIR *opendir(const char *name)
|
||||
{
|
||||
int len;
|
||||
int len = strlen(name);
|
||||
DIR *p;
|
||||
p = malloc(sizeof(DIR));
|
||||
p = malloc(sizeof(DIR) + len + 2);
|
||||
if (!p)
|
||||
return NULL;
|
||||
|
||||
memset(p, 0, sizeof(DIR));
|
||||
strncpy(p->dd_name, name, PATH_MAX);
|
||||
len = strlen(p->dd_name);
|
||||
memset(p, 0, sizeof(DIR) + len + 2);
|
||||
strcpy(p->dd_name, name);
|
||||
p->dd_name[len] = '/';
|
||||
p->dd_name[len+1] = '*';
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user