С++ 0x decltype и оператор разрешения области

С таким классом, как Foo:

struct Foo { static const int i = 9; };

Я обнаружил, что GCC 4.5 отклонит следующие

Foo f;
int x = decltype(f)::i;

Он будет работать, если я использую промежуточный typedef, например:

typedef decltype(f) ftype;
int x = ftype::i;

но я предпочитаю, чтобы пространство имен было чистым. Я думал, что приоритет может быть проблемой, поэтому я также пробовал скобки, но не повезло. Это невозможно, как представлено, или есть ли синтаксис, который может мне помочь?

Ответы

Ответ 1

Действительно, С++ 0x говорит decltype(f)::i. GCC только этого пока не поддерживает. Вы можете работать с шаблоном идентификации

template<typename T> struct identity { typedef T type; };
int x = identity<decltype(f)>::type::i;

identity является частью пространства имен boost::mpl.