In the following code, it would appear that g++ 4.7.2 gets confused by a using
based type alias.
The code:
#include <map>
enum class Direction
{
UP=-1,
DOWN=1
};
template <Direction dir>
struct Comparator
{
bool operator()(int lhs, int rhs) const
{
return lhs<rhs; // Comparison should be based on dir
// but let's not even use dir for now
}
};
template <Direction dir>
using IntToIntMap=std::map<int, int, Comparator<dir>>;
template <Direction dir>
void TestFunc()
{
using TheMap=IntToIntMap<dir>; // TheMap should be a synonym for
// IntToIntMap<dir>
typename IntToIntMap<dir>::value_type value1; // This compiles
typename TheMap::value_type value2; // This does not (???)
}
int main()
{
TestFunc<Direction::UP>();
}
Compile the code with:
g++ -std=c++11 -Wall --pedantic -o test test.cpp
Unexpected compile time errors:
test.cpp: In instantiation of 'void TestFunc() [with Direction dir =
(Direction)-1]
test.cpp:34:29: required from here
test.cpp:29:33: error: no type named 'value_type' in 'using TheMap =
IntToIntMap<dir>'
What is wrong with the line in question? Is the code in violation of the the C++11 standard or is this a g++ 4.7.2 bug? Live code in g++-4.7
It's fixed in gcc-4.8, per the comments:
4.7: http://coliru.stacked-crooked.com/view?id=9d55db125baaac0b169e61bbcfcb2a26-f2a3752efd0426bdaa29babef505f76e
4.8: http://coliru.stacked-crooked.com/a/6cd0ad895d067e51