Perl 5 version 32.0 documentation

chown

  • chown LIST

    Changes the owner (and group) of a list of files. The first two elements of the list must be the numeric uid and gid, in that order. A value of -1 in either position is interpreted by most systems to leave that value unchanged. Returns the number of files successfully changed.

    1. my $cnt = chown $uid, $gid, 'foo', 'bar';
    2. chown $uid, $gid, @filenames;

    On systems that support fchown(2), you may pass filehandles among the files. On systems that don't support fchown(2), passing filehandles raises an exception. Filehandles must be passed as globs or glob references to be recognized; barewords are considered filenames.

    Here's an example that looks up nonnumeric uids in the passwd file:

    1. print "User: ";
    2. chomp(my $user = <STDIN>);
    3. print "Files: ";
    4. chomp(my $pattern = <STDIN>);
    5. my ($login,$pass,$uid,$gid) = getpwnam($user)
    6. or die "$user not in passwd file";
    7. my @ary = glob($pattern); # expand filenames
    8. chown $uid, $gid, @ary;

    On most systems, you are not allowed to change the ownership of the file unless you're the superuser, although you should be able to change the group to any of your secondary groups. On insecure systems, these restrictions may be relaxed, but this is not a portable assumption. On POSIX systems, you can detect this condition this way:

    1. use POSIX qw(sysconf _PC_CHOWN_RESTRICTED);
    2. my $can_chown_giveaway = ! sysconf(_PC_CHOWN_RESTRICTED);

    Portability issues: chown in perlport.