【转】Makefile中的foreach函数

Makefile中的foreach函数

摘自《GNU+Makefile中文手册》整理翻译:徐海兵

概述

函数“ foreach”不同于其它函数。它是一个循环函数。类似于 Linux 的 shell 中的 for 语句。

语法:

$(foreach VAR,LIST,TEXT)

函数功能:

这个函数的工作过程是这样的:

如果需要(存在变量或者函数的引用),首先展开变量“ VAR”和“ LIST”的引用;而表达式“ TEXT”中的变量引用不展开。

执行时把“ LIST”中使用空格分割的单词依次取出赋值给变量“ VAR”,然后执行“ TEXT”表达式。重复直到“ LIST”的最后一个单词(为空时结束)。

“ TEXT”中的变量或者函数引用在执行时才被展开,因此如果在“ TEXT”中存在对“ VAR”的引用,那么“ VAR”的值在每一次展开式将会到的不同的值。

返回值:

空格分割的多次表达式“ TEXT”的计算的结果。

例子:

我们来看一个例子,定义变量“ files”,它的值为四个目录(变量“ dirs”代表的 a、b、 c、 d 四个目录)下的文件列表:

dirs := a b c d
files := $(foreach dir,$(dirs),$(wildcard $(dir)/*))

例子中,“ TEXT”的表达式为“ (wildcard (dir)/)”。表达式第一次执行时将展开为“ (wildcarda/) (wildcard b/)”;第三次展开为“ $(wildcard c/*)”;….;以此类推。所以此函数所实现的功能就和一下语句等价:

files := $(wildcard a/* b/* c/* d/*)

当函数的“ TEXT”表达式过于复杂时,我们可以通过定义一个中间变量,此变量代表表达式的一部分。并在函数的“ TEXT”中引用这个变量。上边的例子也可以这样来实现:

find_files = $(wildcard $(dir)/*)
dirs := a b c d
files := $(foreach dir,$(dirs),$(find_files))

在这里我们定义了一个变量(也可以称之为表达式),需要注意,在这里定义的是“递归展开”时的变量“ find_files”。保证了定义时变量值中的引用不展开,而是在表达式被函数处理时才展开(如果这里使用直接展开式的定义将是无效的表达式)。可参考 6.2两种变量定义 一节。

函数说明:

函数中参数“ VAR”是一个局部的临时变量,它只在“ foreach”函数的上下文中有效,它的定义不会影响其它部分定义的同名“ VAR”变量的值。在函数的执行过程中它是一个“直接展开”式变量。在使用函数“ foreach”时,需要注意: 变量“ VAR”的名字。我们建议使用一个单词、最好能够表达其含义的名字,不要使用一个奇怪的字符串作为变量名。虽然执行是不会发生错误,但是会让人很费解。没有人会喜欢这种方式,尽管可能它可以正常工作:

files := $(foreach Esta escrito en espanol!,b c ch,$(find_files))

你可能感兴趣的:(Makefile)