makefile下$(wildcard $^),$^,$@,$?,$<,$(@D),$(@F)代表的不同含义



$(filter-out $(PHONY) $(wildcard $^),$^)

常用用法为$(wildcard *.c)

表示列举当前目录下的所有.c文件

这里$^因为会包含依赖的文件名,如果包含的该文件存在,那么将返回其含路径的文件名

所以$(wildcard $^)就是用来过滤$^包含的所有文件并且该文件确实在本地存在.



自动化变量$?代表依赖文件列表中被改变过的所有文件。

自动化变量$^代表所有通过目录搜索得到的依赖文件的完整路径名(目录 + 一般文件名)列表。

自动化变量$@代表规则的目标。

自动化变量$<代表规则中通过目录搜索得到的依赖文件列表的第一个依赖文件。

自动化变量$(@D)

The directory part of the file name of the target,

with the trailing slash removed. If the value of ‘$@’ is dir/foo.o

then ‘$(@D)’ is dir. This value is . if ‘$@’ does not contain a slash.

http://www.gnu.org/software/make/manual/make.html

自动化变量$(@F)

The file-within-directory part of the file name of

the target. If the value of ‘$@’ is dir/foo.o then ‘$(@F)’ is foo.o.

‘$(@F)’ is equivalent to ‘$(notdir $@)’.



4.12 静态模式

静态模式规则是这样一个规则:

规则存在多个目标,

并且不同的目标可以根据目标

文件的名字来自动构造出依赖文件。

静态模式规则比多目标规则更通用,

它不需要多个

目标具有相同的依赖。

但是静态模式规则中的依赖文件必须是相类似的而不是完全相同

的。

4.12.1

静态模式规则的语法

首先,我们来看一下静态模式规则的基本语法:

TARGETS ...: TARGET-PATTERN: PREREQ-PATTERNS ...

COMMANDS

...

“TAGETS”

列出了此规则的一系列目标文件。

像普通规则的目标一样可以包含通

配符。关于通配符的使用可参考 4.4 文件名使用通配符 一节

“TAGET-PATTERN”和“PREREQ-PATTERNS”说明了如何为每一个目标文件

生成依赖文件。从目标模式(TAGET-PATTERN)的目标名字中抽取一部分字符串(称

为“茎”。使用“茎”替代依赖模式(PREREQ-PATTERNS)中的相应部分来产生对

)

应目标的依赖文件。下边详细介绍这一替代的过程。

首 先 在目标模式和依赖模式中 ,一般需要包含模式字符“% ”

。在目标模式

(TAGET-PATTERN)中“%”可以匹配目标文件的任何部分,模式字符“%”匹配的

部分就是“茎”

。目标文件和目标模式的其余部分必须精确的匹配。看一个例子:目标

“foo.o”符合模式“%.o”

,其“茎”为“foo”

。而目标“foo.c”和“foo.out”就不符

合此目标模式。

每一个目标的依赖文件是使用此目标的“茎”代替依赖模式

(PREREQ-PATTERNS)中的模式字符“%”而得到。例如:上边的例子中依赖模式

(PREREQ-PATTERNS)为“%.c”

,那么使用“茎”

“foo”替代依赖模式中的“%”

得到的依赖文件就是“foo.c”

。需要明确的一点是:在模式规则的依赖列表中使用不包

含模式字符“%”也是合法的。代表这个文件是所有目标的依赖文件。

在模式规则中字符‘%’可以用前面加反斜杠“\”方法引用。引用“%”的反斜杠

也可以由更多的反斜杠引用。引用“%”“\”的反斜杠在和文件名比较或由“茎”代



替它之前会从模式中被删除。反斜杠不会因为引用“%”而混乱。如,模式

“the\%weird\\%pattern\\”是“the%weird\”+“%”+“pattern\\”构成。最后的两个

反斜杠由于没有任何转义引用“%”所以保持不变。

我们来看一个例子,它根据相应的.c 文件来编译生成“foo.o”和“bar.o”文件:

objects = foo.o bar.o

all: $(objects)

$(objects): %.o: %.c

$(CC) -c $(CFLAGS) $< -o $@

例子中,规则描述了所有的.o文件的依赖文件为对应的.c文件,对于目标“foo.o”

,取

其茎“foo”替代对应的依赖模式“%.c”中的模式字符“%”之后可得到目标的依赖文

