refactor passwd file access code
[musl] / src / passwd / getpw_r.c
index 2855257..0e71e43 100644 (file)
@@ -5,7 +5,6 @@
 
 static int getpw_r(const char *name, uid_t uid, struct passwd *pw, char *buf, size_t size, struct passwd **res)
 {
-       FILE *f;
        char *line = 0;
        size_t len = 0;
        int rv = 0;
@@ -13,33 +12,20 @@ static int getpw_r(const char *name, uid_t uid, struct passwd *pw, char *buf, si
 
        pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, &cs);
 
-       f = fopen("/etc/passwd", "rbe");
-       if (!f) {
-               rv = errno;
-               goto done;
+       rv = __getpw_a(name, uid, pw, &line, &len, res);
+       if (!rv && size < len) {
+               *res = 0;
+               rv = ERANGE;
        }
-
-       *res = 0;
-       while (__getpwent_a(f, pw, &line, &len)) {
-               if (name && !strcmp(name, pw->pw_name)
-               || !name && pw->pw_uid == uid) {
-                       if (size < len) {
-                               rv = ERANGE;
-                               break;
-                       }
-                       *res = pw;
-                       memcpy(buf, line, len);
-                       FIX(name);
-                       FIX(passwd);
-                       FIX(gecos);
-                       FIX(dir);
-                       FIX(shell);
-                       break;
-               }
+       if (!rv) {
+               memcpy(buf, line, len);
+               FIX(name);
+               FIX(passwd);
+               FIX(gecos);
+               FIX(dir);
+               FIX(shell);
        }
        free(line);
-       fclose(f);
-done:
        pthread_setcancelstate(cs, 0);
        return rv;
 }