blob: 23cdb00e6debf8f9f50ed724e5c50401bbd276ee [file] [log] [blame]
// { dg-do run }
// Testcase for implicit 'typename' and resolution of 'typename's in the
// current scope.
class base1 {
public:
int bar() const
{ return 1; }
};
class base2 {
public:
int bar() const
{ return 0; }
};
template<class X>
struct base_trait {
typedef base1 base;
};
template<>
struct base_trait<float> {
typedef base2 base;
};
template<class T>
class weird : public base_trait<T>::base {
public:
typedef typename base_trait<T>::base base;
base f ();
int base::* g ();
int zowee() const
{ return this->bar(); }
};
template <class T>
typename weird<T>::base weird<T>::f ()
{
return base();
}
// The standard does not allow this case; the `typename' keyword may
// not appear in a ptr-operator.
#if 0
template <class T>
int typename weird<T>::base::* weird<T>::g ()
{ return 0; }
#endif
int main()
{
weird<float> z;
return z.zowee() || z.f().bar();
}