件“foo.c”

。这就是目标“foo.o”的依赖关系“foo.o: foo.c”

,规则的命令行描述了如

何完成由“foo.c”编译生成目标“foo.o”

。命令行中“$<”和“$@”是自动化变量,

“$<”

表示规则中的第一个依赖文件,

“$@”

表示规则中的目标文件

(可参考 10.5.3 自

动化变量 一小节)

。上边的这个规则描述了以下两个具体的规则:

foo.o : foo.c

$(CC) -c $(CFLAGS) foo.c -o foo.o

bar.o : bar.c

$(CC) -c $(CFLAGS) bar.c -o bar.o

在使用静态模式规则时,指定的目标必须和目标模式相匹配,否则执行make时将

会得到一个错误提示。

如果存在一个文件列表,

其中一部分符合某一种模式而另外一部

分符合另外一种模式,这种情况下我们可以使用“filter”函数(可参考 第八章 make

的内嵌函数)来对这个文件列表进行分类,在分类之后对确定的某一类使用模式规则。

例如:

files = foo.elc bar.o lose.o

$(filter %.o,$(files)): %.o: %.c

$(CC) -c $(CFLAGS) $< -o $@

$(filter %.elc,$(files)): %.elc: %.el

emacs -f batch-byte-compile $<

其中;$(filter %.o,$(files))的结果为“bar.o lose.o”“filter”函数过滤不符合“%.o”



模式的文件名而返回所有符合此模式的文件列表。

第一条静态模式规则描述了这些目标

文件是通过编译对应的.c 源文件来重建的。同样第二条规则也是使用这种方式。

我们通过另外一个例子来看一下自动环变量“$*”在静态模式规则中的使用方法:

bigoutput littleoutput : %output : text.g

generate text.g -$* > $@

当执行此规则的命令时,

自动环变量

“$*”

被展开为

“茎” 在这里就是



“big” “little”





静态模式规则对一个较大工程的管理非常有用。

它可以对整个工程的同一类文件的

重建规则进行一次定义,而实现对整个工程中此类文件指定相同的重建规则。比如,可

以用来描述整个工程中所有的.o 文件的依赖规则和编译命令。通常的做法是将生成同

一类目标的模式定义在一个 make.rules 的文件中。在工程各个模块的 Makefile 中包含

此文件。

  1. 静态模式makefile中$(cobjs): $(obj)/%.o: $(src)/%.c
  2. http://www.gnu.org/software/make/manual/make.html
  3. 4.12.1 Syntax of Static Pattern Rules
  4. Here is the syntax of a static pattern rule:
  5. targets ...: target-pattern: prereq-patterns
    ...
  6. recipe
  7. ...
  8. The targets list specifies the targets that the rule applies
    to. The targets can contain wildcard characters, just like the targets of ordinary rules
    (see Using Wildcard Characters
    in File Names).
  9. The target-pattern
    and prereq-patterns say how
    to compute the prerequisites of each target.
    Each target is matched against the target-pattern
    to extract a part of the target name, called the stem. This stem
    is substituted into
    each of the prereq-patterns
    to make the prerequisite names (one from
    each prereq-pattern).
  10. Each pattern normally contains the character ‘%’ just once. When the target-pattern matches a target,
    the ‘%’ can match any part of the target name; this part
    is called the stem. The rest of the pattern must match exactly.
    For example, the target foo.o matches the pattern ‘%.o’,
    with ‘foo’ as the stem. The targets foo.c
    and foo.out
    do not match that pattern.
  11. The prerequisite names for
    each target are made by substituting the stem
    for the ‘%’
    in each prerequisite pattern.
    For example,
    if one prerequisite pattern
    is %.c,
    then substitution of the stem ‘foo’ gives the prerequisite name foo.c. It
    is legitimate to write a prerequisite pattern that does
    not contain ‘%’;
    then this prerequisite
    is the same for all targets.
  12. ‘%’ characters
    in pattern rules can be quoted with preceding backslashes
    (‘\’). Backslashes that would otherwise quote ‘%’ characters can be quoted with more backslashes.
    Backslashes that quote ‘%’ characters
    or other backslashes are removed from the pattern before it
    is compared to file names
    or has a stem substituted into it. Backslashes that are
    not in danger of quoting ‘%’ characters go unmolested.
    For example, the pattern the\%weird\\%pattern\\
    has ‘the%weird\’ preceding the operative ‘%’ character,
    and ‘pattern\\’ following it. The final two backslashes are
    left alone because they cannot affect any ‘%’ character.
  13. Here is an example, which compiles
    each of foo.o
    and bar.o from the corresponding
    .c file:
  14. objects = foo.o bar.o
  15. all: $(objects)
  16. $(objects):
    %.o:
    %.c
  17. $(CC)
    -c $(CFLAGS) $<
    -o $@
  18. Here ‘$<’ is the automatic variable that holds the name of the prerequisite
    and ‘$@’ is the automatic variable that holds the name of the target; see Automatic Variables.
  19. Each target specified must match the target pattern; a warning
    is issued for
    each target that does
    not. If you have a list of files, only some of which will match the pattern, you can use the
    filter function
    to remove nonmatching file names
    (see Functions for
    String Substitution and Analysis):
  20. files = foo.elc bar.o lose.o
  21. $(filter
    %.o,$(files)):
    %.o:
    %.c
  22. $(CC)
    -c $(CFLAGS) $<
    -o $@
  23. $(filter
    %.elc,$(files)):
    %.elc:
    %.el
  24. emacs -f batch-byte-compile $<
  25. In this example the result of ‘$(filter
    %.o,$(files))’
    is bar.o lose.o,
    and the first static pattern rule causes
    each of these object files to be updated by compiling the corresponding C source file. The result of ‘$(filter
    %.elc,$(files))’
    is foo.elc, so that file
    is made from foo.el.
  26. Another example shows how to use $*
    in static pattern rules:
  27. bigoutput littleoutput :
    %output : text.g
  28. generate text.g
    -$*
    > $@
  29. When the generate command is run, $* will expand
    to the stem, either ‘big’
    or ‘little’.

