diff options
author | Jim Meyering <jim@meyering.net> | 1999-04-26 13:10:11 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 1999-04-26 13:10:11 +0000 |
commit | c1e374291491a893a9cd3f00b6d6aa0ece932ec6 (patch) | |
tree | 6aa03c7c897716f31906972483dd6df73bb3c7b2 /lib | |
parent | 157b3ef61f919764963bb6cbfc4b25764bb28a4c (diff) | |
download | coreutils-c1e374291491a893a9cd3f00b6d6aa0ece932ec6.tar.xz |
(setst, ftypelet, mode_string): Use proper mode_t types and macros.
Don't assume the traditional Unix values for mode bits.
(S_IRGRP, S_IWGRP, S_IXGRP, S_IROTH, S_IWOTH, S_IXOTH): Define if not defined.
<config.h>, <sys/types.h>: Include for mode_t.
(mode_string): Now takes mode_t.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/filemode.c | 50 |
1 files changed, 32 insertions, 18 deletions
diff --git a/lib/filemode.c b/lib/filemode.c index c4fb54f09..ce089ed0c 100644 --- a/lib/filemode.c +++ b/lib/filemode.c @@ -48,6 +48,25 @@ # endif #endif +#if !S_IRGRP +# define S_IRGRP (S_IRUSR >> 3) +#endif +#if !S_IWGRP +# define S_IWGRP (S_IWUSR >> 3) +#endif +#if !S_IXGRP +# define S_IXGRP (S_IXUSR >> 3) +#endif +#if !S_IROTH +# define S_IROTH (S_IRUSR >> 6) +#endif +#if !S_IWOTH +# define S_IWOTH (S_IWUSR >> 6) +#endif +#if !S_IXOTH +# define S_IXOTH (S_IXUSR >> 6) +#endif + #ifdef STAT_MACROS_BROKEN # undef S_ISBLK # undef S_ISCHR @@ -93,22 +112,11 @@ # define S_ISDOOR(m) (((m) & S_IFMT) == S_IFDOOR) #endif -/* Look at read, write, and execute bits in BITS and set - flags in CHARS accordingly. */ - -static void -rwx (short unsigned int bits, char *chars) -{ - chars[0] = (bits & S_IRUSR) ? 'r' : '-'; - chars[1] = (bits & S_IWUSR) ? 'w' : '-'; - chars[2] = (bits & S_IXUSR) ? 'x' : '-'; -} - /* Set the 's' and 't' flags in file attributes string CHARS, according to the file mode BITS. */ static void -setst (short unsigned int bits, char *chars) +setst (mode_t bits, char *chars) { #ifdef S_ISUID if (bits & S_ISUID) @@ -157,7 +165,7 @@ setst (short unsigned int bits, char *chars) '?' for any other file type. */ static char -ftypelet (long int bits) +ftypelet (mode_t bits) { #ifdef S_ISBLK if (S_ISBLK (bits)) @@ -216,12 +224,18 @@ ftypelet (long int bits) is given as an argument. */ void -mode_string (short unsigned int mode, char *str) +mode_string (mode_t mode, char *str) { - str[0] = ftypelet ((long) mode); - rwx ((mode & 0700) << 0, &str[1]); - rwx ((mode & 0070) << 3, &str[4]); - rwx ((mode & 0007) << 6, &str[7]); + str[0] = ftypelet (mode); + str[1] = mode & S_IRUSR ? 'r' : '-'; + str[2] = mode & S_IWUSR ? 'w' : '-'; + str[3] = mode & S_IXUSR ? 'x' : '-'; + str[4] = mode & S_IRGRP ? 'r' : '-'; + str[5] = mode & S_IWGRP ? 'w' : '-'; + str[6] = mode & S_IXGRP ? 'x' : '-'; + str[7] = mode & S_IROTH ? 'r' : '-'; + str[8] = mode & S_IWOTH ? 'w' : '-'; + str[9] = mode & S_IXOTH ? 'x' : '-'; setst (mode, str); } |