diff options
Diffstat (limited to 'grp')
-rw-r--r-- | grp/Makefile | 2 | ||||
-rw-r--r-- | grp/fgetgrent.c | 36 | ||||
-rw-r--r-- | grp/getgrent.c | 2 | ||||
-rw-r--r-- | grp/getgrent_r.c | 2 | ||||
-rw-r--r-- | grp/getgrgid.c | 2 | ||||
-rw-r--r-- | grp/getgrgid_r.c | 2 | ||||
-rw-r--r-- | grp/getgrnam.c | 2 | ||||
-rw-r--r-- | grp/grp.h | 10 |
8 files changed, 18 insertions, 40 deletions
diff --git a/grp/Makefile b/grp/Makefile index 273b7d17ea..091d8ba84b 100644 --- a/grp/Makefile +++ b/grp/Makefile @@ -23,7 +23,7 @@ subdir := grp routines := fgetgrent initgroups setgroups \ getgrent getgrgid getgrnam \ - getgrent_r getgrgid_r getgrnam_r + getgrent_r getgrgid_r getgrnam_r fgetgrent_r tests := testgrp diff --git a/grp/fgetgrent.c b/grp/fgetgrent.c index 38ccd15e6f..95ae2ecd6a 100644 --- a/grp/fgetgrent.c +++ b/grp/fgetgrent.c @@ -16,25 +16,8 @@ License along with the GNU C Library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ -#include <stdio.h> #include <grp.h> - -/* Define a line parsing function using the common code - used in the nss_files module. */ - -#define STRUCTURE group -#define ENTNAME grent -struct grent_data {}; - -#define TRAILING_LIST_MEMBER gr_mem -#define TRAILING_LIST_SEPARATOR_P(c) ((c) == ',') -#include "../nss/nss_files/files-parse.c" -LINE_PARSER -(, - STRING_FIELD (result->gr_name, ISCOLON, 0); - STRING_FIELD (result->gr_passwd, ISCOLON, 0); - INT_FIELD (result->gr_gid, ISCOLON, 0, 10,); - ) +#include <stdio.h> /* Read one entry from the given stream. */ @@ -43,21 +26,6 @@ fgetgrent (FILE *stream) { static char buffer[BUFSIZ]; static struct group result; - char *p; - - do - { - p = fgets (buffer, sizeof buffer, stream); - if (p == NULL) - return NULL; - - /* Skip leading blanks. */ - while (isspace (*p)) - ++p; - } while (*p == '\0' || *p == '#' || /* Ignore empty and comment lines. */ - /* Parse the line. If it is invalid, loop to - get the next line of the file to parse. */ - ! parse_line (p, &result, (void *) buffer, sizeof buffer)); - return &result; + return __fgetgrent_r (stream, &result, buffer, sizeof buffer); } diff --git a/grp/getgrent.c b/grp/getgrent.c index 4e14bbcf17..d19e4d189b 100644 --- a/grp/getgrent.c +++ b/grp/getgrent.c @@ -25,6 +25,6 @@ Boston, MA 02111-1307, USA. */ #define GETFUNC_NAME getgrent #define ENDFUNC_NAME endgrent #define DATABASE_NAME group -#define BUFLEN 1024 +#define BUFLEN NSS_BUFLEN_GROUP #include "../nss/getXXent.c" diff --git a/grp/getgrent_r.c b/grp/getgrent_r.c index db692b20d6..1f60763ea8 100644 --- a/grp/getgrent_r.c +++ b/grp/getgrent_r.c @@ -25,6 +25,6 @@ Boston, MA 02111-1307, USA. */ #define GETFUNC_NAME getgrent #define ENDFUNC_NAME endgrent #define DATABASE_NAME group -#define BUFLEN 1024 +#define BUFLEN NSS_BUFLEN_GROUP #include "../nss/getXXent_r.c" diff --git a/grp/getgrgid.c b/grp/getgrgid.c index 855d31cbe9..b90000ba1e 100644 --- a/grp/getgrgid.c +++ b/grp/getgrgid.c @@ -25,6 +25,6 @@ Boston, MA 02111-1307, USA. */ #define DATABASE_NAME group #define ADD_PARAMS gid_t gid #define ADD_VARIABLES gid -#define BUFLEN 1024 +#define BUFLEN NSS_BUFLEN_GROUP #include "../nss/getXXbyYY.c" diff --git a/grp/getgrgid_r.c b/grp/getgrgid_r.c index 3b1719d644..6c7704dd52 100644 --- a/grp/getgrgid_r.c +++ b/grp/getgrgid_r.c @@ -25,6 +25,6 @@ Boston, MA 02111-1307, USA. */ #define DATABASE_NAME group #define ADD_PARAMS gid_t gid #define ADD_VARIABLES gid -#define BUFLEN 1024 +#define BUFLEN NSS_BUFLEN_GROUP #include "../nss/getXXbyYY_r.c" diff --git a/grp/getgrnam.c b/grp/getgrnam.c index 2104d87459..f060ea9f5f 100644 --- a/grp/getgrnam.c +++ b/grp/getgrnam.c @@ -25,6 +25,6 @@ Boston, MA 02111-1307, USA. */ #define DATABASE_NAME group #define ADD_PARAMS const char *name #define ADD_VARIABLES name -#define BUFLEN 1024 +#define BUFLEN NSS_BUFLEN_GROUP #include "../nss/getXXbyYY.c" diff --git a/grp/grp.h b/grp/grp.h index 1abe22e4e2..6a88191380 100644 --- a/grp/grp.h +++ b/grp/grp.h @@ -110,6 +110,16 @@ extern struct group *getgrnam_r __P ((__const char *__name, struct group *__resultbuf, char *buffer, int __buflen)); +#ifdef __USE_SVID +/* Read a group entry from STREAM. */ +extern struct group *__fgetgrent_r __P ((FILE * __stream, + struct group *__resultbuf, + char *buffer, int __buflen)); +extern struct group *fgetgrent_r __P ((FILE * __stream, + struct group *__resultbuf, + char *buffer, int __buflen)); +#endif + #endif /* reentrant */ |