re PR c++/80866 (segfault in is_overloaded_fn())
authorNathan Sidwell <nathan@acm.org>
Tue, 23 May 2017 17:04:56 +0000 (17:04 +0000)
committerNathan Sidwell <nathan@gcc.gnu.org>
Tue, 23 May 2017 17:04:56 +0000 (17:04 +0000)
PR c++/80866
* parser.c (cp_parser_template_id): Keep the lookup when stashing
the template_id.

PR c++/80866
* g++.dg/parse/pr80866.C: New.

From-SVN: r248377

gcc/cp/ChangeLog
gcc/cp/parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/parse/pr80866.C [new file with mode: 0644]

index 2e2415c130e928abb682f1d2a4e2d43cf7f7aed9..254f5b7cb7217a12df645bf4033bfcc5ddbfbb59 100644 (file)
@@ -1,5 +1,9 @@
 2017-05-23  Nathan Sidwell  <nathan@acm.org>
 
+       PR c++/80866
+       * parser.c (cp_parser_template_id): Keep the lookup when stashing
+       the template_id.
+
        * cp-tree.h (DECL_HIDDEN_P): New.
        * name-lookup.c (set_decl_context,
        set_local_extern_decl_linkage): New, broken out of ...
index b39e624734b0ccb57cfcdedfa775f5090c41c2c9..71e1d166eacb1fbe8472be2fe8ad761b67f81fe1 100644 (file)
@@ -15570,6 +15570,11 @@ cp_parser_template_id (cp_parser *parser,
        = make_location (token->location, token->location, finish_loc);
       token->location = combined_loc;
 
+      /* We must mark the lookup as kept, so we don't throw it away on
+        the first parse.  */
+      if (is_overloaded_fn (template_id))
+       lookup_keep (get_fns (template_id), true);
+
       /* Retrieve any deferred checks.  Do not pop this access checks yet
         so the memory will not be reclaimed during token replacing below.  */
       token->u.tree_check_value = ggc_cleared_alloc<struct tree_check> ();
index e5d4fce0dbec662bd1965daf1e4f40594f58fe38..f536dda0fda70884fb2bd13d6727a2e8f55f2f3b 100644 (file)
@@ -1,3 +1,8 @@
+2017-05-23  Nathan Sidwell  <nathan@acm.org>
+
+       PR c++/80866
+       * g++.dg/parse/pr80866.C: New.
+
 2017-05-23  Jan Hubicka  <hubicka@ucw.cz>
 
        * gcc.dg/ipa/ctor-empty-1.c: Update template.
diff --git a/gcc/testsuite/g++.dg/parse/pr80866.C b/gcc/testsuite/g++.dg/parse/pr80866.C
new file mode 100644 (file)
index 0000000..18543ba
--- /dev/null
@@ -0,0 +1,10 @@
+// { dg-do compile { target c++11 } }
+// PR 80866 recycled a lookup too soon.
+
+void pow();
+namespace math {
+  template <typename T> void pow(T);
+}
+using namespace math;
+
+decltype(pow<>(0)) z();