随机推荐

  1. Uva10972(RevolC FaeLoN)

    题目链接:传送门 题目大意:给你一副无向图,问至少加多少条边使图成为边双联通图 题目思路:tarjan算法+缩点(如果已经是双连通图就直接输出0) #include <iostream> ...

  2. SpringBoot使用H2内嵌数据库

    1.驱动 我们知道,JDBC是JDK自带的接口规范,不同的数据库有不同的实现,只需要引入相应的驱动包即可. 在使用MySQL数据库时,引入的是MySQL驱动,相应的,使用H2数据库时,也需要引入H2驱 ...

  3. Nginx 启动、停止、平滑重启和平滑升级 graceful shutdown of worker processes

    Controlling nginx http://nginx.org/en/docs/control.html nginx can be controlled with signals. The pr ...

  4. 设计线程安全的类 VS 发布线程安全的对象

    一.设计线程安全的类 步骤: 找出构成对象状态的所有变量 找出约束状态变量的不变性条件 建立对象状态的并发访问策略 1.在现有的线程安全类中添加功能 (1)重用能减低工作量和提高正确性 (2)如果底层 ...

  5. Linux中对启动过程中选择启动级别那个界面设置密码

    生成md5形式的密码: a.执行  grub-md5-crypt  命令 b.在接下来的交互界面中输入自己的密码 c.生成加密后的密码修改配置文件: a.vi /boot/grub/grub.conf ...

  6. sql server扫盲系列

    本系列为入门级,不会介绍过于深入的知识.为防止不道德转载(特别是红黑联盟,把我原文地址删掉,其他照搬,无节操无道德),尽可能打上水印和加上原文地址,读者看的不爽请见谅.原文地址:http://blog ...

  7. Ubuntu 14.04上安装WineTMQQ2013麒麟版

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/tao_627/article/details/24187699 我先后试用了longterm团队的2 ...

  8. java中使用axis发布和调用webService及dom4j解析xml字符串

    工作中需要调用webService服务,这里记录一下如何在java中发布和调用webService. 需要的jar包: webService服务端: import javax.jws.WebMetho ...

  9. 常用MS-SQL写法整理

    这里整理日常会用到的一些写法,一些常规的group by,系统函数等用法不在这里做记录了,大家有什么好的写法也可以分享下 1 sql操作xml内容(sp_xml_preparedocument和ope ...

  10. 剑指offer 面试47题

    面试47题:题:礼物的最大价值 题目:在一个mxn的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于0),你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格,直到到达棋盘的 ...