summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2001-11-28 06:57:02 +0000
committerJim Meyering <jim@meyering.net>2001-11-28 06:57:02 +0000
commit0dc8754559288ca4db87ddcc97d09c48b0b43377 (patch)
treedf4d9b23a0de4cef7c04fb019e3a2614f7fa2758
parentfb66999103891a599d808c7eb155eff55c480967 (diff)
downloadcoreutils-0dc8754559288ca4db87ddcc97d09c48b0b43377.tar.xz
(quotearg_n, quotearg_n_style): Likewise.
(SIZE_MAX, UINT_MAX): New macros. (quotearg_n_options): Abort if N is negative. Avoid overflow check on hosts where size_t is 64 bits and int is 32 bits, as overflow is impossible there. Fix off-by-one typo that caused unnecessary reallocation.
-rw-r--r--lib/quotearg.c33
1 files changed, 23 insertions, 10 deletions
diff --git a/lib/quotearg.c b/lib/quotearg.c
index 9d4395977..bd053eeca 100644
--- a/lib/quotearg.c
+++ b/lib/quotearg.c
@@ -44,9 +44,15 @@
#ifndef CHAR_BIT
# define CHAR_BIT 8
#endif
+#ifndef SIZE_MAX
+# define SIZE_MAX ((size_t) -1)
+#endif
#ifndef UCHAR_MAX
# define UCHAR_MAX ((unsigned char) -1)
#endif
+#ifndef UINT_MAX
+# define UINT_MAX ((unsigned int) -1)
+#endif
#if HAVE_C_BACKSLASH_A
# define ALERT_CHAR '\a'
@@ -535,6 +541,7 @@ quotearg_n_options (int n, char const *arg,
one small component of a "memory exhausted" message in slot 0. */
static char slot0[256];
static unsigned int nslots = 1;
+ unsigned int n0 = n;
struct slotvec
{
size_t size;
@@ -543,20 +550,26 @@ quotearg_n_options (int n, char const *arg,
static struct slotvec slotvec0 = {sizeof slot0, slot0};
static struct slotvec *slotvec = &slotvec0;
- if (nslots <= n)
+ if (n < 0)
+ abort ();
+
+ if (nslots <= n0)
{
- int n1 = n + 1;
- size_t s = n1 * sizeof (struct slotvec);
- if (! (0 < n1 && n1 == s / sizeof (struct slotvec)))
- abort ();
+ unsigned int n1 = n0 + 1;
+ size_t s = n1 * sizeof *slotvec;
+
+ if (SIZE_MAX / UINT_MAX <= sizeof *slotvec
+ && n1 != s / sizeof *slotvec)
+ xalloc_die ();
+
if (slotvec == &slotvec0)
{
- slotvec = (struct slotvec *) xmalloc (sizeof (struct slotvec));
+ slotvec = (struct slotvec *) xmalloc (sizeof *slotvec);
*slotvec = slotvec0;
}
slotvec = (struct slotvec *) xrealloc (slotvec, s);
- memset (slotvec + nslots, 0, (n1 - nslots) * sizeof (struct slotvec));
- nslots = n;
+ memset (slotvec + nslots, 0, (n1 - nslots) * sizeof *slotvec);
+ nslots = n1;
}
{
@@ -576,7 +589,7 @@ quotearg_n_options (int n, char const *arg,
}
char *
-quotearg_n (unsigned int n, char const *arg)
+quotearg_n (int n, char const *arg)
{
return quotearg_n_options (n, arg, &default_quoting_options);
}
@@ -588,7 +601,7 @@ quotearg (char const *arg)
}
char *
-quotearg_n_style (unsigned int n, enum quoting_style s, char const *arg)
+quotearg_n_style (int n, enum quoting_style s, char const *arg)
{
struct quoting_options o;
o.style = s;