Linux下我们可以用pwd命令来获取当前所执行命令的目录,在Makefile中对应可用PWD := $(shell pwd)来获取。但是如果子Makefile 文件是从别处执行的(通过make -f .../Makefile 执行),那么$(shell pwd)得到的目录即为执行make -f命令的当前目录。在这种情况下, Makefile本身里面的命令不能对当前目录作出假设.那么如何获取被调用的Makefile文件所在目录呢?
根据gnu make定义,gnu make 会自动将所有读取的makefile路径都会加入到MAKEFILE_LIST变量中,而且是按照读取的先后顺序添加。
所以可以通过$(abspath $(lastword $(MAKEFILE_LIST)))返回当前正在被执行的Makefile的绝对路径。
mkfile_path := $(abspath $(lastword $(MAKEFILE_LIST))) #获取当前正在执行的makefile的绝对路径
cur_makefile_path := patsubst$(%/, %, dir $(mkfile_patch)) #获取当前正在执行的makefile的绝对目录