aboutsummaryrefslogtreecommitdiff
path: root/gcc/dwarf2out.c
diff options
context:
space:
mode:
authorPaolo Carlini <paolo.carlini@oracle.com>2014-01-29 20:54:09 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2014-01-29 20:54:09 +0000
commit1200933cccdd1bbab4758560f36809f46434294a (patch)
tree43560713e5a7f2a35f9db15893e66276d46a3fd1 /gcc/dwarf2out.c
parent7651c656858e4c80febb67e1742c0aa0d716e1a1 (diff)
downloadgcc-1200933cccdd1bbab4758560f36809f46434294a.zip
gcc-1200933cccdd1bbab4758560f36809f46434294a.tar.gz
gcc-1200933cccdd1bbab4758560f36809f46434294a.tar.bz2
re PR c++/58561 ([c++11] ICE using declaration of function with auto in return type)
2014-01-29 Paolo Carlini <paolo.carlini@oracle.com> PR c++/58561 * dwarf2out.c (is_cxx_auto): New. (is_base_type): Use it. (gen_type_die_with_usage): Likewise. /testsuite 2014-01-29 Paolo Carlini <paolo.carlini@oracle.com> PR c++/58561 * g++.dg/cpp1y/auto-fn23.C: New. From-SVN: r207282
Diffstat (limited to 'gcc/dwarf2out.c')
-rw-r--r--gcc/dwarf2out.c41
1 files changed, 26 insertions, 15 deletions
diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c
index f6efd1f..d1ca4ba 100644
--- a/gcc/dwarf2out.c
+++ b/gcc/dwarf2out.c
@@ -10219,6 +10219,23 @@ base_type_die (tree type)
return base_type_result;
}
+/* A C++ function with deduced return type can have a TEMPLATE_TYPE_PARM
+ named 'auto' in its type: return true for it, false otherwise. */
+
+static inline bool
+is_cxx_auto (tree type)
+{
+ if (is_cxx ())
+ {
+ tree name = TYPE_NAME (type);
+ if (TREE_CODE (name) == TYPE_DECL)
+ name = DECL_NAME (name);
+ if (name == get_identifier ("auto"))
+ return true;
+ }
+ return false;
+}
+
/* Given a pointer to an arbitrary ..._TYPE tree node, return nonzero if the
given input type is a Dwarf "fundamental" type. Otherwise return null. */
@@ -10252,6 +10269,8 @@ is_base_type (tree type)
return 0;
default:
+ if (is_cxx_auto (type))
+ return 0;
gcc_unreachable ();
}
@@ -19830,24 +19849,16 @@ gen_type_die_with_usage (tree type, dw_die_ref context_die,
break;
default:
- // A C++ function with deduced return type can have
- // a TEMPLATE_TYPE_PARM named 'auto' in its type.
- if (is_cxx ())
+ if (is_cxx_auto (type))
{
- tree name = TYPE_NAME (type);
- if (TREE_CODE (name) == TYPE_DECL)
- name = DECL_NAME (name);
- if (name == get_identifier ("auto"))
+ if (!auto_die)
{
- if (!auto_die)
- {
- auto_die = new_die (DW_TAG_unspecified_type,
- comp_unit_die (), NULL_TREE);
- add_name_attribute (auto_die, "auto");
- }
- equate_type_number_to_die (type, auto_die);
- break;
+ auto_die = new_die (DW_TAG_unspecified_type,
+ comp_unit_die (), NULL_TREE);
+ add_name_attribute (auto_die, "auto");
}
+ equate_type_number_to_die (type, auto_die);
+ break;
}
gcc_unreachable ();
}