为C库生成Python SWIG绑定时未定义的符号



我正在尝试与Python中的mdb库接口,使用SWIG根据mdb附带的头文件生成绑定。这是我第一次尝试这样做,最后在python中加载共享库时,我遇到了一个未定义的符号。

这是我的接口定义文件:

$ cat pymdb.i
%module pymdb
%{
#include "mdbtools.h"
%}
%include "mdbtools.h"

生成C代码会引发以下警告:

$ swig -python -o pymdb.c -I/usr/include pymdb.i
/usr/include/mdbtools.h:187: Warning 451: Setting a const char * variable may leak memory.
/usr/include/mdbtools.h:188: Warning 451: Setting a const char * variable may leak memory.
/usr/include/mdbtools.h:189: Warning 451: Setting a const char * variable may leak memory.
/usr/include/mdbtools.h:190: Warning 451: Setting a const char * variable may leak memory.
/usr/include/mdbtools.h:191: Warning 451: Setting a const char * variable may leak memory.
/usr/include/mdbtools.h:192: Warning 451: Setting a const char * variable may leak memory.
/usr/include/mdbtools.h:193: Warning 451: Setting a const char * variable may leak memory.

编译C代码,一切看起来都很好:

$ gcc -c -fPIC -I/usr/include/python2.7 -I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include pymdb.c -o pymdb.o

将其链接到/usr/lib/x86_64-linux-gnu/libmdb.so.2.0.0文件(Debian multiarch):

$ ld -shared -lmdb pymdb.o -o _pymdb.so

这就是我得到未定义符号的地方,在python中加载.so:

$ echo "import pymdb" |python
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "pymdb.py", line 26, in <module>
_pymdb = swig_import_helper()
File "pymdb.py", line 22, in swig_import_helper
_mod = imp.load_module('_pymdb', fp, pathname, description)
ImportError: ./_pymdb.so: undefined symbol: read_pg_if_16

mdbtools.h:中有read_pg_if_16的声明

extern guint16 read_pg_if_16(MdbHandle *mdb, int *cur_pos);

我可以在_pymdb.so文件表中看到未定义的符号:

$ objdump -T _pymdb.so |grep read_pg_if_16
0000000000000000      D  *UND*  0000000000000000 read_pg_if_16

但是libmdb.so.2没有提供这个符号:

$ objdump -T /usr/lib/x86_64-linux-gnu/libmdb.so.2 |grep read_pg_if_16

可能是我的接口文件出错了吗?或者这可能是libmdb.so.2没有公开这个符号的问题吗?我对C和链接的东西没有那么深入,所以在这一点上我有点迷失了如何解决这个问题。

一种可能性是函数在头文件中声明,但在对象文件中没有定义。这在C中工作得很好,其中包含未引用的声明不是问题,但当swig包装声明时,它将创建一个引用,从而导致共享库无法加载。

相关内容

最新更新