2017-02-15 51 views
0

我經常使用boost.python & MSVC 12(動態鏈接)將C++類暴露給python。最近我一直試圖使用「docstring_options」類來包含文檔。該文檔的例子做工精細:當使用docstring_options暴露類時boost.python MSVC12鏈接器錯誤

http://www.boost.org/doc/libs/1_54_0/libs/python/doc/v2/docstring_options.html

然而,當我包括類,並揭露它,我得到的鏈接錯誤:

錯誤LNK2019:無法解析的外部符號「無效__cdecl的boost :: throw_exception(類STD :: exception exception &)「(?throw_exception @ boost @@ YAXABVexception @ std @@@ Z)在函數」public:__thiscall boost :: detail :: shared_count :: shared_count(void *,struct boost :: python ::轉換器:: shared_ptr_deleter)「

我敢肯定,可能有東西簡單的我很想念,但我無法弄清楚。

非常感謝提前!

來自boost示例的示例代碼,這個示例代碼給了我這個錯誤。

#include <string> 
#include <boost/python/module.hpp> 
#include <boost/python/def.hpp> 
#include <boost/python/args.hpp> 
#include <boost/python/docstring_options.hpp> 
#include <boost/python.hpp> 
struct World 
{ 
void set(std::string msg) { this->msg = msg; } 
std::string greet() { return msg; } 
std::string msg; 
}; 
int foo1(int i) { return i; } 
int foo2(long l) { return static_cast<int>(l); } 
int bar1(int i) { return i; } 
int bar2(long l) { return static_cast<int>(l); } 
namespace { 
void wrap_foos() 
{ 
    using namespace boost::python; 
    def("foo1", foo1, arg("i"), "foo1 doc"); 
    def("foo2", foo2, arg("l"), "foo2 doc"); 
} 
void wrap_bars() 
{ 
    using namespace boost::python; 
    bool show_user_defined = true; 
    bool show_signatures = false; 
    docstring_options doc_options(show_user_defined, show_signatures); 
    def("bar1", bar1, arg("i"), "bar1 doc"); 
    def("bar2", bar2, arg("l"), "bar2 doc"); 

    class_<World>("World") 
     .def("greet", &World::greet) 
     .def("set", &World::set) 
    ; 

} 
} 
BOOST_PYTHON_MODULE(boost_py_doc_demo) 
{ 
boost::python::docstring_options doc_options(false); 
wrap_foos(); 
wrap_bars(); 
} 

回答

0

我編譯了最新版本的boost(1.63),現在問題已經消失。我想我的舊圖書館在某種程度上是不完整的。