У меня есть код, который прекрасно компилируется с VC9 (Microsoft Visual C ++ 2008 SP1), но не с GCC 4.2 (на Mac, если это важно). Если я соберу достаточно квалификаторов и ключевых слов, я смогу заставить их работать в GCC, но это не так.
Вот минимальный пример кода, демонстрирующий мои проблемы:
template< typename N >
struct B {
typedef N n_type; // can derived class access typedef?
void foo() {} // can derived class access function?
};
template< typename N >
struct D : public B<N> {
typedef B<N> b_type;
typedef typename b_type::n_type bn_type;
void f1( n_type ) {} // ERROR: 'n_type' has not been
// declared
void f2( typename B<N>::n_type ) {} // OK, verbose
void f3( b_type::n_type ) {} // ERROR: 'struct B<N>::n_type' is
// not a type
void f4( typename b_type::n_type ) {} // OK, verbose
void f5( bn_type ) {} // OK, verbose typedefs
void f6() { foo(); } // ERROR: there are no arguments to
// 'foo' that depend on a template
// parameter, so a declaration of
// 'foo' must be available
void f7() { b_type::foo(); } // OK, verbose
};
Неправильно ли ожидать, что шаблонный класс, производный от другого шаблонного класса, сможет напрямую использовать унаследованные определения типов и функции? Есть ли лучший способ сделать это, чем я придумал до сих пор?