Makefile中常见的错误信息
在下述的错误列表中,省略了普通前缀:
[FOO] Error NN
[FOO] signal description
如果错误信息中没有附加 "***" 字符串,则是子过程的调用失败,如果 Makefile 中此命令有前缀 "-",make 会忽略这个错误。
missing separator. Stop.
missing separator (did you mean TAB instead of 8 spaces?). Stop.
出现这些错误信息的可能的原因是(或许是编辑器,绝大部分是ms- windows的编辑器)在 Makefile 中的命令之前使用了4个(或者8个)空格代替了 [Tab] 字符。这种情况,将产生上述的第二种形式产生错误信息。且记,所有的命令行都应该是以 [Tab] 字符开始的。
commands commence before first target. Stop.
missing rule before commands. Stop.
产生第二种的错误的原因可能是一行的第一个非空字符为分号,make 会认为此处遗漏了规则的 "target: prerequisite" 部分。
No rule to make target 'XXX'.
No rule to make target 'XXX ', needed by 'yyy'.
修正这个错误的方法是:在 Makefile 中添加一个重建目标的规则。其它可能导致这些错误的原因是 Makefile 中文件名拼写错误,或者破坏了源文件树(一个文件不能被重建,可能是由于依赖文件的问题)。
No targets specified and no makefile found. Stop.
No targets. Stop.
Makefile 'XXX' was not found.
Included makefile 'XXX' was not found.
warning: overriding commands for target 'XXX'
warning: ignoring old commands for target 'XXX'
Circular XXX <- YYY dependency dropped.
规则的依赖关系产生了循环:目标 "XXX" 的依赖文件为 "YYY",而依赖 "YYY" 的依赖列表中又包含 "XXX"。Recursive variable 'XXX' references itself (eventually). Stop.
make 的变量 "XXX"(递归展开式)在替换展开时,引用它自身。无论对于直接展开式变量(通过:=定义的)或追加定义(+=),这都是不允许的。Unterminated variable reference. Stop.
变量或者函数引用语法不正确,没有使用完整的的括号(缺少左括号或者右括号)。insufficient arguments to function 'XXX'. Stop.
函数 "XXX" 引用时参数数目不正确。函数缺少参数。
missing target pattern. Stop.
multiple target patterns. Stop.
target pattern contains no '%'. Stop.
mixed implicit and static pattern rules. Stop.
第一条错误的原因是:静态模式规则的目标段中没有模式目标;
第二条错误的原因是:静态模式规则的目标段中存在多个模式目标;
第三条错误的原因是:静态模式规则的目标段目标模式中没有包含模式字符“%”;
第四条错误的原因是:静态模式规则的三部分都包含了模式字符“%”。正确的应该是只有后两个才可以包含模式字符“%”。
warning: -jN forced in submake: disabling jobserver mode.
这一条告警和下条告警信息发生在:make 检测到递归的 make 调用时,可通信的子 make 进程出现并行处理的错误。递归执行的 make 的命令行参数中存在 "-jN" 参数(N的值大于1),在有些情况下可能导致此错误,例如:Makefile 中变量 "MAKE" 被赋值为 "make –j2",并且递归调用的命令行中使用变量 "MAKE"。在这种情况下,被调用 make 进程不能和其它 make 进程进行通信,其只能简单的独立的并行处理两个任务”。warning: jobserver unavailable: using -j1. Add '+' to parent make rule.
为了现实 make 进程之间的通信,上层 make 进程将传递信息给子 make 进程。在传递信息过程中可能存在这种情况,子 make 进程不是一个实际的 make 进程,而上层make却不能确定子进程是否是真实的 make 进程。它只是将所有信息传递下去。上层 make 采用正常的算法来决定这些。当出现这种情况,子进程只会接受父进程传递的部分有用的信息。子进程会产生该警告信息,之后按照其内建的顺序方式进行处理。所有教程
- C语言入门
- C语言编译器
- C语言项目案例
- 数据结构
- C++
- STL
- C++11
- socket
- GCC
- GDB
- Makefile
- OpenCV
- Qt教程
- Unity 3D
- UE4
- 游戏引擎
- Python
- Python并发编程
- TensorFlow
- Django
- NumPy
- Linux
- Shell
- Java教程
- 设计模式
- Java Swing
- Servlet
- JSP教程
- Struts2
- Maven
- Spring
- Spring MVC
- Spring Boot
- Spring Cloud
- Hibernate
- Mybatis
- MySQL教程
- MySQL函数
- NoSQL
- Redis
- MongoDB
- HBase
- Go语言
- C#
- MATLAB
- JavaScript
- Bootstrap
- HTML
- CSS教程
- PHP
- 汇编语言
- TCP/IP
- vi命令
- Android教程
- 区块链
- Docker
- 大数据
- 云计算