summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>1995-06-14 02:23:48 +0000
committerJim Meyering <jim@meyering.net>1995-06-14 02:23:48 +0000
commit60437a80ca57d252ac9d536ac49182fb2896b974 (patch)
treeac86a28f1aac558f0ba4539ff0e7f5291357ae3e
parent891c9b5cc793448495b453f6d575b42b35b6a494 (diff)
downloadcoreutils-60437a80ca57d252ac9d536ac49182fb2896b974.tar.xz
[NDEBUG]: Define it to disable assertions.
(is_char_class_member): Set a variable in each branch of switch stmt and return that value after the switch (rather than returning directly from every branch). (unquote): More int->size_t changes. (build_spec_list): More int->size_t changes. Be very careful about comparison now that variables are unsigned: Use i + 2 < len rather than i < len - 2. The latter failed for len < 2.
-rw-r--r--src/tr.c38
1 files changed, 21 insertions, 17 deletions
diff --git a/src/tr.c b/src/tr.c
index e783011a0..6eb7df3e3 100644
--- a/src/tr.c
+++ b/src/tr.c
@@ -23,6 +23,7 @@
#define _GNU_SOURCE
#include <stdio.h>
+#define NDEBUG 1
#include <assert.h>
#include <errno.h>
#include <sys/types.h>
@@ -407,48 +408,51 @@ is_char_class_member (char_class, c)
enum Char_class char_class;
unsigned int c;
{
+ int result;
+
switch (char_class)
{
case CC_ALNUM:
- return ISALNUM (c);
+ result = ISALNUM (c);
break;
case CC_ALPHA:
- return ISALPHA (c);
+ result = ISALPHA (c);
break;
case CC_BLANK:
- return ISBLANK (c);
+ result = ISBLANK (c);
break;
case CC_CNTRL:
- return ISCNTRL (c);
+ result = ISCNTRL (c);
break;
case CC_DIGIT:
- return ISDIGIT (c);
+ result = ISDIGIT (c);
break;
case CC_GRAPH:
- return ISGRAPH (c);
+ result = ISGRAPH (c);
break;
case CC_LOWER:
- return ISLOWER (c);
+ result = ISLOWER (c);
break;
case CC_PRINT:
- return ISPRINT (c);
+ result = ISPRINT (c);
break;
case CC_PUNCT:
- return ISPUNCT (c);
+ result = ISPUNCT (c);
break;
case CC_SPACE:
- return ISSPACE (c);
+ result = ISSPACE (c);
break;
case CC_UPPER:
- return ISUPPER (c);
+ result = ISUPPER (c);
break;
case CC_XDIGIT:
- return ISXDIGIT (c);
+ result = ISXDIGIT (c);
break;
default:
abort ();
break;
}
+ return result;
}
/* Perform the first pass over each range-spec argument S, converting all
@@ -463,9 +467,9 @@ is_char_class_member (char_class, c)
static int
unquote (s, len)
unsigned char *s;
- int *len;
+ size_t *len;
{
- int i, j;
+ size_t i, j;
j = 0;
for (i = 0; s[i]; i++)
@@ -968,11 +972,11 @@ find_bracketed_repeat (p, start_idx, p_len, char_to_repeat, n)
static int
build_spec_list (unescaped_string, len, result)
const unsigned char *unescaped_string;
- int len;
+ size_t len;
struct Spec_list *result;
{
const unsigned char *p;
- int i;
+ size_t i;
p = unescaped_string;
@@ -983,7 +987,7 @@ build_spec_list (unescaped_string, len, result)
less are composed solely of normal characters. Hence, the index of
the outer for-loop runs only as far as LEN-2. */
- for (i = 0; i < len - 2;)
+ for (i = 0; i + 2 < len;)
{
switch (p[i])
{