@@ -44,6 +44,9 @@ int __getgrent_r (struct group *__restrict group,
return ERANGE;
}
+ if (grp_fd==-1)
+ setgrent();
+
/* We use the restart label to handle malformatted lines */
restart:
/* Read the group line into the buffer for processing */
@@ -47,6 +47,9 @@ int __getpwent_r(struct passwd * passwd, char * line_buff, size_t buflen, int pw
+ if (pw_fd == -1)
+ setpwent();
/* Read the passwd line into the buffer for processing */
@@ -72,7 +72,8 @@ int getpwent_r (struct passwd *password, char *buff,
int ret=EINVAL;
LOCK;
*result = NULL;
- if (pw_fd != -1 && (ret=__getpwent_r(password, buff, buflen, pw_fd)) == 0) {
+ if ((ret=__getpwent_r(password, buff, buflen, pw_fd)) == 0) {
UNLOCK;
*result = password;
return 0;