diff options
author | Hans-Peter Nilsson <hp@bitrange.com> | 2000-02-16 14:44:19 +0000 |
---|---|---|
committer | Hans-Peter Nilsson <hp@gcc.gnu.org> | 2000-02-16 14:44:19 +0000 |
commit | 88a56c2eb1cf04cb828c6c19187a8f9b672e9d26 (patch) | |
tree | f65654b8ee4287eb5ff18168ad859bb200b62378 /gcc/genoutput.c | |
parent | 1efa676d959734b3f89b174b861895b33da776e8 (diff) | |
download | gcc-88a56c2eb1cf04cb828c6c19187a8f9b672e9d26.zip gcc-88a56c2eb1cf04cb828c6c19187a8f9b672e9d26.tar.gz gcc-88a56c2eb1cf04cb828c6c19187a8f9b672e9d26.tar.bz2 |
md.texi (Simple Constraints): Add item about whitespace.
* md.texi (Simple Constraints): Add item about whitespace.
* genoutput.c (strip_whitespace): New.
(scan_operands) [MATCH_OPERAND, MATCH_SCRATCH]: Call
strip_whitespace for constraints.
Test pointer using NULL, not 0.
Co-Authored-By: Michael Meissner <meissner@cygnus.com>
From-SVN: r32008
Diffstat (limited to 'gcc/genoutput.c')
-rw-r--r-- | gcc/genoutput.c | 34 |
1 files changed, 28 insertions, 6 deletions
diff --git a/gcc/genoutput.c b/gcc/genoutput.c index ecac9c9..022d676 100644 --- a/gcc/genoutput.c +++ b/gcc/genoutput.c @@ -104,6 +104,7 @@ struct obstack *rtl_obstack = &obstack; #define obstack_chunk_free free static int n_occurrences PARAMS ((int, char *)); +static void strip_whitespace PARAMS ((char *)); /* insns in the machine description are assigned sequential code numbers that are used by insn-recog.c (produced by genrecog) to communicate @@ -439,9 +440,12 @@ scan_operands (d, part, this_address_p, this_strict_low) d->operand[opno].strict_low = this_strict_low; d->operand[opno].predicate = XSTR (part, 1); d->operand[opno].constraint = XSTR (part, 2); - if (XSTR (part, 2) != 0 && *XSTR (part, 2) != 0) - d->operand[opno].n_alternatives - = n_occurrences (',', XSTR (part, 2)) + 1; + if (XSTR (part, 2) != NULL && *XSTR (part, 2) != 0) + { + strip_whitespace (XSTR (part, 2)); + d->operand[opno].n_alternatives + = n_occurrences (',', XSTR (part, 2)) + 1; + } d->operand[opno].address_p = this_address_p; d->operand[opno].eliminable = 1; return; @@ -464,9 +468,12 @@ scan_operands (d, part, this_address_p, this_strict_low) d->operand[opno].strict_low = 0; d->operand[opno].predicate = "scratch_operand"; d->operand[opno].constraint = XSTR (part, 1); - if (XSTR (part, 1) != 0 && *XSTR (part, 1) != 0) - d->operand[opno].n_alternatives - = n_occurrences (',', XSTR (part, 1)) + 1; + if (XSTR (part, 1) != NULL && *XSTR (part, 1) != 0) + { + strip_whitespace (XSTR (part, 1)); + d->operand[opno].n_alternatives + = n_occurrences (',', XSTR (part, 1)) + 1; + } d->operand[opno].address_p = 0; d->operand[opno].eliminable = 0; return; @@ -969,3 +976,18 @@ n_occurrences (c, s) n += (*s++ == c); return n; } + +/* Remove whitespace in `s' by moving up characters until the end. */ +static void +strip_whitespace (s) + char *s; +{ + char *p = s; + int ch; + + while ((ch = *s++) != '\0') + if (! ISSPACE (ch)) + *p++ = ch; + + *p = '\0'; +} |