GCC学习 (四)如何编写makefile

接上一篇

  • makefile嵌套执行

要执行另外一个makefile文件,若该文件在子目录下,可以这样执行:

----

伪目标:

  $(MAKE) -C subdir

----

$(MAKE) -C 可以用来执行subdir目录下的makefile

 

  • 变量传递

如果在父makefile中已经定义了一个变量,要传递到子makefile里面,需要使用export 关键字

----

export 变量

----

要传递所有变量时,可以不写变量

  • 宏定义
define run-yacc
yacc $(firstword $^)
mv y.tab.c $@
endef

上面是宏定义的使用方法

define endef 中间为定义部分,使用的时候,使用方法为

foo.c : foo.y
  $(run-yacc)

makefile遇到宏定义,展开为上述定义部分

该定义yacc一行为运行yacc命令

第二行为修改生成的y.tab.c 为目标名,显然这里的目标名就是foo.c

  • 变量的使用

当定义变量时,使用等号来完成赋值,使用$() 来引用

变量会在引用处按原值展开,类似于c语言宏定义

两个变量如果相互赋值,则会发生无穷展开,make检测到就会报错

例如

a=$b

b=$a

为了避免出现这种情况,需要使用另外一种赋值方式:= 该方式比较常用

  • 嵌套变量

MAKELEVEL表示当前makefile 的层数

 

posted @ 2016-05-24 19:57  linanwx  阅读(393)  评论(0编辑  收藏  举报