[Bug c++/6936] member using binds wrong

2012-01-03 Thread fabien at gcc dot gnu.org
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=6936

fabien at gcc dot gnu.org changed:

   What|Removed |Added

   Target Milestone|--- |4.7.0


[Bug c++/6936] member using binds wrong

2011-11-16 Thread fabien at gcc dot gnu.org
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=6936

fabien at gcc dot gnu.org changed:

   What|Removed |Added

 Status|ASSIGNED|RESOLVED
 Resolution||FIXED

--- Comment #5 from fabien at gcc dot gnu.org 2011-11-16 08:28:28 UTC ---
Fixed.


[Bug c++/6936] member using binds wrong

2011-11-14 Thread jason at gcc dot gnu.org
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=6936

--- Comment #4 from Jason Merrill jason at gcc dot gnu.org 2011-11-14 
17:56:01 UTC ---
Author: jason
Date: Mon Nov 14 17:55:57 2011
New Revision: 181359

URL: http://gcc.gnu.org/viewcvs?root=gccview=revrev=181359
Log:
PR c++/6936
PR c++/25994
PR c++/26256
PR c++/30195
* search.c (lookup_field_1): Look through USING_DECL.
(lookup_field_r): Call lookup_fnfields_slot instead of
lookup_fnfields_1.
* semantics.c (finish_member_declaration): Remove the check that
prevents USING_DECLs from being verified by
pushdecl_class_level. Call add_method for using declarations that
designates functions if the using declaration is in a template
class. Set DECL_IGNORED_P on class-scope using declarations.
* typeck.c (build_class_member_access_expr): Handle USING_DECLs.
* class.c (check_field_decls): Keep using declarations.
(add_method): Remove two diagnostics about conflicting using
declarations.
* parser.c (cp_parser_nonclass_name): Handle USING_DECLs.
* decl.c (start_enum): Call xref_tag whenever possible.
* cp-tree.h (strip_using_decl): Declare, and reident the previous
function.
* name-lookup.c (strip_using_decl): New function.
(supplement_binding_1): Call strip_using_decl on decl and
bval. Perform most of the checks with USING_DECLs stripped.  Also
check that the target decl and the target bval does not refer to
the same declaration. Allow pushing an enum multiple times in a
template class. Adjustment to diagnose using redeclarations. Call
diagnose_name_conflict.
(push_class_level_binding): Call strip_using_decl on decl and
bval. Perform most of the checks with USING_DECLs stripped. Return
true if both decl and bval refer to USING_DECLs and are dependent.
(diagnose_name_conflict): New function.

Added:
trunk/gcc/testsuite/g++.dg/cpp0x/forw_enum10.C
trunk/gcc/testsuite/g++.dg/debug/using4.C
trunk/gcc/testsuite/g++.dg/debug/using5.C
trunk/gcc/testsuite/g++.dg/lookup/pr6936.C
trunk/gcc/testsuite/g++.dg/lookup/using24.C
trunk/gcc/testsuite/g++.dg/lookup/using25.C
trunk/gcc/testsuite/g++.dg/lookup/using26.C
trunk/gcc/testsuite/g++.dg/lookup/using27.C
trunk/gcc/testsuite/g++.dg/lookup/using28.C
trunk/gcc/testsuite/g++.dg/lookup/using29.C
trunk/gcc/testsuite/g++.dg/lookup/using30.C
trunk/gcc/testsuite/g++.dg/lookup/using31.C
trunk/gcc/testsuite/g++.dg/lookup/using32.C
trunk/gcc/testsuite/g++.dg/lookup/using33.C
trunk/gcc/testsuite/g++.dg/lookup/using34.C
trunk/gcc/testsuite/g++.dg/lookup/using35.C
trunk/gcc/testsuite/g++.dg/lookup/using36.C
trunk/gcc/testsuite/g++.dg/lookup/using37.C
trunk/gcc/testsuite/g++.dg/lookup/using38.C
trunk/gcc/testsuite/g++.dg/lookup/using39.C
trunk/gcc/testsuite/g++.dg/lookup/using40.C
trunk/gcc/testsuite/g++.dg/lookup/using41.C
trunk/gcc/testsuite/g++.dg/lookup/using42.C
trunk/gcc/testsuite/g++.dg/lookup/using44.C
trunk/gcc/testsuite/g++.dg/lookup/using45.C
Modified:
trunk/gcc/cp/ChangeLog
trunk/gcc/cp/class.c
trunk/gcc/cp/cp-tree.h
trunk/gcc/cp/decl.c
trunk/gcc/cp/name-lookup.c
trunk/gcc/cp/parser.c
trunk/gcc/cp/search.c
trunk/gcc/cp/semantics.c
trunk/gcc/cp/typeck.c
trunk/gcc/testsuite/ChangeLog
trunk/gcc/testsuite/g++.dg/abi/mangle41.C
trunk/gcc/testsuite/g++.dg/inherit/using4.C
trunk/gcc/testsuite/g++.dg/lookup/name-clash9.C
trunk/gcc/testsuite/g++.dg/parse/ctor5.C
trunk/gcc/testsuite/g++.dg/template/static4.C
trunk/gcc/testsuite/g++.dg/template/typedef1.C
trunk/gcc/testsuite/g++.dg/template/using2.C
trunk/gcc/testsuite/g++.old-deja/g++.brendan/misc14.C
trunk/gcc/testsuite/g++.old-deja/g++.bugs/900127_02.C
trunk/gcc/testsuite/g++.old-deja/g++.jason/scoping16.C
trunk/gcc/testsuite/g++.old-deja/g++.other/anon7.C
trunk/gcc/testsuite/g++.old-deja/g++.other/redecl1.C
trunk/gcc/testsuite/g++.old-deja/g++.other/typedef7.C
trunk/gcc/testsuite/g++.old-deja/g++.other/using1.C


[Bug c++/6936] member using binds wrong

2011-10-09 Thread bangerth at gmail dot com
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=6936

Wolfgang Bangerth bangerth at gmail dot com changed:

   What|Removed |Added

 CC||bangerth at gmail dot com

--- Comment #2 from Wolfgang Bangerth bangerth at gmail dot com 2011-10-09 
13:38:29 UTC ---
Still happens with gcc4.5.1. Note that it doesn't matter which of
the variables are accessed since it's a name lookup problem and
name lookup happens before access control checking.


[Bug c++/6936] member using binds wrong

2011-10-09 Thread fabien at gcc dot gnu.org
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=6936

fabien at gcc dot gnu.org changed:

   What|Removed |Added

   Last reconfirmed|2006-09-03 21:39:27 |2011-10-09 21:39:27
  Known to fail||4.5.1, 4.6.0

--- Comment #3 from fabien at gcc dot gnu.org 2011-10-09 13:54:21 UTC ---
(In reply to comment #2)
 Still happens with gcc4.5.1. 

... And on 4.6, 4.7 as well.


[Bug c++/6936] member using binds wrong

2010-11-12 Thread fabien at gcc dot gnu.org
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=6936

fabien at gcc dot gnu.org changed:

   What|Removed |Added

 Status|NEW |ASSIGNED
 CC||fabien at gcc dot gnu.org