1
0

Merge branch 'stable'

Este cometimento está contido em:
Lars Hjemli 2009-11-07 18:16:50 +01:00
ascendente 59310ab102 21f67e7d82
cometimento e633ccf714

Ver ficheiro

@ -400,15 +400,16 @@ int cgit_close_filter(struct cgit_filter *filter)
*/ */
int readfile(const char *path, char **buf, size_t *size) int readfile(const char *path, char **buf, size_t *size)
{ {
int fd; int fd, e;
struct stat st; struct stat st;
fd = open(path, O_RDONLY); fd = open(path, O_RDONLY);
if (fd == -1) if (fd == -1)
return errno; return errno;
if (fstat(fd, &st)) { if (fstat(fd, &st)) {
e = errno;
close(fd); close(fd);
return errno; return e;
} }
if (!S_ISREG(st.st_mode)) { if (!S_ISREG(st.st_mode)) {
close(fd); close(fd);
@ -416,7 +417,8 @@ int readfile(const char *path, char **buf, size_t *size)
} }
*buf = xmalloc(st.st_size + 1); *buf = xmalloc(st.st_size + 1);
*size = read_in_full(fd, *buf, st.st_size); *size = read_in_full(fd, *buf, st.st_size);
e = errno;
(*buf)[*size] = '\0'; (*buf)[*size] = '\0';
close(fd); close(fd);
return (*size == st.st_size ? 0 : errno); return (*size == st.st_size ? 0 : e);
} }