]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
2005-01-11 Thorsten Kukuk <kukuk@suse.de>
authorRoland McGrath <roland@gnu.org>
Mon, 18 Jul 2005 03:08:46 +0000 (03:08 +0000)
committerRoland McGrath <roland@gnu.org>
Mon, 18 Jul 2005 03:08:46 +0000 (03:08 +0000)
[BZ #1099]
* grp/putgrent.c (putgrent): Don't write 0 as group
ID if groupname starts with + or -.
* pwd/putpwent.c (putpwent): Don't write 0 as user or
group ID if user name starts with + or -.

grp/putgrent.c
pwd/putpwent.c

index cb9b6b1f79956802ecf8c23c5977b3f4946151c1..8280b0cb2f2d8a1ca89c85a39b49da324e390d72 100644 (file)
@@ -44,8 +44,13 @@ putgrent (gr, stream)
 
   flockfile (stream);
 
-  retval = fprintf (stream, "%s:%s:%u:",
-                   gr->gr_name, _S (gr->gr_passwd), gr->gr_gid);
+  if (gr->gr_name[0] == '+' || gr->gr_name[0] == '-')
+    retval = fprintf (stream, "%s:%s::",
+                     gr->gr_name, _S (gr->gr_passwd));
+  else
+    retval = fprintf (stream, "%s:%s:%lu:",
+                     gr->gr_name, _S (gr->gr_passwd),
+                     (unsigned long int) gr->gr_gid);
   if (__builtin_expect (retval, 0) < 0)
     {
       funlockfile (stream);
index 8b7767bd4a7e12ae2f03d193eecbe1cafe2a66d8..a265719d3682a9d5ff69d86b8734645a78a3c1d8 100644 (file)
@@ -20,7 +20,7 @@
 #include <stdio.h>
 #include <pwd.h>
 
-#define _S(x)  x ? x : ""
+#define _S(x)  x ?: ""
 
 /* Write an entry to the given stream.
    This must know the format of the password file.  */
@@ -35,11 +35,21 @@ putpwent (p, stream)
       return -1;
     }
 
-  if (fprintf (stream, "%s:%s:%lu:%lu:%s:%s:%s\n",
-              p->pw_name, _S (p->pw_passwd),
-              (unsigned long int) p->pw_uid, (unsigned long int) p->pw_gid,
-              _S (p->pw_gecos), _S (p->pw_dir), _S (p->pw_shell)) < 0)
-    return -1;
-
+  if (p->pw_name[0] == '+' || p->pw_name[0] == '-')
+    {
+      if (fprintf (stream, "%s:%s:::%s:%s:%s\n",
+                  p->pw_name, _S (p->pw_passwd),
+                  _S (p->pw_gecos), _S (p->pw_dir), _S (p->pw_shell)) < 0)
+       return -1;
+    }
+  else
+    {
+      if (fprintf (stream, "%s:%s:%lu:%lu:%s:%s:%s\n",
+                  p->pw_name, _S (p->pw_passwd),
+                  (unsigned long int) p->pw_uid,
+                  (unsigned long int) p->pw_gid,
+                  _S (p->pw_gecos), _S (p->pw_dir), _S (p->pw_shell)) < 0)
+       return -1;
+    }
   return 0;
 }