参考自:
http://library.gnome.org/users/anjuta-build-tutorial/2.26/library-autotools.html.en
示例代码:
#include <libxml/parser.h> #include <stdio.h> int main() { xmlDocPtr doc; doc = xmlParseFile ("testfile.xml"); if (doc == NULL) { printf ("Document not parsed successfully. \n"); return -1; } else { printf ("Document parsed successfully.\n"); xmlFreeDoc(doc); return 0; } }
在实例代码中存在libxml库的依赖,
对于一般的C工程来说我们可以通过下面三种方式来添加libxml库的依赖:
1.使用pkg-config
a. 在 configure.ac (或者 configure.in )中添加如下宏:
PKG_CHECK_MODULES(XML, libxml-2.0 >= 2.4)
./configure 时会去确认 libxml-2.0的版本号,大于或者等于2.4。
libxml-2.0 是依赖库的库名,可以通过命令 pkg-config --list-all 查看当前所有的 pkg-config支持库。
b. 在 Makefile.am 中添加如下宏:
tut_prog_CPPFLAGS = $(XML_CFLAGS) tut_prog_LDFLAGS= $(XML_LIBS)
其中tut_prog是程序名,$(XML_CFLAGS) 和 $(XML_LIBS)就是对应的依赖库。
2.使用Autoconf工具提供的宏
在/usr/share/aclocal 中有很多用M4写好的宏,我们可以找到libxml对应的 /usr/share/aclocal/libxml.m4。
a. 在 configure.ac (或者 configure.in )中添加如下宏:
AM_PATH_XML2(2.4.0)
b. 在 Makefile.am 中添加如下宏:
tut_prog_CPPFLAGS = $(XML_CPPFLAGS) tut_prog_LDFLAGS= $(XML_LIBS)
注意:这里的$(XML_CPPFLAGS)和第一点不同,是在libxml.m4中有定义的宏。
如果在/usr/share/aclocal/中找不到对应的M4宏,你可以去这里 看看,也许已经有人写好了一些常用的M4宏。
3.手动指定依赖库的路径
在 Makefile.am 中添加如下代码:
tut_prog_CPPFLAGS = -I /usr/include/libxml2 tut_prog_LDFLAGS= -lxml2