Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3470922
  • 博文数量: 1450
  • 博客积分: 11163
  • 博客等级: 上将
  • 技术积分: 11101
  • 用 户 组: 普通用户
  • 注册时间: 2005-07-25 14:40
文章分类

全部博文(1450)

文章存档

2017年(5)

2014年(2)

2013年(3)

2012年(35)

2011年(39)

2010年(88)

2009年(395)

2008年(382)

2007年(241)

2006年(246)

2005年(14)

分类: LINUX

2007-09-30 08:30:45

例子:

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 这种方式迷惑的人有所帮助 :)
阅读(1637) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~