Chinaunix首页 | 论坛 | 博客
  • 博客访问: 998728
  • 博文数量: 186
  • 博客积分: 10020
  • 博客等级: 上将
  • 技术积分: 1676
  • 用 户 组: 普通用户
  • 注册时间: 2006-08-14 17:08
文章存档

2011年(5)

2009年(11)

2008年(2)

2007年(111)

2006年(57)

我的朋友

分类: LINUX

2007-05-09 11:30:57

一.Makefile里有什么?
Makefile里主要包含5个东西:
1.显示规则。显示规则说明如何生成一个或多个目标文件。指出要生成的文件,文件的依赖
文件,生成的命令。
 
2.隐晦规则。make有自动推导的功能,所以隐晦的规则可以让我们粗糙地简略地书写
Makefile,这是由make所支持的
 
3.变量的定义。在Makefile中我们定义了一系列的变量,变量一般是字符串,当Makefile被
执行时,其中的变量都会被扩展到相应的引用位置上
 
4.文件指示。其包括了三个部分,1)一个Makefile中引用另一个Makefile,像include一样
                          2)根据某些情况指定Makefile中的有效部分,像#if一样
                          3)定义一个多行的命令。后续会说明这个部分
 
5.注释。Makefile中只有行注释,和UNIX的shell脚本一样,其注释是用"#"字符
最后值得一提的是,在Makefile中的命令,必须要以[Tab]键开始
 
 
二.Makefile的文件名
   默认情况下,make命令会在当前目录下按顺序寻文件名为"GNUmakefile","makefile","Makefile"的文件。
   其中Makefile这个文件最好识别,因为它第一个是以大写字母开头的
   也可以使用别的文件名来书写Makefile,比如"Make.Linux","Make.Solaris","Make.AIX"
   如要指定特定的Makefile,可以使用 make -f Make.Linux 或 make --file Make.AIX
 
三.引用其它的Makefile
   在Makefile使用include关键字可以把别的Makefile包含进来,它很像C语言的#include,被
包含的文件会原摸原样的放在当前文件的包含位置。include的语法是:
   include
            filename可以是当前操作系统Shell的文件模式(可以包含路径和通配符)
   在include前面可以有一些空字符,但是绝不能是[Tab]键开始
 
举个例子,你有这样几个Makefile:a.mk、b.mk、c.mk,还有一个文件叫foo.make,以及一
个变量$(bar),其包含了e.mk和f.mk,那么,下面的语句:
    include foo.make *.mk $(bar)
    等价于:
    include foo.make a.mk b.mk c.mk e.mk f.mk
 
    make命令开始时,会找寻include所指出的其他Makefile并把内容安置在当前位置;如
果文件都没有指定绝对路径或是相对路径的话,make会在当前目录下首先寻找,然后还会在
下面的几个目录下找:
    1.如果make执行时,有"-I"或"--include-dir"参数,那么make就会在这个参数所指定
的目录下去寻找。
    2.如果目录/include(一般是:/usr/local/bin或/usr/include)存在的话,
make也会去找
     如果有文件没有找到的话,make会生成一条警告信息,但不会马上出现致命错误;它
会继续载入其他的文件,一旦完成makefile读取,make会再重试这些没有找到,或是不能读
取的文件,如果还是不行,make才会出现一条致命信息。
     如果你想让make不理那些无法读取的文件,而继续执行,你可以在include前加一个减
号"-",如:     -include
     其表示,无论include过程中出现什么错误,都不要报错继续执行,和其他版本make兼
容相关命令是sinclude,其作用和这一个是一样的
 
四.环境变量MAKEFILES
     如果你的当前环境中定义了环境变量MAKEFILES,那么,make会把这个变量中的值做一
个类似于include的动作,这个变量的值是其他的Makefile,用空格分隔;它和include不同
的是,从这个环境变量中引入的Makefile的"目标"不会起作用,如果环境变量中定义的文件
发现错误,make也不会理。
     所以在这里我不建议使用这个环境变量,如果使用,那所有的Makefile都会受到它的
影响,这绝不是你想看到的。
     呵呵,题外话,如果你的Makefile出现了怪事,那么你可以看看当前环境中有没有定义
这个变量。
 
五.make的工作方式
   GNU的make工作时的执行步骤如下:(想来其他的make也是类似)
       1.读入所有的Makefile
       2.读入被include的其他Makefile
       3.初始化文件中的变量
       4.推导隐晦规则,并分析所有规则
       5.为所有的目标文件创建依赖关系链
       6.根据依赖关系,决定哪些目标要重新生成
       7.执行生成命令
1-5步为第一个阶段:如果定义的变量被使用了,那么,make会把其展开在使用的位置;但
make并不会完全马上展开,make使用的是拖延战术,如果变量出现在依赖关系的规则中,那
么仅当这条依赖被决定要使用了,变量才会在其内部展开
6-7步为第二个阶段
阅读(1726) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~