X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fpasswd%2Fgetgrent_a.c;h=7fc389d46332a9ef408d29c67d853978a5dc5082;hb=59b64ff686cef2a87e9552658b2c8d2531f87176;hp=7c63c57ba55f307f312906c72afe0fa41dfe277f;hpb=fb62ae74d0c87ff506e970bf18579cc96b16e046;p=musl diff --git a/src/passwd/getgrent_a.c b/src/passwd/getgrent_a.c index 7c63c57b..7fc389d4 100644 --- a/src/passwd/getgrent_a.c +++ b/src/passwd/getgrent_a.c @@ -1,16 +1,28 @@ #include "pwf.h" +#include -struct group *__getgrent_a(FILE *f, struct group *gr, char **line, size_t *size, char ***mem, size_t *nmem) +static unsigned atou(char **s) +{ + unsigned x; + for (x=0; **s-'0'<10U; ++*s) x=10*x+(**s-'0'); + return x; +} + +int __getgrent_a(FILE *f, struct group *gr, char **line, size_t *size, char ***mem, size_t *nmem, struct group **res) { ssize_t l; char *s, *mems; size_t i; - + int rv = 0; + int cs; + pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, &cs); for (;;) { if ((l=getline(line, size, f)) < 0) { + rv = ferror(f) ? errno : 0; free(*line); *line = 0; - return 0; + gr = 0; + goto end; } line[0][l-1] = 0; @@ -21,8 +33,8 @@ struct group *__getgrent_a(FILE *f, struct group *gr, char **line, size_t *size, *s++ = 0; gr->gr_passwd = s; if (!(s = strchr(s, ':'))) continue; - *s++ = 0; gr->gr_gid = atoi(s); - if (!(s = strchr(s, ':'))) continue; + *s++ = 0; gr->gr_gid = atou(&s); + if (*s != ':') continue; *s++ = 0; mems = s; break; @@ -33,9 +45,11 @@ struct group *__getgrent_a(FILE *f, struct group *gr, char **line, size_t *size, free(*mem); *mem = calloc(sizeof(char *), *nmem+1); if (!*mem) { + rv = errno; free(*line); *line = 0; - return 0; + gr = 0; + goto end; } if (*mems) { mem[0][0] = mems; @@ -46,5 +60,9 @@ struct group *__getgrent_a(FILE *f, struct group *gr, char **line, size_t *size, mem[0][0] = 0; } gr->gr_mem = *mem; - return gr; +end: + pthread_setcancelstate(cs, 0); + *res = gr; + if(rv) errno = rv; + return rv; }