diff options
author | Richard Sandiford <rsandifo@nildram.co.uk> | 2001-11-09 18:05:30 +0000 |
---|---|---|
committer | Richard Sandiford <rsandifo@nildram.co.uk> | 2001-11-09 18:05:30 +0000 |
commit | d6241b80b8c742cb1008306a701e71b842c0f1cb (patch) | |
tree | 1cd38f67421be023141450547c248e32d3905086 /opcodes/cgen-asm.c | |
parent | 81631f697ec9e09ae04bdb61881eb0b7caeba032 (diff) | |
download | gdb-d6241b80b8c742cb1008306a701e71b842c0f1cb.tar.gz |
* cgen-asm.c (cgen_parse_keyword): If the keyword is too big to
fit in the buffer, try to match the empty keyword.
Diffstat (limited to 'opcodes/cgen-asm.c')
-rw-r--r-- | opcodes/cgen-asm.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/opcodes/cgen-asm.c b/opcodes/cgen-asm.c index b664d7bc8bf..05b62bf49e1 100644 --- a/opcodes/cgen-asm.c +++ b/opcodes/cgen-asm.c @@ -229,10 +229,16 @@ cgen_parse_keyword (cd, strp, keyword_table, valuep) ++p; if (p - start >= (int) sizeof (buf)) - return _("unrecognized keyword/register name"); - - memcpy (buf, start, p - start); - buf[p - start] = 0; + { + /* All non-empty CGEN keywords can fit into BUF. The only thing + we can match here is the empty keyword. */ + buf[0] = 0; + } + else + { + memcpy (buf, start, p - start); + buf[p - start] = 0; + } ke = cgen_keyword_lookup_name (keyword_table, buf); |