mirror of
https://github.com/git/git.git
synced 2024-09-30 13:42:06 +02:00
17194c1e96
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>
35 lines
559 B
C
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"
|