summaryrefslogtreecommitdiffstats
path: root/bin
diff options
context:
space:
mode:
authortegge <tegge@FreeBSD.org>2001-09-19 20:07:47 +0000
committertegge <tegge@FreeBSD.org>2001-09-19 20:07:47 +0000
commit0c39138a0b8e8641570b8e60e24b63c5226b67dd (patch)
treecccdbf82d641da8669f0615050ea9e9865a497fe /bin
parent221fff643731890a2799e1730976fa57fbd0d9c4 (diff)
downloadFreeBSD-src-0c39138a0b8e8641570b8e60e24b63c5226b67dd.zip
FreeBSD-src-0c39138a0b8e8641570b8e60e24b63c5226b67dd.tar.gz
BASESYNTAX, DQSYNTAX, SQSYNTAX and ARISYNTAX handles negative indexes.
Allow those to be used to properly quote characters in the shell control character range.
Diffstat (limited to 'bin')
-rw-r--r--bin/sh/expand.c8
-rw-r--r--bin/sh/parser.c4
2 files changed, 6 insertions, 6 deletions
diff --git a/bin/sh/expand.c b/bin/sh/expand.c
index d82f459..f1d0d69 100644
--- a/bin/sh/expand.c
+++ b/bin/sh/expand.c
@@ -315,7 +315,7 @@ done:
goto lose;
*p = c;
while ((c = *home++) != '\0') {
- if (quotes && c >= 0 && SQSYNTAX[(int)c] == CCTL)
+ if (quotes && SQSYNTAX[(int)c] == CCTL)
STPUTC(CTLESC, expdest);
STPUTC(c, expdest);
}
@@ -478,7 +478,7 @@ expbackq(cmd, quoted, flag)
}
lastc = *p++;
if (lastc != '\0') {
- if (quotes && lastc >= 0 && syntax[(int)lastc] == CCTL)
+ if (quotes && syntax[(int)lastc] == CCTL)
STPUTC(CTLESC, dest);
STPUTC(lastc, dest);
}
@@ -694,7 +694,7 @@ again: /* jump here after setting a variable with ${var=text} */
}
else {
while (*val) {
- if (quotes && *val >= 0 &&
+ if (quotes &&
syntax[(int)*val] == CCTL)
STPUTC(CTLESC, expdest);
STPUTC(*val++, expdest);
@@ -866,7 +866,7 @@ varvalue(name, quoted, allow_split)
if (allow_split) { \
syntax = quoted? DQSYNTAX : BASESYNTAX; \
while (*p) { \
- if (*p >= 0 && syntax[(int)*p] == CCTL) \
+ if (syntax[(int)*p] == CCTL) \
STPUTC(CTLESC, expdest); \
STPUTC(*p++, expdest); \
} \
diff --git a/bin/sh/parser.c b/bin/sh/parser.c
index e1c0572..1dc5d4b 100644
--- a/bin/sh/parser.c
+++ b/bin/sh/parser.c
@@ -977,7 +977,7 @@ readtoken1(firstc, syntax, eofmark, striptabs)
c != '`' && c != '$' &&
(c != '"' || eofmark != NULL))
USTPUTC('\\', out);
- if (c >= 0 && SQSYNTAX[c] == CCTL)
+ if (SQSYNTAX[c] == CCTL)
USTPUTC(CTLESC, out);
else if (eofmark == NULL)
USTPUTC(CTLQUOTEMARK, out);
@@ -1496,7 +1496,7 @@ noexpand(text)
continue;
if (c == CTLESC)
p++;
- else if (c >= 0 && BASESYNTAX[(int)c] == CCTL)
+ else if (BASESYNTAX[(int)c] == CCTL)
return 0;
}
return 1;
OpenPOWER on IntegriCloud