1 /* system-dependent definitions for coreutils
2 Copyright (C) 1989-2013 Free Software Foundation, Inc.
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 3 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
17 /* Include this file _after_ system headers if possible. */
21 /* Include <sys/types.h> before this file.
22 Note this doesn't warn if we're included
23 before all system headers. */
25 #if 2 < __GLIBC__ || ( 2 == ___GLIBC__ && 2 <= __GLIBC_MINOR__ )
26 # if ! defined _SYS_TYPES_H
27 you must include <sys/types.h> before including this file
33 /* Commonly used file permission combination. */
34 #define MODE_RW_UGO (S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH)
36 #if !defined HAVE_MKFIFO
37 # define mkfifo(name, mode) mknod (name, (mode) | S_IFIFO, 0)
41 # include <sys/param.h>
50 # define PATH_MAX 8192
53 #include "configmake.h"
58 /* Since major is a function on SVR4, we can't use 'ifndef major'. */
60 # include <sys/mkdev.h>
63 #if MAJOR_IN_SYSMACROS
64 # include <sys/sysmacros.h>
67 #ifdef major /* Might be defined in sys/types.h. */
72 # define major(dev) (((dev) >> 8) & 0xff)
73 # define minor(dev) ((dev) & 0xff)
74 # define makedev(maj, min) (((maj) << 8) | (min))
78 #if ! defined makedev && defined mkdev
79 # define makedev(maj, min) mkdev (maj, min)
85 /* Some systems don't define this; POSIX mentions it but says it is
86 obsolete. gnulib defines it, but only on native Windows systems,
87 and there only because MSVC 10 does. */
96 /* Exit statuses for programs like 'env' that exec other programs. */
99 EXIT_TIMEDOUT = 124, /* Time expired before child completed. */
100 EXIT_CANCELED = 125, /* Internal error prior to exec attempt. */
101 EXIT_CANNOT_INVOKE = 126, /* Program located, but not usable. */
102 EXIT_ENOENT = 127 /* Could not find program to exec. */
105 #include "exitfail.h"
107 /* Set exit_failure to STATUS if that's not the default already. */
109 initialize_exit_failure (int status)
111 if (status != EXIT_FAILURE)
112 exit_failure = status;
118 #ifndef _D_EXACT_NAMLEN
119 # define _D_EXACT_NAMLEN(dp) strlen ((dp)->d_name)
124 NOT_AN_INODE_NUMBER = 0
127 #ifdef D_INO_IN_DIRENT
128 # define D_INO(dp) (dp)->d_ino
130 /* Some systems don't have inodes, so fake them to avoid lots of ifdefs. */
131 # define D_INO(dp) NOT_AN_INODE_NUMBER
134 /* include here for SIZE_MAX. */
135 #include <inttypes.h>
137 /* Redirection and wildcarding when done by the utility itself.
138 Generally a noop, but used in particular for native VMS. */
139 #ifndef initialize_main
140 # define initialize_main(ac, av)
143 #include "stat-macros.h"
145 #include "timespec.h"
149 /* ISDIGIT differs from isdigit, as follows:
150 - Its arg may be any int or unsigned int; it need not be an unsigned char
152 - It's typically faster.
153 POSIX says that only '0' through '9' are digits. Prefer ISDIGIT to
154 isdigit unless it's important to use the locale's definition
155 of 'digit' even when the host does not conform to POSIX. */
156 #define ISDIGIT(c) ((unsigned int) (c) - '0' <= 9)
158 /* Convert a possibly-signed character to an unsigned character. This is
159 a bit safer than casting to unsigned char, since it catches some type
160 errors that the cast doesn't. */
161 static inline unsigned char to_uchar (char ch) { return ch; }
165 /* Take care of NLS matters. */
170 # define textdomain(Domainname) /* empty */
171 # undef bindtextdomain
172 # define bindtextdomain(Domainname, Dirname) /* empty */
175 #define _(msgid) gettext (msgid)
176 #define N_(msgid) msgid
178 /* Return a value that pluralizes the same way that N does, in all
179 languages we know of. */
180 static inline unsigned long int
181 select_plural (uintmax_t n)
183 /* Reduce by a power of ten, but keep it away from zero. The
184 gettext manual says 1000000 should be safe. */
185 enum { PLURAL_REDUCER = 1000000 };
186 return (n <= ULONG_MAX ? n : n % PLURAL_REDUCER + PLURAL_REDUCER);
189 #define STREQ(a, b) (strcmp (a, b) == 0)
190 #define STREQ_LEN(a, b, n) (strncmp (a, b, n) == 0)
191 #define STRPREFIX(a, b) (strncmp(a, b, strlen (b)) == 0)
193 /* Just like strncmp, but the second argument must be a literal string
194 and you don't specify the length; that comes from the literal. */
195 #define STRNCMP_LIT(s, literal) \
196 strncmp (s, "" literal "", sizeof (literal) - 1)
198 #if !HAVE_DECL_GETLOGIN
202 #if !HAVE_DECL_TTYNAME
206 #if !HAVE_DECL_GETEUID
210 #if !HAVE_DECL_GETPWUID
211 struct passwd *getpwuid ();
214 #if !HAVE_DECL_GETGRGID
215 struct group *getgrgid ();
218 /* Interix has replacements for getgr{gid,nam,ent}, that don't
219 query the domain controller for group members when not required.
220 This speeds up the calls tremendously (<1 ms vs. >3 s). */
221 /* To protect any system that could provide _nomembers functions
222 other than interix, check for HAVE_SETGROUPS, as interix is
223 one of the very few (the only?) platform that lacks it */
225 # if HAVE_GETGRGID_NOMEMBERS
226 # define getgrgid(gid) getgrgid_nomembers(gid)
228 # if HAVE_GETGRNAM_NOMEMBERS
229 # define getgrnam(nam) getgrnam_nomembers(nam)
231 # if HAVE_GETGRENT_NOMEMBERS
232 # define getgrent() getgrent_nomembers()
236 #if !HAVE_DECL_GETUID
243 /* This is simply a shorthand for the common case in which
244 the third argument to x2nrealloc would be 'sizeof *(P)'.
245 Ensure that sizeof *(P) is *not* 1. In that case, it'd be
246 better to use X2REALLOC, although not strictly necessary. */
247 #define X2NREALLOC(P, PN) ((void) verify_true (sizeof *(P) != 1), \
248 x2nrealloc (P, PN, sizeof *(P)))
250 /* Using x2realloc (when appropriate) usually makes your code more
251 readable than using x2nrealloc, but it also makes it so your
252 code will malfunction if sizeof *(P) ever becomes 2 or greater.
253 So use this macro instead of using x2realloc directly. */
254 #define X2REALLOC(P, PN) ((void) verify_true (sizeof *(P) == 1), \
257 #include "unlocked-io.h"
258 #include "same-inode.h"
264 dot_or_dotdot (char const *file_name)
266 if (file_name[0] == '.')
268 char sep = file_name[(file_name[1] == '.') + 1];
269 return (! sep || ISSLASH (sep));
275 /* A wrapper for readdir so that callers don't see entries for '.' or '..'. */
276 static inline struct dirent const *
277 readdir_ignoring_dot_and_dotdot (DIR *dirp)
281 struct dirent const *dp = readdir (dirp);
282 if (dp == NULL || ! dot_or_dotdot (dp->d_name))
287 /* Return true if DIR is determined to be an empty directory. */
289 is_empty_dir (int fd_cwd, char const *dir)
292 struct dirent const *dp;
294 int fd = openat (fd_cwd, dir,
295 (O_RDONLY | O_DIRECTORY
296 | O_NOCTTY | O_NOFOLLOW | O_NONBLOCK));
301 dirp = fdopendir (fd);
309 dp = readdir_ignoring_dot_and_dotdot (dirp);
314 return saved_errno == 0 ? true : false;
317 /* Factor out some of the common --help and --version processing code. */
319 /* These enum values cannot possibly conflict with the option values
320 ordinarily used by commands, including CHAR_MAX + 1, etc. Avoid
321 CHAR_MIN - 1, as it may equal -1, the getopt end-of-options value. */
324 GETOPT_HELP_CHAR = (CHAR_MIN - 2),
325 GETOPT_VERSION_CHAR = (CHAR_MIN - 3)
328 #define GETOPT_HELP_OPTION_DECL \
329 "help", no_argument, NULL, GETOPT_HELP_CHAR
330 #define GETOPT_VERSION_OPTION_DECL \
331 "version", no_argument, NULL, GETOPT_VERSION_CHAR
332 #define GETOPT_SELINUX_CONTEXT_OPTION_DECL \
333 "context", required_argument, NULL, 'Z'
335 #define case_GETOPT_HELP_CHAR \
336 case GETOPT_HELP_CHAR: \
337 usage (EXIT_SUCCESS); \
340 /* Program_name must be a literal string.
341 Usually it is just PROGRAM_NAME. */
342 #define USAGE_BUILTIN_WARNING \
344 "NOTE: your shell may have its own version of %s, which usually supersedes\n" \
345 "the version described here. Please refer to your shell's documentation\n" \
346 "for details about the options it supports.\n")
348 #define HELP_OPTION_DESCRIPTION \
349 _(" --help display this help and exit\n")
350 #define VERSION_OPTION_DESCRIPTION \
351 _(" --version output version information and exit\n")
354 #include "closeout.h"
356 #define emit_bug_reporting_address unused__emit_bug_reporting_address
357 #include "version-etc.h"
358 #undef emit_bug_reporting_address
360 #include "propername.h"
361 /* Define away proper_name (leaving proper_name_utf8, which affects far
362 fewer programs), since it's not worth the cost of adding ~17KB to
363 the x86_64 text size of every single program. This avoids a 40%
364 (almost ~2MB) increase in the on-disk space utilization for the set
365 of the 100 binaries. */
366 #define proper_name(x) (x)
368 #include "progname.h"
370 #define case_GETOPT_VERSION_CHAR(Program_name, Authors) \
371 case GETOPT_VERSION_CHAR: \
372 version_etc (stdout, Program_name, PACKAGE_NAME, Version, Authors, \
374 exit (EXIT_SUCCESS); \
378 # define MAX(a, b) ((a) > (b) ? (a) : (b))
382 # define MIN(a,b) (((a) < (b)) ? (a) : (b))
385 #include "intprops.h"
388 # define SSIZE_MAX TYPE_MAXIMUM (ssize_t)
392 # define OFF_T_MIN TYPE_MINIMUM (off_t)
396 # define OFF_T_MAX TYPE_MAXIMUM (off_t)
400 # define UID_T_MAX TYPE_MAXIMUM (uid_t)
404 # define GID_T_MAX TYPE_MAXIMUM (gid_t)
408 # define PID_T_MAX TYPE_MAXIMUM (pid_t)
411 /* Use this to suppress gcc's '...may be used before initialized' warnings. */
413 # define IF_LINT(Code) Code
415 # define IF_LINT(Code) /* empty */
418 #ifndef __attribute__
419 # if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 8)
420 # define __attribute__(x) /* empty */
424 #ifndef ATTRIBUTE_NORETURN
425 # define ATTRIBUTE_NORETURN __attribute__ ((__noreturn__))
428 #ifndef ATTRIBUTE_UNUSED
429 # define ATTRIBUTE_UNUSED __attribute__ ((__unused__))
432 /* The warn_unused_result attribute appeared first in gcc-3.4.0 */
433 #undef ATTRIBUTE_WARN_UNUSED_RESULT
434 #if __GNUC__ < 3 || (__GNUC__ == 3 && __GNUC_MINOR__ < 4)
435 # define ATTRIBUTE_WARN_UNUSED_RESULT /* empty */
437 # define ATTRIBUTE_WARN_UNUSED_RESULT __attribute__ ((__warn_unused_result__))
441 # define ASSIGN_STRDUPA(DEST, S) \
442 do { DEST = strdupa (S); } while (0)
444 # define ASSIGN_STRDUPA(DEST, S) \
447 const char *s_ = (S); \
448 size_t len_ = strlen (s_) + 1; \
449 char *tmp_dest_ = alloca (len_); \
450 DEST = memcpy (tmp_dest_, s_, len_); \
456 # define sync() /* empty */
459 /* Compute the greatest common divisor of U and V using Euclid's
460 algorithm. U and V must be nonzero. */
462 static inline size_t _GL_ATTRIBUTE_CONST
463 gcd (size_t u, size_t v)
476 /* Compute the least common multiple of U and V. U and V must be
477 nonzero. There is no overflow checking, so callers should not
478 specify outlandish sizes. */
480 static inline size_t _GL_ATTRIBUTE_CONST
481 lcm (size_t u, size_t v)
483 return u * (v / gcd (u, v));
486 /* Return PTR, aligned upward to the next multiple of ALIGNMENT.
487 ALIGNMENT must be nonzero. The caller must arrange for ((char *)
488 PTR) through ((char *) PTR + ALIGNMENT - 1) to be addressable
492 ptr_align (void const *ptr, size_t alignment)
494 char const *p0 = ptr;
495 char const *p1 = p0 + alignment - 1;
496 return (void *) (p1 - (size_t) p1 % alignment);
499 /* Return whether the buffer consists entirely of NULs.
500 Note the word after the buffer must be non NUL. */
502 static inline bool _GL_ATTRIBUTE_PURE
503 is_nul (const char *buf, size_t bufsize)
505 typedef uintptr_t word;
507 /* Find first nonzero *word*, or the word with the sentinel. */
508 word *wp = (word *) buf;
512 /* Find the first nonzero *byte*, or the sentinel. */
513 char *cp = (char *) (wp - 1);
517 return cp > buf + bufsize;
520 /* If 10*Accum + Digit_val is larger than the maximum value for Type,
521 then don't update Accum and return false to indicate it would
522 overflow. Otherwise, set Accum to that new value and return true.
523 Verify at compile-time that Type is Accum's type, and that Type is
524 unsigned. Accum must be an object, so that we can take its
525 address. Accum and Digit_val may be evaluated multiple times.
527 The "Added check" below is not strictly required, but it causes GCC
528 to return a nonzero exit status instead of merely a warning
529 diagnostic, and that is more useful. */
531 #define DECIMAL_DIGIT_ACCUMULATE(Accum, Digit_val, Type) \
533 (void) (&(Accum) == (Type *) NULL), /* The type matches. */ \
534 (void) verify_true (! TYPE_SIGNED (Type)), /* The type is unsigned. */ \
535 (void) verify_true (sizeof (Accum) == sizeof (Type)), /* Added check. */ \
536 (((Type) -1 / 10 < (Accum) \
537 || (Type) ((Accum) * 10 + (Digit_val)) < (Accum)) \
538 ? false : (((Accum) = (Accum) * 10 + (Digit_val)), true)) \
542 emit_mandatory_arg_note (void)
545 Mandatory arguments to long options are mandatory for short options too.\n\
550 emit_size_note (void)
553 SIZE is an integer and optional unit (example: 10M is 10*1024*1024). Units\n\
554 are K, M, G, T, P, E, Z, Y (powers of 1024) or KB, MB, ... (powers of 1000).\n\
559 emit_blocksize_note (char const *program)
562 Display values are in units of the first available SIZE from --block-size,\n\
563 and the %s_BLOCK_SIZE, BLOCK_SIZE and BLOCKSIZE environment variables.\n\
564 Otherwise, units default to 1024 bytes (or 512 if POSIXLY_CORRECT is set).\n\
569 emit_ancillary_info (void)
571 printf (_("\nReport %s bugs to %s\n"), last_component (program_name),
573 printf (_("%s home page: <%s>\n"), PACKAGE_NAME, PACKAGE_URL);
574 fputs (_("General help using GNU software: <http://www.gnu.org/gethelp/>\n"),
576 /* Don't output this redundant message for English locales.
577 Note we still output for 'C' so that it gets included in the man page. */
578 const char *lc_messages = setlocale (LC_MESSAGES, NULL);
579 if (lc_messages && STRNCMP_LIT (lc_messages, "en_"))
581 /* TRANSLATORS: Replace LANG_CODE in this URL with your language code
582 <http://translationproject.org/team/LANG_CODE.html> to form one of
583 the URLs at http://translationproject.org/team/. Otherwise, replace
584 the entire URL with your translation team's email address. */
585 printf (_("Report %s translation bugs to "
586 "<http://translationproject.org/team/>\n"),
587 last_component (program_name));
589 printf (_("For complete documentation, run: "
590 "info coreutils '%s invocation'\n"), last_component (program_name));
596 fprintf (stderr, _("Try '%s --help' for more information.\n"), program_name);
599 #include "inttostr.h"
602 timetostr (time_t t, char *buf)
604 return (TYPE_SIGNED (time_t)
606 : umaxtostr (t, buf));
610 bad_cast (char const *s)
615 /* Return a boolean indicating whether SB->st_size is defined. */
617 usable_st_size (struct stat const *sb)
619 return (S_ISREG (sb->st_mode) || S_ISLNK (sb->st_mode)
620 || S_TYPEISSHM (sb) || S_TYPEISTMO (sb));
623 void usage (int status) ATTRIBUTE_NORETURN;
625 #define emit_cycle_warning(file_name) \
629 WARNING: Circular directory structure.\n\
630 This almost certainly means that you have a corrupted file system.\n\
631 NOTIFY YOUR SYSTEM MANAGER.\n\
632 The following directory is part of the cycle:\n %s\n"), \
633 quote (file_name)); \
637 /* Like stpncpy, but do ensure that the result is NUL-terminated,
638 and do not NUL-pad out to LEN. I.e., when strnlen (src, len) == len,
639 this function writes a NUL byte into dest[len]. Thus, the length
640 of the destination buffer must be at least LEN + 1.
641 The DEST and SRC buffers must not overlap. */
643 stzncpy (char *restrict dest, char const *restrict src, size_t len)
645 char const *src_end = src + len;
646 while (src < src_end && *src)
652 #ifndef ARRAY_CARDINALITY
653 # define ARRAY_CARDINALITY(Array) (sizeof (Array) / sizeof *(Array))