NAME
chmod -- change permissions of files.
SYNOPSIS
chmod [-R [-H | -L | -P]] mode file [files ...]
DESCRIPTION
chmod sets the permissions of files. The first argument after the options is permission the files should be given.
OPTIONS
chmod accepts the options described below. The options -L, -H and -P are mutally exclusive, and only the last given option will be honoured. All of -L, -H and -P require the -R option to be set first.
- -R
-
Recurse into directories. Any directories are recursively traversed, and all files and directories will change owner.
- -L
-
Follow symbolic links. By default, chmod will not follow symbolic links. This is a potential dangerous option, as chmod will not check for cycles. Be careful. This option requires the -R option to be set.
- -H
-
Follow symbolic links of command line files/directories only. This option requires the -R option to be set.
- -P
-
Do not follow symbolic links at all. This option requires the -R option to be set.
MODES
Modes are either absolute, or symbolic. An absolute mode is an octal number, calculated by OR-ing the following values:
- 4000
Suid on execution.
- 2000
Guid on execution.
- 1000
The sticky(8) bit is turned on.
- 0400
Read permission for the ownwer of the file.
- 0200
-
Write permission for the ownwer of the file.
- 0100
-
Execute permission for the ownwer of the file.
- 0040
-
Read permission for those in the group as the group of the file.
- 0020
-
Write permission for those in the group as the group of the file.
- 0010
-
Execute permission for those in the group as the group of the file.
- 0004
Read permission for all others.
- 0002
Write permission for all others.
- 0001
Execute permission for all others.
Symbolic mode is a comma separated list of actions. Each action has the following format:
[who] operator [permissions] [operator [permissions] ...]
who consists of zero or more of the following symbols:
- u
-
Permissions for the user (owner) of the file.
- g
-
Permissions for the group of the file.
- o
-
Permissions for all others.
- a
-
Permissions for everyone.
If who is omitted, it will default to a, but the value of your umask is taken into account. chmod will then not set a permission that is masked by your umask.
The operator is one of:
- +
-
Add permissions. If no permissions are given, this action is ignored. If who is absent, set the permission bit as indicated by permissions, but respect the umask settings. If who is given, set the permission bits as indicated by permissions, for those groups indicated by who.
- -
-
Revoke permissions. If no permissions are given, this action is ignored. If who is absent, revoke the permission bit as indicated by permissions, but respect the umask settings. If who is given, revoke the permission bits as indicated by permissions, for those groups indicated by who.
- -
-
Set permissions. The permission bits indicated by who are all cleared. If who isn't given, all permission bits are cleared. Then, if who isn't given, those permission bits in permission whose corresponding bit in the umask is clear are set. Otherwise, the permission bits are set as indicated by who and permission.
permission consists of zero or more of:
- r
-
The read permission bit.
- w
-
The write permission bit.
- x
-
The execute permission bit.
- X
-
The execute permission bit, but only if the target is either a directory, or has at least one execution bit set in the unmodified permission bits. Furthermore, this permission is ignored if operator is either - or =.
- s
-
The suid and guid bit. These will have no effect in combination with the o who setting.
- t
-
The sticky bit. This makes sense only for the others group, however, it will be ignored if o is the only group in the who part of the clause.
- u
-
The original permissions of the user.
- g
-
The original permissions of the group.
- o
-
The original permissions for others.
ENVIRONMENT
The working of chmod is not influenced by any environment variables.
BUGS
It is unlikely there are no bugs. The documentation is at best ambiguous. The OpenBSD documentation does not match the OpenBSD implementation. Furthermore, the implementations of Solaris, SunOS, HP, and GNU all differ from each other, and from OpenBSD.
This manual page needs work. The module SymbolicMode needs to be documented.
chmod parses a symbolic mode once for each file. That is too much redundant work.
chmod can loop forever when symbolic links create cycles.
chmod uses File::Find to recurse.
This manual should have been written in Texinfo, LaTeX, or a funky SGML application. pod2man, pod2html, pod2text and pod2latex are all broken beyond belief.
STANDARDS
It does not make sense to talk about standards in a chmod manual page.
REVISION HISTORY
$Log: chmod,v $
Revision 1.2 2004/08/05 14:17:43 cwest
cleanup, new version number on website
Revision 1.1 2004/07/23 20:10:01 cwest
initial import
Revision 1.3 1999/03/09 02:44:57 abigail
Fixed SybolicMode -> SymbolicMode typo.
Revision 1.2 1999/03/08 03:07:28 abigail
Major documentation tweaks.
Revision 1.1 1999/03/07 12:03:54 abigail
Initial revision
AUTHOR
The Perl implementation of chmod was written by Abigail, abigail@fnx.com.
COPYRIGHT and LICENSE
This program is copyright by Abigail 1999.
This program is free and open software. You may use, copy, modify, distribute, and sell this program (and any modified variants) in any way you wish, provided you do not restrict others from doing the same.