Skip to content
Snippets Groups Projects
  1. Oct 08, 2024
    • Jakub Jelinek's avatar
      contrib, libcpp, libstdc++: Update to Unicode 16.0 · d0e8f58b
      Jakub Jelinek authored
      It is autumn again and there is a new Unicode version 16.0.
      
      The following patch updates our Unicode stuff in contrib, libcpp and
      libstdc++ from that Unicode version.
      
      2024-10-08  Jakub Jelinek  <jakub@redhat.com>
      
      contrib/
      	* unicode/README: Update glibc git commit hash, replace
      	Unicode 15 or 15.1 versions with 16.
      	* unicode/gen_libstdcxx_unicode_data.py: Use 160000 instead of
      	150100 in _GLIBCXX_GET_UNICODE_DATA test.
      	* unicode/from_glibc/utf8_gen.py: Updated from glibc
      	064c708c78cc2a6b5802dce73108fc0c1c6bfc80 commit.
      	* unicode/DerivedCoreProperties.txt: Updated from Unicode 16.0.
      	* unicode/emoji-data.txt: Likewise.
      	* unicode/PropList.txt: Likewise.
      	* unicode/GraphemeBreakProperty.txt: Likewise.
      	* unicode/DerivedNormalizationProps.txt: Likewise.
      	* unicode/NameAliases.txt: Likewise.
      	* unicode/UnicodeData.txt: Likewise.
      	* unicode/EastAsianWidth.txt: Likewise.
      gcc/testsuite/
      	* c-c++-common/cpp/named-universal-char-escape-1.c: Add tests
      	for some Unicode 16.0 characters, both normal and generated.
      libcpp/
      	* makeucnid.cc (write_copyright): Update Unicode Copyright years.
      	* makeuname2c.cc (generated_ranges): Adjust Unicode version from 15.1
      	to 16.0.  Add EGYPTIAN HIEROGLYPH- generated range, adjust indexes in
      	following entries.
      	(write_copyright): Update Unicode Copyright years.
      	* generated_cpp_wcwidth.h: Regenerated.
      	* ucnid.h: Regenerated.
      	* uname2c.h: Regenerated.
      libstdc++-v3/
      	* include/bits/unicode.h (std::__unicode::__v15_1_0): Rename inline
      	namespace to ...
      	(std::__unicode::__v16_0_0): ... this.
      	(_GLIBCXX_GET_UNICODE_DATA): Change from 150100 to 160000.
      	* include/bits/unicode-data.h: Regenerated.
      	* testsuite/ext/unicode/properties.cc: Check for _Gcb_SpacingMark
      	on U+11F03 rather than U+1D16D as the latter lost SpacingMark property
      	in Unicode 16.0.
      d0e8f58b
  2. Jan 03, 2024
  3. Nov 14, 2023
    • Jakub Jelinek's avatar
      libcpp, contrib: Update to Unicode 15.1 · d64b7c82
      Jakub Jelinek authored
      The following patch (in plaintext just a pseudo-patch where I've left out
      the too big parts of either wget downloaded or regenerated files out with
      ..., full patch attached compressed) updates to Unicode 15.1 from 15.0
      we had last year.  Apparently Unicode forgot to add a new range to 4-8 Table
      we are using, but from the other files it is clear what should have been
      added; I've filed a bugreport against Unicode.
      
      2023-11-14  Jakub Jelinek  <jakub@redhat.com>
      
      contrib/
      	* unicode/README: Adjust glibc git commit hash, number of Unicode
      	data files to be updated and latest Unicode version.
      	* unicode/from_glibc/utf8_gen.py: Update from glibc.
      	* unicode/UnicodeData.txt: Update from Unicode 15.1.
      	* unicode/EastAsianWidth.txt: Likewise.
      	* unicode/DerivedNormalizationProps.txt: Likewise.
      	* unicode/NameAliases.txt: Likewise.
      	* unicode/DerivedCoreProperties.txt: Likewise.
      	* unicode/PropList.txt: Likewise.
      libcpp/
      	* makeucnid.cc (write_copyright): Update copyright year.
      	* makeuname2c.cc (write_copyright): Likewise.
      	(struct generated): Update latest Unicode version.
      	(generated_ranges): Add 2ebf0-2ee5d CJK UNIFIED IDEOGRAPH
      	range which was forgotten to be added to 4-8 table, but
      	clearly is expected to be there from the 15.1 additions.
      	* ucnid.h: Regenerated.
      	* uname2c.h: Regenerated.
      	* generated_cpp_wcwidth.h: Regenerated.
      d64b7c82
  4. Mar 16, 2023
    • Jakub Jelinek's avatar
      libcpp: Update Unicode copyright years · 99bae6ee
      Jakub Jelinek authored
      I've noticed I forgot to update copyright years when updating from
      Unicode 15.0.0 (and makeucnid.cc had it hopelessly obsolete).
      
      2023-03-16  Jakub Jelinek  <jakub@redhat.com>
      
      	* makeucnid.cc (write_copyright): Update Unicode copyright years
      	up to 2022.
      	* makeuname2c.cc (write_copyright): Likewise.
      	* ucnid.h: Regenerated.
      	* uname2c.h: Regenerated.
      99bae6ee
  5. Jan 16, 2023
  6. Nov 04, 2022
    • Jakub Jelinek's avatar
      libcpp: Update to Unicode 15 · 2662d537
      Jakub Jelinek authored
      The following pseudo-patch regenerates the libcpp tables with Unicode 15.0.0
      which added 4489 new characters.
      
      As mentioned previously, this isn't just a matter of running the
      two libcpp/make*.cc programs on the new Unicode files, but one needs
      to manually update a table inside of makeuname2c.cc according to
      a table in Unicode text (which is partially reflected in the text
      files, but e.g. in Unicode 14.0.0 not 100% accurately, in 15.0.0
      actually accurately).
      I've also added some randomly chosen subset of those 4489 new
      characters to a testcase.
      
      2022-11-04  Jakub Jelinek  <jakub@redhat.com>
      
      gcc/testsuite/
      	* c-c++-common/cpp/named-universal-char-escape-1.c: Add tests for some
      	characters newly added in Unicode 15.0.0.
      libcpp/
      	* makeuname2c.cc (struct generated): Update from Unicode 15.0.0
      	table 4-8.
      	* ucnid.h: Regenerated for Unicode 15.0.0.
      	* uname2c.h: Likewise.
      2662d537
  7. Jun 28, 2022
    • Lewis Hyatt's avatar
      libcpp: Update ucnid.h to Unicode 14 · 4fda776a
      Lewis Hyatt authored
      This patch updates ucnid.h from Unicode 13 to Unicode 14.  Additionally, the
      procedure detailed in contrib/unicode/README, which updates
      generated_wcwidth.h, has been expanded with instructions for updating this
      file as well, so that both may be done at the same time conveniently.  Two
      additional Unicode data files which are needed to create ucnid.h are also
      added to source control in contrib/unicode.
      
      contrib/ChangeLog:
      
      	* unicode/README: Added instructions for updating ucnid.h.
      	* unicode/DerivedCoreProperties.txt: New file added to source
      	control from Unicode 14.0 release.
      	* unicode/DerivedNormalizationProps.txt: Likewise.
      
      libcpp/ChangeLog:
      
      	* ucnid.h: Regenerated for Unicode 14.0.
      4fda776a
  8. Jan 03, 2022
  9. Sep 01, 2021
    • Jakub Jelinek's avatar
      libcpp: Implement C++23 P1949R7 - C++ Identifier Syntax using Unicode Standard Annex 31 · c4d6dcac
      Jakub Jelinek authored
      The following patch implements the
      P1949R7 - C++ Identifier Syntax using Unicode Standard Annex 31
      paper.  We already allow UTF-8 characters in the source, so that part
      is already implemented, so IMHO all we need to do is pedwarn instead of
      just warn for the (default) -Wnormalize=nfc (or for -Wnormalize={id,nkfc})
      if the character is not in NFC and to use the unicode XID_Start and
      XID_Continue derived code properties to find out what characters are allowed
      (the standard actually adds U+005F to XID_Start, but we are handling the
      ASCII compatible characters differently already and they aren't allowed
      in UCNs in identifiers).  Instead of hardcoding the large tables
      in ucnid.tab, this patch makes makeucnid.c read them from the Unicode
      tables (13.0.0 version at this point).
      
      For non-pedantic mode, we accept as 2nd+ char in identifiers a union
      of valid characters in all supported modes, but for the 1st char it
      was actually pedantically requiring that it is not any of the characters
      that may not appear in the currently chosen standard as the first character.
      This patch changes it such that also what is allowed at the start of an
      identifier is a union of characters valid at the start of an identifier
      in any of the pedantic modes.
      
      2021-09-01  Jakub Jelinek  <jakub@redhat.com>
      
      	PR c++/100977
      libcpp/
      	* include/cpplib.h (struct cpp_options): Add cxx23_identifiers.
      	* charset.c (CXX23, NXX23): New enumerators.
      	(CID, NFC, NKC, CTX): Renumber.
      	(ucn_valid_in_identifier): Implement P1949R7 - use CXX23 and
      	NXX23 flags for cxx23_identifiers.  For start character in
      	non-pedantic mode, allow characters that are allowed as start
      	characters in any of the supported language modes, rather than
      	disallowing characters allowed only as non-start characters in
      	current mode but for characters from other language modes allowing
      	them even if they are never allowed at start.
      	* init.c (struct lang_flags): Add cxx23_identifiers.
      	(lang_defaults): Add cxx23_identifiers column.
      	(cpp_set_lang): Initialize CPP_OPTION (pfile, cxx23_identifiers).
      	* lex.c (warn_about_normalization): If cxx23_identifiers, use
      	cpp_pedwarning_with_line instead of cpp_warning_with_line for
      	"is not in NFC" diagnostics.
      	* makeucnid.c: Adjust usage comment.
      	(CXX23, NXX23): New enumerators.
      	(all_languages): Add CXX23.
      	(not_NFC, not_NFKC, maybe_not_NFC): Renumber.
      	(read_derivedcore): New function.
      	(write_table): Print also CXX23 and NXX23 columns.
      	(main): Require 5 arguments instead of 4, call read_derivedcore.
      	* ucnid.h: Regenerated using Unicode 13.0.0 files.
      gcc/testsuite/
      	* g++.dg/cpp23/normalize1.C: New test.
      	* g++.dg/cpp23/normalize2.C: New test.
      	* g++.dg/cpp23/normalize3.C: New test.
      	* g++.dg/cpp23/normalize4.C: New test.
      	* g++.dg/cpp23/normalize5.C: New test.
      	* g++.dg/cpp23/normalize6.C: New test.
      	* g++.dg/cpp23/normalize7.C: New test.
      	* g++.dg/cpp23/ucnid-1-utf8.C: New test.
      	* g++.dg/cpp23/ucnid-2-utf8.C: New test.
      	* gcc.dg/cpp/ucnid-4.c: Don't expect
      	"not valid at the start of an identifier" errors.
      	* gcc.dg/cpp/ucnid-4-utf8.c: Likewise.
      	* gcc.dg/cpp/ucnid-5-utf8.c: New test.
      c4d6dcac
  10. Aug 05, 2021
    • Jakub Jelinek's avatar
      libcpp: Regenerate ucnid.h using Unicode 13.0.0 files [PR100977] · 4739344d
      Jakub Jelinek authored
      The following patch (incremental to the makeucnid.c fix) regenerates
      ucnid.h with https://www.unicode.org/Public/13.0.0/ucd/ files.
      
      2021-08-05  Jakub Jelinek  <jakub@redhat.com>
      
      	PR c++/100977
      	* ucnid.h: Regenerated using Unicode 13.0.0 files.
      4739344d
    • Jakub Jelinek's avatar
      libcpp: Fix makeucnid bug with combining values [PR100977] · 4805b92a
      Jakub Jelinek authored
      I've noticed in ucnid.h two adjacent lines that had all flags and combine
      values identical and as such were supposed to be merged.
      
      This is due to a bug in makeucnid.c, which records last_flag,
      last_combine and really_safe of what has just been printed, but
      because of a typo mishandles it for last_combine, always compares against
      the combining_value[0] which is 0.
      
      This has two effects on the table, one is that often the table is
      unnecessarily large, as for non-zero .combine every character has its own
      record instead of adjacent characters with the same flags and combine
      being merged.  This means larger tables.
      The other is that sometimes the last char that has combine set doesn't
      actually have it in the tables, because the code is printing entries only
      upon seeing the next character and if that character does have
      combining_value of 0 and flags are otherwise the same as previously printed,
      it will not print anything.
      
      The following patch fixes that, for clarity what exactly it affects
      I've regenerated with the same Unicode files as last time it has
      been regenerated.
      
      2021-08-05  Jakub Jelinek  <jakub@redhat.com>
      
      	PR c++/100977
      	* makeucnid.c (write_table): Fix computation of last_combine.
      	* ucnid.h: Regenerated using Unicode 6.3.0 files.
      4805b92a
  11. Jan 04, 2021
  12. Jan 01, 2020
  13. Jan 01, 2019
  14. Jan 03, 2018
  15. Jan 01, 2017
  16. Jan 04, 2016
  17. Jan 05, 2015
  18. Jan 02, 2014
  19. Nov 16, 2013
    • Joseph Myers's avatar
      ucnid-2011-1.c: New test. · d3f4ff8b
      Joseph Myers authored
      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
      d3f4ff8b
  20. Nov 15, 2013
    • Joseph Myers's avatar
      ucnid-9.c: New test. · 54848ff8
      Joseph Myers authored
      gcc/testsuite:
      	* gcc.dg/cpp/ucnid-9.c: New test.
      
      libcpp:
      	* ucnid.tab: Mark C99 digits as [C99DIG].
      	* makeucnid.c (read_ucnid): Handle [C99DIG].
      	(read_table): Don't check for digit characters.
      	* ucnid.h: Regenerate.
      
      From-SVN: r204835
      54848ff8
  21. Jan 14, 2013
  22. Apr 09, 2009
  23. Jun 29, 2005
  24. Mar 15, 2005
    • Geoffrey Keating's avatar
      Index: gcc/ChangeLog · 50668cf6
      Geoffrey Keating authored
      2005-03-14  Geoffrey Keating  <geoffk@apple.com>
      
      	* doc/cppopts.texi (-fexec-charset): Add concept index entry.
      	(-fwide-exec-charset): Likewise.
      	(-finput-charset): Likewise.
      	* doc/invoke.texi (Warning Options): Document -Wnormalized=.
      	* c-opts.c (c_common_handle_option): Handle -Wnormalized=.
      	* c.opt (Wnormalized): New.
      
      Index: libcpp/ChangeLog
      2005-03-14  Geoffrey Keating  <geoffk@apple.com>
      
      	* init.c (cpp_create_reader): Default warn_normalize to normalized_C.
      	* charset.c: Update for new format of ucnid.h.
      	(ucn_valid_in_identifier): Update for new format of ucnid.h.
      	Add NST parameter, and update it; update callers.
      	(cpp_valid_ucn): Add NST parameter, update callers.  Replace abort
      	with cpp_error.
      	(convert_ucn): Pass normalize_state to cpp_valid_ucn.
      	* internal.h (struct normalize_state): New.
      	(INITIAL_NORMALIZE_STATE): New.
      	(NORMALIZE_STATE_RESULT): New.
      	(NORMALIZE_STATE_UPDATE_IDNUM): New.
      	(_cpp_valid_ucn): New.
      	* lex.c (warn_about_normalization): New.
      	(forms_identifier_p): Add normalize_state parameter, update callers.
      	(lex_identifier): Add normalize_state parameter, update callers.  Keep
      	the state current.
      	(lex_number): Likewise.
      	(_cpp_lex_direct): Pass normalize_state to subroutines.  Check
      	it with warn_about_normalization.
      	* makeucnid.c: New.
      	* ucnid.h: Replace.
      	* ucnid.pl: Remove.
      	* ucnid.tab: Make appropriate for input to makeucnid.c.  Remove
      	comments about obsolete version of C++.
      	* include/cpplib.h (enum cpp_normalize_level): New.
      	(struct cpp_options): Add warn_normalize field.
      
      Index: gcc/testsuite/ChangeLog
      2005-03-14  Geoffrey Keating  <geoffk@apple.com>
      
      	* gcc.dg/cpp/normalize-1.c: New.
      	* gcc.dg/cpp/normalize-2.c: New.
      	* gcc.dg/cpp/normalize-3.c: New.
      	* gcc.dg/cpp/normalize-4.c: New.
      	* gcc.dg/cpp/ucnid-4.c: New.
      	* gcc.dg/cpp/ucnid-5.c: New.
      	* g++.dg/cpp/normalize-1.C: New.
      	* g++.dg/cpp/ucnid-1.C: New.
      
      From-SVN: r96459
      50668cf6
  25. May 24, 2004
    • Paolo Bonzini's avatar
      Makefile.def (host_modules): add libcpp. · 4f4e53dd
      Paolo Bonzini authored
      ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	* Makefile.def (host_modules): add libcpp.
      	* Makefile.tpl: Add dependencies on and for libcpp.
      	* Makefile.in: Regenerate.
      	* configure.in: Add libcpp host module.
      	* configure: Regenerate.
      
      config/ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	* acx.m4 (ACX_HEADER_STDBOOL, ACX_HEADER_STRING):
      	From gcc.
      
      gcc/ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	Move libcpp to the toplevel.
      	* Makefile.in: Remove references to libcpp files,
      	use CPPLIBS instead of libcpp.a.  Define SYMTAB_H
      	and change hashtable.h to that.
      	* aclocal.m4 (gcc_AC_HEADER_STDBOOL,
      	gcc_AC_HEADER_STRING, gcc_AC_C__BOOL): Remove.
      	* configure.ac (gcc_AC_C__BOOL, HAVE_UCHAR): Remove tests.
      	* configure: Regenerate.
      	* config.in: Regenerate.
      	* c-ppoutput.c: Include ../libcpp/internal.h instead of cpphash.h.
      	* cppcharset.c: Removed.
      	* cpperror.c: Removed.
      	* cppexp.c: Removed.
      	* cppfiles.c: Removed.
      	* cpphash.c: Removed.
      	* cpphash.h: Removed.
      	* cppinit.c: Removed.
      	* cpplex.c: Removed.
      	* cpplib.c: Removed.
      	* cpplib.h: Removed.
      	* cppmacro.c: Removed.
      	* cpppch.c: Removed.
      	* cpptrad.c: Removed.
      	* cppucnid.h: Removed.
      	* cppucnid.pl: Removed.
      	* cppucnid.tab: Removed.
      	* hashtable.c: Removed.
      	* hashtable.h: Removed.
      	* line-map.c: Removed.
      	* line-map.h: Removed.
      	* mkdeps.c: Removed.
      	* mkdeps.h: Removed.
      	* stringpool.h: Include symtab.h instead of hashtable.h.
      	* tree.h: Include symtab.h instead of hashtable.h.
      	* system.h (O_NONBLOCK, O_NOCTTY): Do not define.
      
      gcc/cp/ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	* Make-lang.in: No need to specify $(LIBCPP).
      
      gcc/java/ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	* Make-lang.in: Link in $(LIBCPP) instead of mkdeps.o.
      
      libcpp/ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	Moved libcpp from the gcc subdirectory to the toplevel.
      	* Makefile.am: New file.
      	* Makefile.in: Regenerate.
      	* configure.ac: New file.
      	* configure: Regenerate.
      	* config.in: Regenerate.
      	* charset.c: Moved from gcc/cppcharset.c.  Add note about
      	brokenness of input charset detection.  Adjust for change
      	in name of cppucnid.h.
      	* errors.c: Moved from gcc/cpperror.c.  Do not include intl.h.
      	* expr.c: Moved from gcc/cppexp.c.
      	* files.c: Moved from gcc/cppfiles.c.  Do not include intl.h.
      	Remove #define of O_BINARY, it is in system.h.
      	* identifiers.c: Moved from gcc/cpphash.c.
      	* internal.h: Moved from gcc/cpphash.h.  Change header
      	guard name.  All other files adjusted to match name change.
      	* init.c: Moved from gcc/cppinit.c.
      	(init_library) [ENABLE_NLS]: Call bindtextdomain.
      	* lex.c: Moved from gcc/cpplex.c.
      	* directives.c: Moved from gcc/cpplib.c.
      	* macro.c: Moved from gcc/cppmacro.c.
      	* pch.c: Moved from gcc/cpppch.c.  Do not include intl.h.
      	* traditional.c: Moved from gcc/cpptrad.c.
      	* ucnid.h: Moved from gcc/cppucnid.h.  Change header
      	guard name.
      	* ucnid.pl: Moved from gcc/cppucnid.pl.
      	* ucnid.tab: Moved from gcc/cppucnid.tab.  Change header
      	guard name.
      	* symtab.c: Moved from gcc/hashtable.c.
      	* line-map.c: Moved from gcc.  Do not include intl.h.
      	* mkdeps.c: Moved from gcc.
      	* system.h: New file.
      
      libcpp/include/ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	* cpplib.h: Moved from gcc.  Change header guard name.
      	* line-map.h: Moved from gcc.  Change header guard name.
      	* mkdeps.h: Moved from gcc.  Change header guard name.
      	* symtab.h: Moved from gcc/hashtable.h.  Change header
      	guard name.
      
      libcpp/po/ChangeLog:
      
      2004-05-23  Paolo Bonzini  <bonzini@gnu.org>
      
      	* be.po: Extracted from gcc/po/be.po.
      	* ca.po: Extracted from gcc/po/ca.po.
      	* da.po: Extracted from gcc/po/da.po.
      	* de.po: Extracted from gcc/po/de.po.
      	* el.po: Extracted from gcc/po/el.po.
      	* es.po: Extracted from gcc/po/es.po.
      	* fr.po: Extracted from gcc/po/fr.po.
      	* ja.po: Extracted from gcc/po/ja.po.
      	* nl.po: Extracted from gcc/po/nl.po.
      	* sv.po: Extracted from gcc/po/sv.po.
      	* tr.po: Extracted from gcc/po/tr.po.
      
      From-SVN: r82199
      4f4e53dd
  26. Jul 05, 2003
    • Zack Weinberg's avatar
      cpplib.h (CPP_AT_NAME, [...]): New token types. · e6cc3a24
      Zack Weinberg authored
      	* cpplib.h (CPP_AT_NAME, CPP_OBJC_STRING): New token types.
      	(struct cpp_options): Add narrow_charset, wide_charset,
      	bytes_big_endian fields.  Remove EBCDIC field.
      	(cpp_init_iconv, cpp_interpret_string): New external interfaces.
      
      	* cpphash.h: Include <iconv.h> if we have it, otherwise
      	provide a dummy definition of iconv_t.
      	(struct cpp_reader): Add narrow_cset_desc and wide_cset_desc fields.
      	(_cpp_valid_ucn): Update prototype.
      	(_cpp_destroy_iconv): New prototype.
      
      	* doc/cpp.texi: Document character set handling.
      	* doc/cppopts.texi: Document -fexec-charset= and -fexec-wide-charset=.
      	* doc/extend.texi: Delete entire section on multiline strings.
      	Rewrite section on __FUNCTION__ etc now that these are
      	variables in C.
      
      	* cppucnid.tab, cppucnid.pl: New files.
      	* cppucnid.h: New generated file.
      	* cppcharset.c: Include cppucnid.h.  Lots of commentary added.
      	(iconv_open, iconv, iconv_close): Provide dummy definitions
      	if !HAVE_ICONV.
      	(SOURCE_CHARSET, struct strbuf, init_iconv_desc, cpp_init_iconv,
      	_cpp_destroy_iconv, convert_cset, width_to_mask, convert_ucn,
      	emit_numeric_escape, convert_hex, convert_oct, convert_escape,
      	cpp_interpret_string, narrow_str_to_charconst,
      	wide_str_to_charconst): New.
      	(ucn_valid_in_identifier): Use a binary search through the
      	ucnranges table defined in cppucnid.h, not a long chain of if
      	statements.
      	(_cpp_valid_ucn): Add a limit pointer.  Downgrade "universal
      	character names are only valid in C++ and C99" to a warning.
      	Issue the "meaning of \[uU] is different in traditional C"
      	warning here.  Take care not to let iconv see an invalid UCS
      	value if we get a malformed UCN.  Issue an error if we don't
      	have iconv.
      	(cpp_interpret_charconst): Moved here from cpplex.c.  Use
      	cpp_interpret_string to do the heavy lifting.
      
      	* cppinit.c (cpp_create_reader): Initialize bytes_big_endian,
      	narrow_charset, wide_charset fields of options structure.
      	(cpp_destroy): Call _cpp_destroy_iconv.
      	* cpplex.c (forms_identifier_p): Adjust call to _cpp_valid_ucn.
      	(maybe_read_ucn, hex_digit_value, cpp_parse_escape): Delete.
      	(cpp_interpret_charconst): Moved to cppcharset.c.
      	* cpplib.c (dequote_string): Delete.
      	(interpret_string_notranslate): New.
      	(do_line, do_linemarker): Use interpret_string_notranslate.
      
      	* Makefile.in (cppcharset.o): Depend on cppucnid.h.
      
      	* c-common.c (fname_string, combine_strings): Delete.
      	* c-common.h (fname_string, combine_strings): Delete prototypes.
      	* c-lex.c (ignore_escape_flag): Delete.
      	(cb_ident): Use cpp_interpret_string, not lex_string.
      	(get_nonpadding_token): New function.
      	(c_lex): Handle Objective-C @-prefixed identifiers and strings here.
      	Adjust calls to lex_string.  Don't write *value twice.
      	(lex_string): Now handles string constant concatenation.
      	Most of the work handed off to cpp_interpret_string.
      	Call fix_string_type here.
      	* c-parse.in (STRING_FUNC_NAME, VAR_FUNC_NAME): Replace with
      	FUNC_NAME, throughout.
      	(OBJC_STRING): New token type.
      	(primary:STRING): No need to call fix_string_type here.
      	(primary:objc_string): Make that OBJC_STRING.
      	(objc_string nonterminal): Delete.
      	(yylexname): Delete code to handle fake string constants.
      	(yylexstring): Delete entirely.
      	(_yylex): Handle CPP_AT_NAME and CPP_OBJC_STRING.  No need
      	to handle CPP_ATSIGN.
      
      	* c.opt (-fexec-charset=, -fwide-exec-charset=): New options.
      	* c-opts.c (missing_arg, c_common_handle_option): Handle
      	OPT_fexec_charset_ and OPT_fwide_exec_charset_.
      	(c_common_init): Set cpp_opts->bytes_big_endian, not
      	cpp_opts->EBCDIC.  Call cpp_init_iconv.
      	(print_help): Document -fexec-charset= and -fexec-wide-charset=.
      	(TARGET_EBCDIC): Delete default definition.
      
      	* objc/objc-act.c (build_objc_string_object): No need to
      	handle string constant concatenation.
      
      cp:
      	* parser.c (cp_lexer_read_token): No need to handle string
      	constant concatenation.
      
      testsuite:
      	* gcc.c-torture/execute/wchar_t-1.x: New file; XFAIL wchar_t-1.c
      	everywhere.
      	* gcc.dg/concat.c: Concatenation of string constants with
      	__FUNCTION__ / __PRETTY_FUNCTION__ is now a hard error.
      	* gcc.dg/wtr-strcat-1.c: Loosen dg-warning regexp.
      	* gcc.dg/cpp/escape-2.c: Use wide character constants where
      	necessary to avoid multi-character character constant warning.
      	* gcc.dg/cpp/escape.c: Likewise.
      	* gcc.dg/cpp/ucs.c: Likewise.
      	Remove backslashes from dg-bogus comments, as they confuse Tcl.
      	Fix a typo.
      
      libstdc++-v3:
      	* testsuite/22_locale/collate/compare/wchar_t/2.cc
      	* testsuite/22_locale/collate/compare/wchar_t/wrapped_env.cc
      	* testsuite/22_locale/collate/compare/wchar_t/wrapped_locale.cc
      	* testsuite/22_locale/collate/hash/wchar_t/2.cc
      	* testsuite/22_locale/collate/hash/wchar_t/wrapped_env.cc
      	* testsuite/22_locale/collate/hash/wchar_t/wrapped_locale.cc
      	* testsuite/22_locale/collate/transform/wchar_t/2.cc
      	* testsuite/22_locale/collate/transform/wchar_t/wrapped_env.cc
      	* testsuite/22_locale/collate/transform/wchar_t/wrapped_locale.cc:
      	XFAIL on all targets.
      
      From-SVN: r68952
      e6cc3a24
Loading