// PR c++/9634, c++/29469, c++/29607 // Contributed by: Giovanni Bajo // DR224: Make sure that a name is *truly* semantically dependent. struct D { typedef int K; }; template struct A { typedef int Bar; template struct N {}; typedef Bar type1; typedef A::Bar type2; typedef A::Bar type3; typedef A::Bar type4; // { dg-error "" } typedef typename A::Bar type5; typedef N type6; typedef A::N type7; typedef A::N type8; typedef A::template N type9; // { dg-error "" } typedef typename A::template N type10; typedef D Bar2; struct N2 { typedef int K; }; // Check that A::N2 is still considered dependent (because it // could be specialized), while A::Bar2 (being just ::D) is not. typedef A::Bar2 type11; typedef type11::K k3; typedef A::N2 type12; typedef typename type12::K k2; typedef type12::K k1; // { dg-error "" } // Check that A::Bar2 is not considered dependent even if we use // the typename keyword. typedef typename A::Bar2 type13; typedef type13::K k4; };