Перегрузка boost::multiprecision::cpp_int arguments

Когда я пытаюсь перегрузить аргумент типа boost::multiprecision::cpp_int с каким-то другим не связанным типом класса я получаю странные ошибки. Кто-нибудь знает, как это исправить или обойти это?

test_program.cpp:

#include <boost/multiprecision/cpp_int.hpp>

class A {
public:
    virtual void abstract_fn() = 0;
};

extern void fn(boost::multiprecision::cpp_int);
extern void fn(const A &);

void test(const A *v) {
    fn(*v);
}

g ++ -c test_program.cpp:

In file included from /usr/include/c++/5/random:42:0,
                 from /usr/include/c++/5/bits/stl_algo.h:66,
                 from /usr/include/c++/5/algorithm:62,
                 from /usr/include/boost/math/tools/config.hpp:17,
                 from /usr/include/boost/math/policies/error_handling.hpp:18,
                 from /usr/include/boost/multiprecision/detail/default_ops.hpp:9,
                 from /usr/include/boost/multiprecision/detail/generic_interconvert.hpp:9,
                 from /usr/include/boost/multiprecision/number.hpp:22,
                 from /usr/include/boost/multiprecision/cpp_int.hpp:12,
                 from test_program.cpp:1:
/usr/include/c++/5/limits: In instantiation of ‘struct std::numeric_limits<A>’:
/usr/include/boost/multiprecision/detail/number_base.hpp:749:80:   required from ‘struct boost::multiprecision::number_category<A>’
/usr/include/boost/multiprecision/traits/is_restricted_conversion.hpp:21:38:   required from ‘struct boost::multiprecision::detail::is_lossy_conversion<A, boost::multiprecision::backends::cpp_int_backend<> >’
/usr/include/boost/multiprecision/traits/is_restricted_conversion.hpp:38:7:   required from ‘struct boost::multiprecision::detail::is_restricted_conversion<A, boost::multiprecision::backends::cpp_int_backend<> >’
/usr/include/boost/multiprecision/number.hpp:49:16:   required by substitution of ‘template<class V> boost::multiprecision::number<Backend, ExpressionTemplates>::number(const V&, typename boost::enable_if_c<((((boost::is_arithmetic<V>::value || boost::is_same<std::__cxx11::basic_string<char>, V>::value) || boost::is_convertible<V, const char*>::value) && (! boost::is_convertible<typename boost::multiprecision::detail::canonical<V, Backend>::type, Backend>::value)) && (! boost::multiprecision::detail::is_restricted_conversion<typename boost::multiprecision::detail::canonical<V, Backend>::type, Backend>::value))>::type*) [with V = A]’
test_program.cpp:12:10:   required from here
/usr/include/c++/5/limits:320:7: error: invalid abstract return type ‘A’
       min() _GLIBCXX_USE_NOEXCEPT { return _Tp(); }
       ^
test_program.cpp:3:7: note:   because the following virtual functions are pure within ‘A’:
 class A {
       ^
test_program.cpp:5:18: note:        virtual void A::abstract_fn()
     virtual void abstract_fn() = 0;
                  ^

Это использует g++ 5.4.0 и boost v1.58 (пакеты по умолчанию для Ubuntu 16.04)

0 ответов

Другие вопросы по тегам