Deal with situation where sysconf(_SC_GETPW_R_SIZE_MAX) returns -1

This commit is contained in:
Alexander Botero-Lowry 2009-11-17 11:30:39 -08:00 committed by Carl Worth
parent 12d3014d88
commit 8177dc5d40

View file

@ -80,8 +80,17 @@ get_name_from_passwd_file (void *ctx)
char *pw_buf = talloc_zero_size (ctx, pw_buf_size); char *pw_buf = talloc_zero_size (ctx, pw_buf_size);
struct passwd passwd, *ignored; struct passwd passwd, *ignored;
char *name; char *name;
int e;
if (getpwuid_r (getuid (), &passwd, pw_buf, pw_buf_size, &ignored) == 0) { if (pw_buf_size == -1) pw_buf_size = 64;
while ((e = getpwuid_r (getuid (), &passwd, pw_buf,
pw_buf_size, &ignored)) == ERANGE) {
pw_buf_size = pw_buf_size * 2;
pw_buf = talloc_zero_size(ctx, pw_buf_size);
}
if (e == 0) {
char *comma = strchr (passwd.pw_gecos, ','); char *comma = strchr (passwd.pw_gecos, ',');
if (comma) if (comma)
name = talloc_strndup (ctx, passwd.pw_gecos, name = talloc_strndup (ctx, passwd.pw_gecos,
@ -104,8 +113,16 @@ get_username_from_passwd_file (void *ctx)
char *pw_buf = talloc_zero_size (ctx, pw_buf_size); char *pw_buf = talloc_zero_size (ctx, pw_buf_size);
struct passwd passwd, *ignored; struct passwd passwd, *ignored;
char *name; char *name;
int e;
if (getpwuid_r (getuid (), &passwd, pw_buf, pw_buf_size, &ignored) == 0) if (pw_buf_size == -1) pw_buf_size = 64;
while ((e = getpwuid_r (getuid (), &passwd, pw_buf,
pw_buf_size, &ignored)) == ERANGE) {
pw_buf_size = pw_buf_size * 2;
pw_buf = talloc_zero_size(ctx, pw_buf_size);
}
if (e == 0)
name = talloc_strdup (ctx, passwd.pw_name); name = talloc_strdup (ctx, passwd.pw_name);
else else
name = talloc_strdup (ctx, ""); name = talloc_strdup (ctx, "");