У меня проблемы с компиляцией следующего фрагмента
int temp;
vector<int> origins;
vector<string> originTokens = OTUtils::tokenize(buffer, ","); // buffer is a char[] array
// original loop
BOOST_FOREACH(string s, originTokens)
{
from_string(temp, s);
origins.push_back(temp);
}
// I'd like to use this to replace the above loop
std::transform(originTokens.begin(), originTokens.end(), origins.begin(), boost::bind<int>(&FromString<int>, boost::ref(temp), _1));
, где рассматриваемая функция
// the third parameter should be one of std::hex, std::dec or std::oct
template <class T>
bool FromString(T& t, const std::string& s, std::ios_base& (*f)(std::ios_base&) = std::dec)
{
std::istringstream iss(s);
return !(iss >> f >> t).fail();
}
ошибка, которую я получаю
1>Compiling with Intel(R) C++ 11.0.074 [IA-32]... (Intel C++ Environment)
1>C:\projects\svn\bdk\Source\deps\boost_1_42_0\boost/bind/bind.hpp(303): internal error: assertion failed: copy_default_arg_expr: rout NULL, no error (shared/edgcpfe/il.c, line 13919)
1>
1> return unwrapper<F>::unwrap(f, 0)(a[base_type::a1_], a[base_type::a2_]);
1> ^
1>
1>icl: error #10298: problem during post processing of parallel object compilation
Google необычайно бесполезен, поэтому я надеюсь, что кто-то здесь может дать некоторые идеи.
ОБНОВЛЕНИЕ : на вопрос отвечает решение @ gf, но, что интересно, исходная функция была не совсем корректной, поскольку в ней сохранялся результат операции преобразования (не удалось / не удалось), а не само преобразованное значение , Я изменил сигнатуру, возвращающую преобразованное значение напрямую, и компилятор смог правильно определить тип привязки.
// new signature
T FromString(const std::string& s, std::ios_base& (*f)(std::ios_base&) = std::dec);
// revised calling syntax - note that bind<int> is not required.
transform(originTokens.begin(), originTokens.end(), origins.begin(), bind(&FromString<int>, _1, std::dec));