template36.C   [plain text]


// { 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();
}