blob: 1babed6dac9a0a0f1da429ac6a9c7caafa53016a [file] [log] [blame]
Dmitry V. Levin38a34c92015-12-17 17:56:48 +00001/*
2 * Copyright (c) 1991, 1992 Paul Kranenburg <pk@cs.few.eur.nl>
3 * Copyright (c) 1993 Branko Lankester <branko@hacktic.nl>
4 * Copyright (c) 1993-1996 Rick Sladkey <jrs@world.std.com>
5 * Copyright (c) 1996-1999 Wichert Akkerman <wichert@cistron.nl>
6 * Copyright (c) 2012 Denys Vlasenko <vda.linux@googlemail.com>
7 * All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3. The name of the author may not be used to endorse or promote products
18 * derived from this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
21 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
22 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
23 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
24 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
29 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
Dmitry V. Levin9514ac72014-12-06 03:53:16 +000032#include "defs.h"
33
34#include <fcntl.h>
Felix Jandad34e00b2015-03-28 18:21:09 +010035#include <sys/stat.h>
Dmitry V. Levin9514ac72014-12-06 03:53:16 +000036
37#include "xlat/modetypes.h"
38
Dmitry V. Levin8d374382016-08-03 14:05:39 +000039void
40print_symbolic_mode_t(const unsigned int mode)
Dmitry V. Levin9514ac72014-12-06 03:53:16 +000041{
Dmitry V. Levin8d374382016-08-03 14:05:39 +000042 const char *ifmt;
Dmitry V. Levin9514ac72014-12-06 03:53:16 +000043
Dmitry V. Levin8d374382016-08-03 14:05:39 +000044 if (mode & S_IFMT) {
45 ifmt = xlookup(modetypes, mode & S_IFMT);
46 if (!ifmt) {
47 tprintf("%#03o", mode);
48 return;
49 }
50 } else {
51 ifmt = NULL;
Dmitry V. Levin9514ac72014-12-06 03:53:16 +000052 }
Dmitry V. Levin8d374382016-08-03 14:05:39 +000053
54 tprintf("%s%s%s%s%s%#03o",
55 ifmt ? ifmt : "",
56 ifmt ? "|" : "",
57 (mode & S_ISUID) ? "S_ISUID|" : "",
58 (mode & S_ISGID) ? "S_ISGID|" : "",
59 (mode & S_ISVTX) ? "S_ISVTX|" : "",
60 mode & ~(S_IFMT|S_ISUID|S_ISGID|S_ISVTX));
61}
62
63void
64print_numeric_umode_t(const unsigned short mode)
65{
66 tprintf("%#03ho", mode);
67}
68
69void
70print_numeric_long_umask(const unsigned long mode)
71{
72 tprintf("%#03lo", mode);
Dmitry V. Levin9514ac72014-12-06 03:53:16 +000073}