Makefile中用$(shell pwd)获取相对路径

Makefile里面获取相对路径必须在pwd前面加shell,然后把shell pwd当一个变量来引用,书写形式是:$(shell pwd)

INCDIR    := $(shell pwd)       //将shell pwd作为变量,通过 $(shell pwd)形式引用这个变量
# C预处理器的flag,flag就是编译器可选的选项
CPPFLAGS    := -nostdlib -nostdinc -I$(INCDIR)/include   //-nostdlib表示不使用标准库
                                                         //-nostdinc表示不使用标准头文件
//-I是用来指定相对路径的,这里表示我们需要预处理的文件所在的路径是相对路径下的include文件夹

INCDIR   := $(shell pwd)这种写法在Makefile中很常见,这里符号“:=”的意思是将$(shell pwd)表示为INCDIR,以免与下面用到shell pwd时可以用INCDIR来替代。这可以用宏定义的方法来类比理解一下

学习一下别人关于$(shell pwd)与$(pwd)的区别。有个网友写了这么一段,说明$(pwd)不行

$(pwd)不行
我刚才试了一下,把这几行保存成Makefile,然后make可以看到结果
P=$(shell pwd) # 这样可以输出路径
#P=$(pwd) # 这样没有输出
all:
    echo $P


 

你可能感兴趣的:(ARM,linux,Makefile)