Implement N4197 - Adding u8 character literals
libcpp: 2015-06-30 Edward Smith-Rowland <3dw4rd@verizon.net> Implement N4197 - Adding u8 character literals * include/cpplib.h (UTF8CHAR, UTF8CHAR_USERDEF): New cpp tokens; (struct cpp_options): Add utf8_char_literals. * init.c (struct lang_flags): Add utf8_char_literals; (struct lang_flags lang_defaults): Add column for utf8_char_literals. * macro.c (stringify_arg()): Treat CPP_UTF8CHAR token; * expr.c (cpp_userdef_char_remove_type(), cpp_userdef_char_add_type()): Treat CPP_UTF8CHAR_USERDEF, CPP_UTF8CHAR tokens; (cpp_userdef_char_p()): Treat CPP_UTF8CHAR_USERDEF token; (eval_token(), _cpp_parse_expr()): Treat CPP_UTF8CHAR token. * lex.c (lex_string(), _cpp_lex_direct()): Include CPP_UTF8CHAR tokens. * charset.c (converter_for_type(), cpp_interpret_charconst()): Treat CPP_UTF8CHAR token. gcc/c-family: 2015-06-30 Edward Smith-Rowland <3dw4rd@verizon.net> Implement N4197 - Adding u8 character literals * c-family/c-ada-spec.c (print_ada_macros()): Treat CPP_UTF8CHAR like CPP_CHAR. * c-family/c-common.c (c_parse_error()): print CPP_UTF8CHAR and CPP_UTF8CHAR_USERDEF tokens. * c-family/c-lex.c (c_lex_with_flags()): Treat CPP_UTF8CHAR_USERDEF and CPP_UTF8CHAR tokens; (lex_charconst()): Treat CPP_UTF8CHAR token. gcc/cp: 2015-06-30 Edward Smith-Rowland <3dw4rd@verizon.net> Implement N4197 - Adding u8 character literals * parser.c (cp_parser_primary_expression()): Treat CPP_UTF8CHAR and CPP_UTF8CHAR_USERDEF tokens; (cp_parser_parenthesized_expression_list()): Treat CPP_UTF8CHAR token. gcc/testsuite: 2015-06-30 Edward Smith-Rowland <3dw4rd@verizon.net> Implement N4197 - Adding u8 character literals * g++.dg/cpp1z/utf8.C: New. * g++.dg/cpp1z/utf8-neg.C: New. * g++.dg/cpp1z/udlit-utf8char.C: New. From-SVN: r225185
This commit is contained in:
parent
5b00d92116
commit
fe95b0366a
17 changed files with 127 additions and 26 deletions
|
@ -307,6 +307,8 @@ cpp_userdef_char_remove_type (enum cpp_ttype type)
|
|||
return CPP_CHAR16;
|
||||
else if (type == CPP_CHAR32_USERDEF)
|
||||
return CPP_CHAR32;
|
||||
else if (type == CPP_UTF8CHAR_USERDEF)
|
||||
return CPP_UTF8CHAR;
|
||||
else
|
||||
return type;
|
||||
}
|
||||
|
@ -325,6 +327,8 @@ cpp_userdef_char_add_type (enum cpp_ttype type)
|
|||
return CPP_CHAR16_USERDEF;
|
||||
else if (type == CPP_CHAR32)
|
||||
return CPP_CHAR32_USERDEF;
|
||||
else if (type == CPP_UTF8CHAR)
|
||||
return CPP_UTF8CHAR_USERDEF;
|
||||
else
|
||||
return type;
|
||||
}
|
||||
|
@ -350,7 +354,8 @@ cpp_userdef_char_p (enum cpp_ttype type)
|
|||
if (type == CPP_CHAR_USERDEF
|
||||
|| type == CPP_WCHAR_USERDEF
|
||||
|| type == CPP_CHAR16_USERDEF
|
||||
|| type == CPP_CHAR32_USERDEF)
|
||||
|| type == CPP_CHAR32_USERDEF
|
||||
|| type == CPP_UTF8CHAR_USERDEF)
|
||||
return true;
|
||||
else
|
||||
return false;
|
||||
|
@ -1029,6 +1034,7 @@ eval_token (cpp_reader *pfile, const cpp_token *token,
|
|||
case CPP_CHAR:
|
||||
case CPP_CHAR16:
|
||||
case CPP_CHAR32:
|
||||
case CPP_UTF8CHAR:
|
||||
{
|
||||
cppchar_t cc = cpp_interpret_charconst (pfile, token,
|
||||
&temp, &unsignedp);
|
||||
|
@ -1214,6 +1220,7 @@ _cpp_parse_expr (cpp_reader *pfile, bool is_if)
|
|||
case CPP_WCHAR:
|
||||
case CPP_CHAR16:
|
||||
case CPP_CHAR32:
|
||||
case CPP_UTF8CHAR:
|
||||
case CPP_NAME:
|
||||
case CPP_HASH:
|
||||
if (!want_value)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue