makefile中的特殊变量

1、MAKECMDGOALS

make 在执行时会设置一个特殊变量 -- "MAKECMDGOALS" ,该变量记录了命令行参数指定的终极目标列表,没有通过参数指定终极目标时此变量为空。该变量仅限于用在特殊场合(比如判断),在 Makefile 中最好不要对它进行重新定义。

在敲命令:make run时,MAKECMDGOALS这个变量的值就被设为了run

// 在makefile中判断是否执行了某个命令
ifeq($(MAKECMDGOALS),$(findstring $(MAKECMDGOALS),run,cmp,ncrun)
     当执行的是run、cmp、ncrun就执行这些处理
endif
1、MAKE
$(MAKE)变量其实就是存储的make字符
taget:
    @$(MAKE) run tc=xxx

// 等效于
taget:
    @make run tc=xxx
 
原文地址:https://www.cnblogs.com/yuandonghua/p/11942722.html