[pushed] c++: signed __int128_t [PR108099]
Checks
Commit Message
Tested x86_64-pc-linux-gnu, applying to trunk.
-- 8< --
The code for handling signed + typedef was breaking on __int128_t, because
it isn't a proper typedef: it doesn't have DECL_ORIGINAL_TYPE.
PR c++/108099
gcc/cp/ChangeLog:
* decl.cc (grokdeclarator): Handle non-typedef typedef_decl.
gcc/testsuite/ChangeLog:
* g++.dg/ext/int128-7.C: New test.
---
gcc/cp/decl.cc | 11 ++++++++---
gcc/testsuite/g++.dg/ext/int128-7.C | 4 ++++
2 files changed, 12 insertions(+), 3 deletions(-)
create mode 100644 gcc/testsuite/g++.dg/ext/int128-7.C
base-commit: 68c5d92a1390ecccb61d3600a95eeff6caf7ccdf
@@ -12440,10 +12440,15 @@ grokdeclarator (const cp_declarator *declarator,
{
if (typedef_decl)
{
- pedwarn (loc, OPT_Wpedantic, "%qs specified with %qT",
- key, type);
+ pedwarn (loc, OPT_Wpedantic, "%qs specified with %qD",
+ key, typedef_decl);
ok = !flag_pedantic_errors;
- type = DECL_ORIGINAL_TYPE (typedef_decl);
+ if (is_typedef_decl (typedef_decl))
+ type = DECL_ORIGINAL_TYPE (typedef_decl);
+ else
+ /* PR108099: __int128_t comes from c_common_nodes_and_builtins,
+ and is not built as a typedef. */
+ type = TREE_TYPE (typedef_decl);
typedef_decl = NULL_TREE;
}
else if (declspecs->decltype_p)
new file mode 100644
@@ -0,0 +1,4 @@
+// PR c++/108099
+// { dg-do compile { target { c++11 && int128 } } }
+
+using i128 = signed __int128_t; // { dg-error "specified with" }