Update from main archive 960808
authordrepper <drepper>
Fri, 9 Aug 1996 03:05:59 +0000 (03:05 +0000)
committerdrepper <drepper>
Fri, 9 Aug 1996 03:05:59 +0000 (03:05 +0000)
grp/Makefile
grp/fgetgrent.c
grp/getgrent.c
grp/getgrent_r.c
grp/getgrgid.c
grp/getgrgid_r.c
grp/getgrnam.c
grp/grp.h

index 273b7d1..091d8ba 100644 (file)
@@ -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
 
index 38ccd15..95ae2ec 100644 (file)
@@ -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);
 }
index 4e14bbc..d19e4d1 100644 (file)
@@ -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"
index db692b2..1f60763 100644 (file)
@@ -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"
index 855d31c..b90000b 100644 (file)
@@ -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"
index 3b1719d..6c7704d 100644 (file)
@@ -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"
index 2104d87..f060ea9 100644 (file)
@@ -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"
index 1abe22e..6a88191 100644 (file)
--- 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 */