summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2001-08-12 18:28:19 +0000
committerJim Meyering <jim@meyering.net>2001-08-12 18:28:19 +0000
commit4d94665d3dd9a9b62a84dbf35aaa938ba9b3869b (patch)
tree14efef386ae171410419a0a7dce3b62007ef7e6d
parente3b1f10354fe95b8f1002a4ca9f49246c15cd39c (diff)
downloadcoreutils-4d94665d3dd9a9b62a84dbf35aaa938ba9b3869b.tar.xz
(PATH_MAX_FOR): Use pathconf via wrapper.
(NAME_MAX_FOR): Likewise. (pathconf_wrapper): New function. (validate_path): Declare length variables to be `long', not `int'. Adjust corresponding printf-style specs to use %ld.
-rw-r--r--src/pathchk.c38
1 files changed, 30 insertions, 8 deletions
diff --git a/src/pathchk.c b/src/pathchk.c
index 74241588a..bba26d5db 100644
--- a/src/pathchk.c
+++ b/src/pathchk.c
@@ -1,5 +1,5 @@
/* pathchk -- check whether pathnames are valid or portable
- Copyright (C) 1991-2000 Free Software Foundation, Inc.
+ Copyright (C) 1991-2001 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -43,6 +43,11 @@
#include <getopt.h>
#include <sys/types.h>
+#include <errno.h>
+#ifndef errno
+extern int errno;
+#endif
+
#include "system.h"
#include "error.h"
#include "long-options.h"
@@ -55,10 +60,10 @@
#ifdef _POSIX_VERSION
# ifndef PATH_MAX
-# define PATH_MAX_FOR(p) pathconf ((p), _PC_PATH_MAX)
+# define PATH_MAX_FOR(p) pathconf_wrapper ((p), _PC_PATH_MAX)
# endif /* not PATH_MAX */
# ifndef NAME_MAX
-# define NAME_MAX_FOR(p) pathconf ((p), _PC_NAME_MAX);
+# define NAME_MAX_FOR(p) pathconf_wrapper ((p), _PC_NAME_MAX);
# endif /* not NAME_MAX */
#else /* not _POSIX_VERSION */
@@ -107,6 +112,23 @@ static struct option const longopts[] =
{NULL, 0, NULL, 0}
};
+/* Distinguish between the cases when pathconf fails and when it reports there
+ is no limit (the latter is the case for PATH_MAX on the Hurd). When there
+ is no limit, return LONG_MAX. Otherwise, return pathconf's return value. */
+
+static long int
+pathconf_wrapper (const char *filename, int param)
+{
+ long int ret;
+
+ errno = 0;
+ ret = pathconf (filename, param);
+ if (ret < 0 && errno == 0)
+ return LONG_MAX;
+
+ return ret;
+}
+
void
usage (int status)
{
@@ -263,7 +285,7 @@ dir_ok (const char *path)
static int
validate_path (char *path, int portability)
{
- int path_max;
+ long int path_max;
int last_elem; /* Nonzero if checking last element of path. */
int exists IF_LINT (= 0); /* 2 if the path element exists. */
char *slash;
@@ -282,8 +304,8 @@ validate_path (char *path, int portability)
last_elem = 0;
while (1)
{
- int name_max;
- int length; /* Length of partial path being checked. */
+ long int name_max;
+ long int length; /* Length of partial path being checked. */
char *start; /* Start of path element being checked. */
/* Find the end of this element of the path.
@@ -324,7 +346,7 @@ validate_path (char *path, int portability)
name_max = _POSIX_NAME_MAX;
if (length > name_max)
{
- error (0, 0, _("name `%s' has length %d; exceeds limit of %d"),
+ error (0, 0, _("name `%s' has length %ld; exceeds limit of %ld"),
start, length, name_max);
free (parent);
return 1;
@@ -350,7 +372,7 @@ validate_path (char *path, int portability)
free (parent);
if (strlen (path) > (size_t) path_max)
{
- error (0, 0, _("path `%s' has length %d; exceeds limit of %d"),
+ error (0, 0, _("path `%s' has length %d; exceeds limit of %ld"),
path, strlen (path), path_max);
return 1;
}