(转)make的常见错误信息

news/2025/2/12 8:08:25/
(转)make的常见错误信息


make执行过程中所产生错误并不都是致命的;特别是在命令行之前存在“-”、或者make使用“-k”选项执行时。make执行过程的致命错误都带有前缀字符串“***”。

错误信息都有前缀,一种是执行程序名作为错误前缀(通常是“make”);另外一种是当Makefile本身存在语法错误无法被make解析并执行时,前缀包含了makefile文件名和出现错误的行号。

在下述的错误列表中,省略了普通前缀:

[FOO] Error NN

[FOO] signal description

这类错误并不是make的真正错误。它表示make检测到make所调用的作为执行命令的程序返回一个非零状态(Error NN),或者此命令程序以非正常方式退出(携带某种信号),参考 5.4 命令的错误 一节。

 

如果错误信息中没有附加“***”字符串,则是子过程的调用失败,如果Makefile中此命令有前缀“-”,make会忽略这个错误。

missing separator. Stop.

missing separator (did you mean TAB instead of 8 spaces?). Stop.

不可识别的命令行,make在读取Makefile过程中不能解析其中包含的内容。GNU make在读取Makefile时根据各种分隔符(:, =, [TAB]字符等)来识别Makefile的每一行内容。这些错误意味着make不能发现一个合法的分隔符。

 

出现这些错误信息的可能的原因是(或许是编辑器,绝大部分是ms-windows的编辑器)在Makefile中的命令之前使用了4个(或者8个)空格代替了[Tab]字符。这种情况,将产生上述的第二种形式产生错误信息。且记,所有的命令行都应该是以[Tab]字符开始的。

commands commence before first target. Stop.

missing rule before commands. Stop.

Makefile可能是以命令行开始:以[Tab]字符开始,但不是一个合法的命令行(例如,一个变量的赋值)。命令行必须和规则一一对应。

 

产生第二种的错误的原因可能是一行的第一个非空字符为分号,make会认为此处遗漏了规则的“target: prerequisite”部分。

No rule to make target `XXX'.

No rule to make target ` XXX ', needed by `yyy'.

无法为重建目标“XXX”找到合适的规则,包括明确规则和隐含规则。

 

修正这个错误的方法是:在Makefile中添加一个重建目标的规则。其它可能导致这些错误的原因是Makefile中文件名拼写错误,或者破坏了源文件树(一个文件不能被重建,可能是由于依赖文件的问题)。

No targets specified and no makefile found. Stop.

No targets. Stop.

第一个错误表示在命令行中没有指定需要重建的目标,并且make不能读入任何makefile文件。第二个错误表示能够找到makefile文件,但没有终极目标或者没有在命令行中指出需要重建的目标。这种情况下,make什么也不做。参考 第九章 执行make

Makefile `XXX' was not found.

Included makefile `XXX' was not found.

没有使用“-f”指定makefile文件,make不能在当前目录下找到默认Makefilemakefile或者GNUmakefile)。使用“-f”指定文件,但不能读取这个指定的makefile文件。

warning: overriding commands for target `XXX'

warning: ignoring old commands for target `XXX'

对同一目标“XXX”存在一个以上的重建命令。GNU make规定:当同一个文件作为多个规则的目标时,只能有一个规则定义重建它的命令(双冒号规则除外)。如果为一个目标多次指定了相同或者不同的命令,就会产生第一个告警;第二个告警信息说新指定的命令覆盖了上一次指定的命令。

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.

不正确的静态模式规则。

第一条错误的原因是:静态模式规则的目标段中没有模式目标;

第二条错误的原因是:静态模式规则的目标段中存在多个模式目标;

第三条错误的原因是:静态模式规则的目标段目标模式中没有包含模式字符“%”;

第四条错误的原因是:静态模式规则的三部分都包含了模式字符“%”。正确的应该是只有后两个才可以包含模式字符“%”。

关于静态模式规则可参考 4.12 静态模式 一节

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采用正常的算法来决定这些。当出现这种情况,子进程只会接受父进程传递的部分有用的信息。子进程会产生该警告信息,之后按照其内建的顺序方式进行处理。

 原文地址 http://www.linuxsir.org/main/doc/gnumake/GNUmake_v3.80-zh_CN_html/make-15.html
 

http://www.ppmy.cn/news/128977.html

相关文章

Android实验五-组件通信2

5.2、Intent对象 Intent是一种轻量级消息传递机制&#xff0c;旨在解决各项组件之间的通信问题。它描述了应用中一次操作的动作、动作涉及数据、附加数据&#xff0c;Android则根据此描述&#xff0c;负责找到对应的组件&#xff0c;将 Intent传递给调用的组件&#xff0c;并完…

金刚石切割丝的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告

本文研究全球与中国市场金刚石切割丝的发展现状及未来发展趋势&#xff0c;分别从生产和消费的角度分析金刚石切割丝的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品规格、不同规格产品的价格、产量、产值及全球和中国市场主要…

动词的时态(Les temps du verbe )

在开始讲解直陈式现在时的主要用法之前,我们有必要先搞清楚两个基本概念:▶语式(mode):语式是动词表达动作的方式。一个动作,可以作为实在的事表达出来,也可以作为希望或单纯设想的事表达出来,法语动词共有六种语式:直陈式,命令式,条件式,虚拟式,分词式和不定式。…

提高情商 倾听能力

父文章 表达 ,情感描写 沟通 工具书_个人渣记录仅为自己搜索用的博客-CSDN博客 让 chatgpt推荐的 1. 心理学倾听教程 2. 表达 - 比喻 具象 ,有画面感 https://blog.csdn.net/fei33423/article/details/129131137 小说&#xff1a; 1.《呼啸山庄》&#xff08;Wuthering He…

表达 ,情感描写 沟通 工具书

父文章 人人都是xx_个人渣记录仅为自己搜索用的博客-CSDN博客 相关 如何表达,写好文章,技术文章,论文_如何写好技术文章_个人渣记录仅为自己搜索用的博客-CSDN博客 人人都是总结大师_fei33423 人人都是_个人渣记录仅为自己搜索用的博客-CSDN博客 提高情商 倾听能力_个人渣记录…

结合结构特征基于测试集重排序的故障诊断方法

摘要 故障诊断是集成电路领域中的重要研究方向,基于测试激励集方法求解候选故障诊断是目前较为高效的诊断方法,而GTreord是目前具有较高诊断准确性的方法.在对GTreord方法深入研究的基础上,本文依据测试激励与候选故障诊断解之间的结构特征,通过分析电路故障输出响应,提出…

Star-GAN阅读笔记

Star-GAN阅读笔记 SummaryContributionRelated WorkApproach and Model ArchitectureImplementExperimentsCode Summary 之前传统的GAN只能在两个域之间做图像转换(例如Cycle-GAN)&#xff0c;如果要在多个域之间做图像转换&#xff0c;则需要N(N-1)对生成器/鉴别器。然而Star…

【paper and code】StarGAN

文章下载链接&#xff1a;https://arxiv.org/abs/1711.09020 代码链接&#xff1a;https://github.com/yunjey/StarGAN 一、这篇文章讲了什么&#xff1f; Pix2Pix模型解决了有Pair对数据的图像翻译问题&#xff1b;CycleGAN解决了Unpaired数据下的图像翻译问题。 但无论是Pi…