NAME
pw_dup —
    make a copy of a struct
  passwd
SYNOPSIS
#include
  <pwd.h>
struct passwd *
  
  pw_dup(const
    struct passwd *pw);
DESCRIPTION
The
    pw_dup()
    function allocates sufficient memory for a copy of the struct passwd
    pw, does the copy, and returns a pointer to it. This
    is useful as subsequent calls to
    getpwent(),
    getpwnam(),
    and
    getpwuid()
    will overwrite the data they returned from previous calls.
The returned pointer should be deallocated by a
    single call to free(3). Since
    pw_dup()
    allocates space for the copy in one chunk, it is not necessary to free the
    individual strings contained in the returned struct passwd.
If insufficient memory is available, NULL
    is returned.
EXAMPLES
The following will make a copy of the struct passwd for root and store it in "pw_save":
struct passwd *pw, *pw_save;
if ((pw = getpwnam("root")) == NULL) {
	fprintf(stderr, "Cannot find root in the password file.\n");
	exit(1);
}
if ((pw_save = pw_dup(pw)) == NULL) {
	fprintf(stderr, "Out of memory.\n");
	exit(1);
}
ERRORS
pw_dup() function may fail and set the
    external variable errno for any of the errors
    specified for the library function
    malloc(3).
SEE ALSO
HISTORY
The pw_dup() function first appeared in
    OpenBSD 2.9.