GCC学习 如何编写makefile

Posted linanwx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了GCC学习 如何编写makefile相关的知识,希望对你有一定的参考价值。

接上一篇

  • makefile嵌套执行

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

----

伪目标:

  $(MAKE) -C subdir

----

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

 

  • 变量传递

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

----

export 变量

----

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

  • 宏定义
define run-yacc
yacc $(firstword $^)
mv y.tab.c [email protected]
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的主要内容,如果未能解决你的问题,请参考以下文章

GCC学习 如何编写makefile

单文件夹下的C程序如何编写Makefile文件

你如何为 clang 和 gcc 编写一个 makefile?

gdbmake/makefile学习心得

gdbmake/makefile学习心得

如何编写makefile