Я пытаюсь скомпилировать небольшую программу C++, используя clang со стандартной стандартной библиотекой C++ (4.6.2) в Fedora. Сам Clang компилирует все в порядке, а тестовая программа использует только компиляции и работает нормально.Действительно ли этот код шаблона C++? g ++ компилирует его, но clang не будет
В моей другой программе используются веревки, которые жалуются.
/usr/lib/gcc/x86_64-redhat-linux/4.6.2/../../../../include/c++/4.6.2/ext/ropeimpl.h:433:2: error: use of undeclared identifier '_Data_allocate' _Data_allocate(_S_rounded_up_size(__old_len + __len));
bug был подан против лязга за это сообщение об ошибке, и разрешение было лязг правильно, библиотечный код неверен.
Clang is correct here. There are no type-dependent arguments in the call to _Data_allocate, so name lookup fails at template definition time.
Контекст неисправного кода:
// Concatenate a C string onto a leaf rope by copying the rope data.
// Used for short ropes.
template <class _CharT, class _Alloc>
typename rope<_CharT, _Alloc>::_RopeLeaf*
rope<_CharT, _Alloc>::
_S_leaf_concat_char_iter(_RopeLeaf* __r, const _CharT* __iter, size_t __len)
{
size_t __old_len = __r->_M_size;
_CharT* __new_data = (_CharT*)
_Data_allocate(_S_rounded_up_size(__old_len + __len));
_RopeLeaf* __result;
uninitialized_copy_n(__r->_M_data, __old_len, __new_data);
uninitialized_copy_n(__iter, __len, __new_data + __old_len);
_S_cond_store_eos(__new_data[__old_len + __len]);
__try
{
__result = _S_new_RopeLeaf(__new_data, __old_len + __len,
__r->_M_get_allocator());
}
__catch(...)
{
_RopeRep::__STL_FREE_STRING(__new_data, __old_len + __len,
__r->_M_get_allocator());
__throw_exception_again;
}
return __result;
}
Мой вопрос, если этот код не действует, есть простое решение? g ++ компилирует это нормально.
Считаете ли вы, что хотите сделать отчет об ошибке на странице http://gcc.gnu.org/bugzilla/? –