我經常使用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();
}