在介绍了简单的如何产生Makefile文档之后,相信已能够编写Makefile文档了,但那还远远不够,因为编写那么简单的Makefile文档还要如此繁琐和兴师动众,那未免小题大做了。因此,我们有必要进一步了解如何制作Makefile文档。在制作Makefile文档的过程中,编写configure.in文档是关键,因此这一部分将重点介绍configure.in文档的编写的相关问题。对于Makefile.am文档的编写在编译多文档和多目录中要用到,所以下一篇将会介绍。
在打开生成的Makefile文档,才发现能够编译的目标(target)有很多,因此有必要介绍一下其中比较重要而且常用的目标(target)的含义,也就是说,如何使用这个Makefile文档。
1〉make 或 make all
开始执行编译过程,产生我们设定的目标。这时会开始编译必要的源代码文档,然后进
行连结,并且最终生成可执行文档或我们想要生成库文档。 具体命令行如下:
[root@localhost testmk]#make
或
[root@localhost testmk]#make all
2〉make dist
将程式的源代码和相关文档打包成一个压缩文档,以用来备份源代码文档。命令完成后
会在目录下会产生一个以 PACKAGE-VERSION.tar.gz 为名称的打包文档。PACKAGE 和 VERSION 这两个变量是在configure.in文档中定义的。在我们的例子中定义如下:
AM_INIT_AUTOMAKE(hello,1.0)
因此会在目录中生成一个名为hello-1.0.tar.gz的文档。具体命令行如下:
[root@localhost testmk]#make dist
3〉make install
将正确编译生成的可执行文档或库文档安装到系统中,通常是/usr/local/bin这个目录。
假如没有需要安装的可执行文档或库文档,将会自动执行make命令进行编译,然后再进行安装操作。具体命令行如下:
[root@localhost testmk]#make install
4〉make clean
清除之前所编译的可执行文档连同目标文档(Object Files, *.o)。 具体命令行如下:
[root@localhost testmk]#make clean
5〉make distclean
清除之前所编译的可执行文档、目标文档(Object Files, *.o)连同由执行./configure
所产生的 Makefile文档。 具体命令行如下:
[root@localhost testmk]#make distclean
在弄清Makefile文档如何使用之后,我们来进一步了解生成Makefile文档的有关问题。先看一下源文档的结构和内容:
/hello-1.0
/hello-1.0/pubfun.h
/hello-1.0/pubfun.c
/hello-1.0/hello.c
-------------------------------------------------
/*filename:pubfun.h */
#include
void *printA(void *pdata);
-------------------------------------------------
/*filename:pubfun.c */
#include
#include
#include
void *printA(void *pdata)
{
printf("%f\n",sin(2));
printf("Hello,World -->%d\n",getpid());
}
-------------------------------------------------
/*filename:hello.c */
#include
#include
#include "pubfun.h"
int main(int argc,char **argv)
{
int ret;
pthread_t ptid;
int index;
// create a thread
ret = pthread_create(&ptid,NULL,printA,(void *)&index);
if(ret)
return -1;
printA(NULL);
return 0;
}
---------------------------------------------------
对于我们的源文档中用到了数学库和线程库,更有我们自己写的头文档,我们修改configure.in
文档如下:
01:dnl Process this file with autoconf to produce a configure script.
02:AC_INIT(hello.c)
03:
04:dnl Add the file by leaf
05:AM_INIT_AUTOMAKE(hello,1.0)
06:
07:dnl 检查C编译器.假如在环境中没有设定CC,就查找gcc,假如没有找到,就使用cc.
08:AC_PROG_CC
09:
10: dnl 为C编译器提供的调试和优化选项.
11: CFLAGS=" -O2"
12:
13: dnl 为C预处理器和编译器提供头文档搜索目录选项('-Idir')连同其他各种选项.
14: CPPFLAGS=" -I."
15:
16: dnl 自定义输出的检查信息
17:AC_MSG_CHECKING([for architecture type])
18:
19:dnl 输出检查结果
20: AC_MSG_RESULT([ok])
21:
22: dnl 传递给连接器的'-l'和'-L'选项.
23: LIBS=" -L."
24:
25:dnl Checks for libraries,Might abort.
26:AC_CHECK_LIB(m,sin,[LIBS="$LIBS -lm"],exit 1)
27: AC_CHECK_LIB(pthread,pthread_create,[LIBS="$LIBS -pthread"],exit 1)
28: dnl AC_CHECK_LIB(socket, connect)
29:
30:dnl Checks for header files.(检查头文档是否存在)
31:AC_CHECK_HEADERS(sys/socket.h)
32:
33:dnl Checks for typedefs, structures, and compiler characteristics.
34:
35:dnl Checks for library functions.
36:
37:AC_OUTPUT(Makefile)
这个configure.in文档中使用了几个常用的宏,更有一些如AC_ARG_ENABLE宏、AC_MSG_ERROR 宏、AC_MSG_RESULT宏、AM_PATH_GTK宏等有用的宏,您能够在附带的附件文档里查找,以便使用。这里我要重点提一下第26到28行,对于程式中需要用到一些特定的库,需要在编译时进行指定,否则会出现连结错误。例如第26行就对数学库进行了检查,假如没有,将退出Makefile文档的生成,因为很难找到数学库生成也编译但是去;同理第27行对线程库进行了检查,第28行对socket库进行了检查(被注释掉的原因是引用的例子中没用到此库)。这里面用到了AC_CHECK_LIB宏。具体用法如下:
文章整理:西部数码--专业提供域名注册、虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!



