码迷,mamicode.com
首页 > 其他好文 > 详细

GCC学习 (四)如何编写makefile

时间:2016-05-24 20:39:30      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:

接上一篇

  • 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 的层数

 

GCC学习 (四)如何编写makefile

标签:

原文地址:http://www.cnblogs.com/linanwx/p/5524646.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!