【转】makefile 获取指定目录下源文件名称

本文转自:http://langhuazht.blog.163.com/blog/static/1061055122009021105014565/


目的: 得到指定路径下源文件名称集合

 
       依次循环取得各目录下的所有源文件,在各目录下取源文件时过滤不支持的源文件格式,
       得到源文件集合(带路径)
SOURCES := $(foreach x,${SRC_DIR},\
       $(wildcard  \
       $(addprefix  ${x}/*,${SFIX}) ) )

例:

OS = ./plus        --------------------------------- .c文件所在目录
OS_C := $(foreach x,${OS},\   ----------------得到该目录下所有的 .c 文件
      $(wildcard  \
      $(addprefix  ${x}/*,.c) ) )

解释以下makefile中的函数:

1、foreach:

       foreach是用来做循环用的,类似于for 语句,语法是:$(foreach <var>,<list>,<text> )
       意思:把参数<list>中的单词逐一取出放到参数<var>所指定的变量中,然后再执行<text>所包含的表达式。每一次<text>会返回一个字符串,循环过程中,<text>的所返回的每个字符串会以空格分隔,最后当整个循环结束时,<text>所返回的每个字符串所组成的整个字符串(以空格分隔)将会是foreach函数的返回值。所以,<var>最好是一个变量名,<list>可以是一个表达式,而<text>中一般会使用<var>这个参数来依次枚举<list>中的单词。

例:
names := a b c d
files := $(foreach n,$(names),$(n).o)
      $(name)中的单词会被挨个取出,并存到变量“n”中,“$(n).o”每次根据“$(n)”计算出一个值,这些值以空格分隔,最后作为foreach函数的返回,所以,$(files)的值是“a.o b.o c.o d.o”。


2、wildcard:

      使用wildcard得到指定目录下所有的C语言源程序文件名的方法,不用手工一个一个指定需要编译的.c文件了,方法如下:
SRC = $(wildcard *.c)
      等于指定编译当前目录下所有.c文件,如果还有子目录,比如子目录为inc,则再增加一个wildcard函数:
SRC = $(wildcard *.c) $(wildcard inc/*.c)
      也可以指定汇编源程序:
ASRC = $(wildcard *.S)


3、addprefix:    

     功能:$(addprefix <prefix>,<names...> )   ,加前缀函数,把前缀<prefix>加到<names>中的每个单词前。
     返回:返回加过前缀的文件名序列。
     例:$(addprefix src/,foo bar)返回值是“src/foo src/bar”。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值