В настоящее время я работаю над числовой библиотекой, которая использует шаблоны выражений. К сожалению, я столкнулся с проблемой перегрузки моего оператора. Рассмотрим следующий урезанный пример.
#include <vector>
namespace test {
class test {};
template<class A, class B>
class testExpr {};
template<class A, class B>
testExpr<A, B>
operator-(A a, B b)
{
return testExpr<A, B>();
}
}
test::test
stuff(std::vector<test::test> &v)
{ return v.back(); }
int main()
{ }
Что выдает следующее сообщение об ошибке при компиляции с gcc 4.4.3 или clang 2.8:
In file included from eir_test.cc:2:
In file included from /usr/include/c++/4.4/vector:64:
/usr/include/c++/4.4/bits/stl_vector.h:696:16: error: indirection requires pointer operand
('testExpr<__gnu_cxx::__normal_iterator<test::test *, std::vector<test::test, std::allocator<test::test> > >, int>' invalid)
{ return *(end() - 1); }
^~~~~~~~~~~~
eir_test.cc:21:12: note: in instantiation of member function 'std::vector<test::test, std::allocator<test::test> >::back' requested here
return v.back();
^
1 error generated.
По какой-то причине компиляторы выполняют поиск в тестовом пространстве имен и находят мой общий оператор. Я использовал эту форму вместе с магией некоторых черт, чтобы уменьшить количество версий, которые я должен был сделать для оператора. Он должен принимать 4 разных типа данных (включая double и int), что приведет к множеству различных комбинаций.
Есть ли способ заставить это работать без указания всех комбинаций для каждого оператора?