我得到以下错误运行make:
Makefile:168: *** missing separator. Stop.
是什么导致了这种情况?
我得到以下错误运行make:
Makefile:168: *** missing separator. Stop.
是什么导致了这种情况?
当前回答
在我的例子中,错误导致了下一个。我尝试全局执行命令,即在任何目标之外。
乌利希期刊指南。要在全局运行命令,必须正确地构造一个命令。例如命令
ln -sf ../../user/curl/$SRC_NAME ./$SRC_NAME
将成为:
$(shell ln -sf ../../user/curl/$(SRC_NAME) ./$(SRC_NAME))
其他回答
在我的例子中,我实际上在ifeq和下一行的命令之间缺少了一个制表符。一开始就没有空间。
ifeq ($(wildcard $DIR_FILE), )
cd $FOLDER; cp -f $DIR_FILE.tpl $DIR_FILE.xs;
endif
本来应该是:
ifeq ($(wildcard $DIR_FILE), )
<tab>cd $FOLDER; cp -f $DIR_FILE.tpl $DIR_FILE.xs;
endif
注意<tab>是一个实际的制表符
正如在线手册中所指出的,该错误最常见的原因是当make期望制表符时,行被空格缩进。
正确的
target:
\tcmd
其中\t为TAB (U+0009)
错误的
target:
....cmd
每一个。表示空格(U+0020)。
这是Makefile中的语法错误。如果没有看到文件本身或其中的相关部分,就很难更具体。
在我的例子中,错误导致了下一个。我尝试全局执行命令,即在任何目标之外。
乌利希期刊指南。要在全局运行命令,必须正确地构造一个命令。例如命令
ln -sf ../../user/curl/$SRC_NAME ./$SRC_NAME
将成为:
$(shell ln -sf ../../user/curl/$(SRC_NAME) ./$(SRC_NAME))
只是为了笑一笑,以防别人遇到类似的错误:
我得到了臭名昭著的“缺少分隔符”错误,因为我调用了将函数定义为的规则
($eval $(call function,args))
而不是
$(eval $(call function,args))
即($而不是$(。