diff options
author | Joseph Myers <joseph@codesourcery.com> | 2013-11-16 00:05:08 +0000 |
---|---|---|
committer | Joseph Myers <jsm28@gcc.gnu.org> | 2013-11-16 00:05:08 +0000 |
commit | d3f4ff8b51b8875a7862fae1fb574735db4bfd36 (patch) | |
tree | ddce12237d1c0fb641f1d74daf972657ec50caca /libcpp/lex.c | |
parent | 3d053a5f72d60cc868defb5108ac0b28bdd9ef4c (diff) | |
download | gcc-d3f4ff8b51b8875a7862fae1fb574735db4bfd36.zip gcc-d3f4ff8b51b8875a7862fae1fb574735db4bfd36.tar.gz gcc-d3f4ff8b51b8875a7862fae1fb574735db4bfd36.tar.bz2 |
ucnid-2011-1.c: New test.
gcc/testsuite:
* c-c++-common/cpp/ucnid-2011-1.c: New test.
libcpp:
* ucnid.tab: Add C11 and C11NOSTART data.
* makeucnid.c (digit): Rename enum value to N99.
(C11, N11, all_languages): New enum values.
(NUM_CODE_POINTS, MAX_CODE_POINT): New macros.
(flags, decomp, combining_value): Use NUM_CODE_POINTS as array
size.
(decomp): Use unsigned int as element type.
(all_decomp): New array.
(read_ucnid): Handle C11 and C11NOSTART. Use MAX_CODE_POINT.
(read_table): Use MAX_CODE_POINT. Store all decompositions in
all_decomp.
(read_derived): Use MAX_CODE_POINT.
(write_table): Use NUM_CODE_POINTS. Print N99, C11 and N11
flags. Print whole array variable declaration rather than just
array contents.
(char_id_valid, write_context_switch): New functions.
(main): Call write_context_switch.
* ucnid.h: Regenerate.
* include/cpplib.h (struct cpp_options): Add c11_identifiers.
* init.c (struct lang_flags): Add c11_identifiers.
(cpp_set_lang): Set c11_identifiers option from selected language.
* internal.h (struct normalize_state): Document "previous" as
previous starter character.
(NORMALIZE_STATE_UPDATE_IDNUM): Take character as argument.
* charset.c (DIG): Rename enum value to N99.
(C11, N11): New enum values.
(struct ucnrange): Give name to struct. Use short for flags and
unsigned int for end of range. Include ucnid.h for whole variable
declaration.
(ucn_valid_in_identifier): Allow for characters up to 0x10FFFF.
Allow for C11 in determining valid characters and valid start
characters. Use check_nfc for non-Hangul context-dependent
checks. Only store starter characters in nst->previous.
(_cpp_valid_ucn): Pass new argument to
NORMALIZE_STATE_UPDATE_IDNUM.
* lex.c (lex_identifier): Pass new argument to
NORMALIZE_STATE_UPDATE_IDNUM. Call NORMALIZE_STATE_UPDATE_IDNUM
after initial non-UCN part of identifier.
(lex_number): Pass new argument to NORMALIZE_STATE_UPDATE_IDNUM.
From-SVN: r204886
Diffstat (limited to 'libcpp/lex.c')
-rw-r--r-- | libcpp/lex.c | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/libcpp/lex.c b/libcpp/lex.c index 95995ed..99c2140 100644 --- a/libcpp/lex.c +++ b/libcpp/lex.c @@ -1204,11 +1204,14 @@ lex_identifier (cpp_reader *pfile, const uchar *base, bool starts_ucn, cur = pfile->buffer->cur; if (! starts_ucn) - while (ISIDNUM (*cur)) - { - hash = HT_HASHSTEP (hash, *cur); - cur++; - } + { + while (ISIDNUM (*cur)) + { + hash = HT_HASHSTEP (hash, *cur); + cur++; + } + NORMALIZE_STATE_UPDATE_IDNUM (nst, *(cur - 1)); + } pfile->buffer->cur = cur; if (starts_ucn || forms_identifier_p (pfile, false, nst)) { @@ -1216,8 +1219,8 @@ lex_identifier (cpp_reader *pfile, const uchar *base, bool starts_ucn, do { while (ISIDNUM (*pfile->buffer->cur)) { + NORMALIZE_STATE_UPDATE_IDNUM (nst, *pfile->buffer->cur); pfile->buffer->cur++; - NORMALIZE_STATE_UPDATE_IDNUM (nst); } } while (forms_identifier_p (pfile, false, nst)); result = _cpp_interpret_identifier (pfile, base, @@ -1277,8 +1280,8 @@ lex_number (cpp_reader *pfile, cpp_string *number, while (ISIDNUM (*cur) || *cur == '.' || DIGIT_SEP (*cur) || VALID_SIGN (*cur, cur[-1])) { + NORMALIZE_STATE_UPDATE_IDNUM (nst, *cur); cur++; - NORMALIZE_STATE_UPDATE_IDNUM (nst); } pfile->buffer->cur = cur; |