1) Makefile:6: *** missing separator. Stop.
报出来Makefile的第6行有缺少分隔符问题. 打开Makefile文件,找到第6行,发现是该行的命令
顶行写,没有用Tab键隔离.
第六行行首加一个Tab键后问题解决. 注: 在makefile中,命令行要以tab键开头。
可通过.RECIPEPREFIX来修改tab为其他符号,如:
.RECIPEPREFIX = >
all:
> echo $$pwd
2) = 和 :=的区别
我们可以使用这两个赋值符号用其它变量来给变量赋值。这两个赋值符号的效果不同。
对=符号,为动态赋值。右侧变量不一定非要是已定义好的值,其也可以使用后面定义的值。如:
foo = $(bar)
bar = aaa
all:
echo $(foo)
命令make all将打印出aaa。
“:=”为静态赋值,不能用在当前代码之前还未定义的变量。如:
foo := $(bar)
bar := aaa
all:
echo $(foo)
命令make all打印内容为空。
3)make: *** cur-dir: command not found 问题
以下代码会导致如题的出错信息。
all:
ifeq (0, ${MAKELEVEL})
cur-dir := $(shell pwd)
endif
原因: all之后的必须是可执行命令,不能定义变量。变量的定义可以放在all的前面。如:
ifeq (0, ${MAKELEVEL})
cur-dir := $(shell pwd)
endif
all:
...
也可以用define,如:
ifeq (0, ${MAKELEVEL})
define cur-dir
$(shell pwd)
endef
endif
all:
...
注意:endef前面用空格,不能用tab键,否则可能会报出找不到endef。