我得到以下错误运行make:

Makefile:168: *** missing separator.  Stop.

是什么导致了这种情况?


当前回答

再补充一个出现这种情况的原因:

$(eval VALUE)

无效,将产生“缺少分隔符”错误。

$(eval IDENTIFIER=VALUE)

是可以接受的。当我用define定义宏并尝试执行时,出现了这种错误

define SOME_MACRO
... some expression ...
endef

VAR=$(eval $(call SOME_MACRO,arg))

宏没有计算为赋值。

其他回答

正如在线手册中所指出的,该错误最常见的原因是当make期望制表符时,行被空格缩进。

正确的

target: 
\tcmd

其中\t为TAB (U+0009)

错误的

target:
....cmd

每一个。表示空格(U+0020)。

再补充一个出现这种情况的原因:

$(eval VALUE)

无效,将产生“缺少分隔符”错误。

$(eval IDENTIFIER=VALUE)

是可以接受的。当我用define定义宏并尝试执行时,出现了这种错误

define SOME_MACRO
... some expression ...
endef

VAR=$(eval $(call SOME_MACRO,arg))

宏没有计算为赋值。

我的错误发生在具有多行扩展名的变量声明行上。我在“\”后面有一个尾随空格,这使得它是一个无效的行续。

MY_VAR = \
   val1 \ <-- 0x20 there caused the error.
   val2

只是为了笑一笑,以防别人遇到类似的错误:

我得到了臭名昭著的“缺少分隔符”错误,因为我调用了将函数定义为的规则

($eval $(call function,args))

而不是

$(eval $(call function,args))

即($而不是$(。

对我来说,问题是我有一些行将结束的#…注释嵌入在定义…结束多行变量定义。删除注释使问题消失了。