From 7c8750c15d57df1cda76bc66e0a7a59bd4544f2e Mon Sep 17 00:00:00 2001 From: jason Date: Wed, 2 Sep 2009 15:48:52 +0000 Subject: * semantics.c (describable_type): Don't pretend to be in a template. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@151335 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/cp/ChangeLog | 4 +++- gcc/cp/semantics.c | 6 +----- 2 files changed, 4 insertions(+), 6 deletions(-) diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index d4745c370c6..0a351b2068d 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,4 +1,6 @@ -2009-09-01 Jason Merrill +2009-09-02 Jason Merrill + + * semantics.c (describable_type): Don't pretend to be in a template. * ptree.c (cxx_print_type) [DECLTYPE_TYPE]: Print the expression. diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 1c16b72e8d5..1e5255e8ce2 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -4543,17 +4543,13 @@ describable_type (tree expr) { tree type = NULL_TREE; - /* processing_template_decl isn't set when we're called from the mangling - code, so bump it now. */ - ++processing_template_decl; if (! type_dependent_expression_p (expr) && ! type_unknown_p (expr)) { - type = TREE_TYPE (expr); + type = unlowered_expr_type (expr); if (real_lvalue_p (expr)) type = build_reference_type (type); } - --processing_template_decl; if (type) return type; -- cgit v1.2.1