我得到以下错误运行make:

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

是什么导致了这种情况?


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

正确的

target: 
\tcmd

其中\t为TAB (U+0009)

错误的

target:
....cmd

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


这是Makefile中的语法错误。如果没有看到文件本身或其中的相关部分,就很难更具体。


以下Makefile代码工作:

obj-m = hello.o

all:
    $(MAKE) -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules 

clean:
    $(MAKE) -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean

在我的例子中,错误导致了下一个。我尝试全局执行命令,即在任何目标之外。

乌利希期刊指南。要在全局运行命令,必须正确地构造一个命令。例如命令

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))

即($而不是$(。


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


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

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

在我的例子中,这个错误是由于缺乏空间造成的。我在我的makefile中有这个if块:

if($(METHOD),opt)
CFLAGS=
endif

应该是:

if ($(METHOD),opt)
CFLAGS=
endif

if后面加一个空格。


因此,显然,我所需要的是“构建必要”包,然后首先运行autoconf,这使得Makefile.pre。In,然后是。/configure,然后是make。


在我的例子中,同样的错误是由于冒号:在结束时丢失了stage .deploy:。所以请注意,这可能是一个简单的语法错误。


我在qmake生成的Makefiles中丢失了分隔符文件。我把Qt代码移植到一个不同的平台。我没有QMAKESPEC或MAKE集。这是我找到答案的链接:

https://forum.qt.io/topic/3783/missing-separator-error-in-makefile/5


在我的例子中,我实际上在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>是一个实际的制表符


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

$(eval VALUE)

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

$(eval IDENTIFIER=VALUE)

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

define SOME_MACRO
... some expression ...
endef

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

宏没有计算为赋值。


这是因为在PHONY后面没有冒号

不是这个,

.PHONY install
install:
    install -m0755 bin/ytdl-clean /usr/local/bin

但是这个(注意冒号)

.PHONY: install
...