summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/install.c48
1 files changed, 26 insertions, 22 deletions
diff --git a/src/install.c b/src/install.c
index 675564b76..fed0ffe5c 100644
--- a/src/install.c
+++ b/src/install.c
@@ -64,9 +64,18 @@
#include "modechange.h"
#include "makepath.h"
#include "error.h"
+#include "xstrtol.h"
#if HAVE_SYS_WAIT_H
-#include <sys/wait.h>
+# include <sys/wait.h>
+#endif
+
+#if HAVE_VALUES_H
+# include <values.h>
+#endif
+
+#ifndef BITSPERBYTE
+# define BITSPERBYTE 8
#endif
struct passwd *getpwnam ();
@@ -92,6 +101,14 @@ int wait ();
/* Number of bytes of a file to copy at a time. */
#define READ_SIZE (32 * 1024)
+#ifndef UID_T_MAX
+# define UID_T_MAX ((uid_t)(~((uid_t)1 << (sizeof (uid_t) * BITSPERBYTE - 1))))
+#endif
+
+#ifndef GID_T_MAX
+# define GID_T_MAX ((gid_t)(~((gid_t)1 << (sizeof (gid_t) * BITSPERBYTE - 1))))
+#endif
+
char *basename ();
char *stpcpy ();
char *xmalloc ();
@@ -511,20 +528,6 @@ strip (char *path)
}
}
-/* Return nonzero if STR is an ASCII representation of a nonzero
- decimal integer, zero if not. */
-
-static int
-is_number (char *str)
-{
- if (*str == 0)
- return 0;
- for (; *str; str++)
- if (!ISDIGIT (*str))
- return 0;
- return 1;
-}
-
/* Initialize the user and group ownership of the files to install. */
static void
@@ -538,11 +541,11 @@ get_ids (void)
pw = getpwnam (owner_name);
if (pw == NULL)
{
- if (!is_number (owner_name))
+ long int tmp_long;
+ if (xstrtol (owner_name, NULL, 0, &tmp_long, NULL) != LONGINT_OK
+ || tmp_long < 0 || tmp_long > UID_T_MAX)
error (1, 0, _("invalid user `%s'"), owner_name);
- /* FIXME: atoi won't warn about overflow. Use xstrtoul. */
- /* FIXME: eliminate is_number altogether! */
- owner_id = atoi (owner_name);
+ owner_id = (uid_t) tmp_long;
}
else
owner_id = pw->pw_uid;
@@ -556,10 +559,11 @@ get_ids (void)
gr = getgrnam (group_name);
if (gr == NULL)
{
- if (!is_number (group_name))
+ long int tmp_long;
+ if (xstrtol (group_name, NULL, 0, &tmp_long, NULL) != LONGINT_OK
+ || tmp_long < 0 || tmp_long > (long) GID_T_MAX)
error (1, 0, _("invalid group `%s'"), group_name);
- /* FIXME: atoi won't warn about overflow. Use xstrtoul. */
- group_id = atoi (group_name);
+ group_id = (gid_t) tmp_long;
}
else
group_id = gr->gr_gid;