Makefile missing separator. Stop.怎么解决
2016年08月17日 15:30:04 limanjihe 阅读数:31526更多
个人分类: Linux系统与服务器配置
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/limanjihe/article/details/52231243
现象:
在makefile中写入:
all: clean comp
clean:
./clean.csh
comp:
./run_tc
命令行的背景显示为红色。
运行makefile 提示:makefile 3 missing separator.stop:
检查了一番发现,有几个原因会引起这样的结果:
第一:makefile的命令行,开头必须用tab键,目前没有发现tabstop的设定值的不同,会引起error。例如:
set tabstop=3(默认) OR set tabstop=4等,均可以。
第二:编码方式引起的原因。这个原因不多见,不容易发现。查看/etc/vimrc文件以及~/.vimrc,查看是否有set fileencodings的选项,是否设定了utf-8。没有的话加上。
扩展
Makefile missing separator. Stop.如何解决
Makefile:1: *** missing separator. Stop.
makefile 如下
makefile missing?separator? stop makefile常见错误
[解决办法]
这个makefile里不要乱用TAB,只有命令所在的行才能且只能以TAB开头!
其他的如,make变量的定义、赋值,make内定函数如
(
e
r
r
o
r
"
s
t
r
i
n
g
s
"
)
都
不
能
以
T
A
B
开
头
,
不
然
m
a
k
e
会
将
其
作
为
命
令
来
处
理
!
[
解
决
办
法
]
1.
第
一
行
i
f
n
e
p
这
个
符
号
是
做
什
么
的
?
大
概
是
i
f
n
e
q
吧
?
2.
很
多
地
方
你
打
的
是
空
格
,
你
最
好
尝
试
习
惯
去
用
t
a
b
键
3.
第
八
行
和
第
十
行
必
须
用
t
a
b
开
头
i
f
n
e
q
(
(error "strings")都不能以TAB开头,不然make会将其作为命令来处理! [解决办法] 1.第一行ifnep这个符号是做什么的?大概是ifneq吧? 2.很多地方你打的是空格,你最好尝试习惯去用tab键 3.第八行和第十行必须用tab开头 ifneq (
(error"strings")都不能以TAB开头,不然make会将其作为命令来处理![解决办法]1.第一行ifnep这个符号是做什么的?大概是ifneq吧?2.很多地方你打的是空格,你最好尝试习惯去用tab键3.第八行和第十行必须用tab开头ifneq((KERNELRELEASE),)
obj-m += module.o
else
PWD := $(shell pwd)
KVER :=
(
s
h
e
l
l
u
n
a
m
e
−
r
)
K
D
I
R
:
=
/
l
i
b
/
m
o
d
u
l
e
s
/
(shell uname -r) KDIR := /lib/modules/
(shelluname−r)KDIR:=/lib/modules/(KVER)/build
all:
$(MAKE) -C $(KDIR) M= $(PWD)
clean:
rm -rf *.o *.mod.c *.ko *.symvers *.order *.makers
endif
[解决办法]
如果排除了TAB用空格代替的问题后、以及由中文“:”等问题后,问题还存在
那么很可能是文件编码格式的问题
查看一下Makefile 文件编码格式是不是utf-8的,还带有BOM标记在文件头
$ xxd -l 16 Makefile
0000000: efbb bf61 6c6c 3a0a 2020 6563 686f 2068 …all:.
去掉红色字体部分就OK了