例子:
dep:
sed '/\#\#\# Dependencies/q' < Makefile > tmp_make
(for i in init/*.c;do echo -n "init/";$(CPP) -M $$i;done) >> tmp_make #
cp tmp_make Makefile
(cd fs; make dep)
(cd kernel; make dep)
(cd mm; make dep)
其中的 $$i 好长时间让我无法理解,最近看到一个关于 makefile 的文档, 它的解释是这样的:
出现在规则命令行中shell变量(一般为执行命令过程中的临时变量,它不属于Makefile变量,而是一个shell变量)引用使用shell的“$tmp”格式。
这也就是说, 在 (for i in init/*.c;do echo -n "init/";$(CPP) -M $$i;done) >> tmp_make
中的 i 是一个 shell 临时变量。在 shell 是引用变量与makefile中引用变是一样也是用 $符。所以 $i也就代表的是一个 shell 对i变量的引用。
那么再在makefile中引用这个 shell变量,所以就成了 $($i)。而在makefile中可以将()去掉,最终就变成了 $$i.
希望对 $$i 这种方式迷惑的人有所帮助 :)
阅读(1416) | 评论(0) | 转发(0) |