OSDN Git Service

PR c++/47336
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 25 May 2011 01:08:24 +0000 (01:08 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 25 May 2011 01:08:24 +0000 (01:08 +0000)
* error.c (dump_template_bindings): Suppress access control.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-4_6-branch@174160 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/error.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/error3.C [new file with mode: 0644]

index 3e305cc..230b588 100644 (file)
@@ -1,5 +1,8 @@
 2011-05-24  Jason Merrill  <jason@redhat.com>
 
+       PR c++/47336
+       * error.c (dump_template_bindings): Suppress access control.
+
        PR c++/47544
        * pt.c (instantiate_decl): Handle =default.
 
index 28305d2..2477123 100644 (file)
@@ -312,7 +312,9 @@ dump_template_bindings (tree parms, tree args, VEC(tree,gc)* typenames)
       pp_cxx_whitespace (cxx_pp);
       pp_equal (cxx_pp);
       pp_cxx_whitespace (cxx_pp);
+      push_deferring_access_checks (dk_no_check);
       t = tsubst (t, args, tf_none, NULL_TREE);
+      pop_deferring_access_checks ();
       /* Strip typedefs.  We can't just use TFF_CHASE_TYPEDEF because
         pp_simple_type_specifier doesn't know about it.  */
       t = strip_typedefs (t);
index 82696db..9185ae5 100644 (file)
@@ -1,5 +1,7 @@
 2011-05-24  Jason Merrill  <jason@redhat.com>
 
+       * g++.dg/cpp0x/error3.C: New.
+
        * g++.dg/cpp0x/defaulted27.C: New.
 
        * g++.dg/cpp0x/decltype27.C: New.
diff --git a/gcc/testsuite/g++.dg/cpp0x/error3.C b/gcc/testsuite/g++.dg/cpp0x/error3.C
new file mode 100644 (file)
index 0000000..e7da961
--- /dev/null
@@ -0,0 +1,24 @@
+// PR c++/47336
+// { dg-options -std=c++0x }
+
+template <typename T>
+void g(T t)
+{
+  t+1;                         // { dg-error "no match" }
+}
+
+template <typename S>
+class C
+{
+  struct D {} d;
+public:
+  decltype(g(d)) h()
+  {
+    return g(d);
+  }
+};
+
+int main()
+{
+  C<int>().h();
+}