GNU Make无法检测到明显的规则

问题描述 投票:1回答:1

出于某种原因,我从来没有掌握现代编程方法。作为一个68k汇编程序员,我正在尝试使用单个树文件来关闭最终文件的所有内容,而是遵循更典型的“构建/链接对象”方案。但是,我花了4天的时间试图找到合理的解释并解决这个问题。

我正在尝试自动检测并构建某个文件夹中的每个文件,其文件夹被打包到一个特定的对象中,该对象将其他特定的对象链接在一起。

这是makefile:https://pastebin.com/H6QE29fj

CUR = $(SRC)\lib
VPATH = $(OBJ) $(CUR)
INPUT = $(notdir $(wildcard $(CUR:\=/)/*))
$(OBJ)\library.md.o: $(INPUT:.asm=.o)
    $(VLINK) -r -o $@ $(addprefix $(OBJ)\,$(notdir $^))

问题出在上面。几天前,我使用相同的代码片段从$(SRC)\ ints文件夹生成$(OBJ)\ ints.md.o。完全没有问题,我甚至在使用$(INPUT)变量之前手动添加了一个文件名,因此它在SECTION(引擎shenanigans)的开头组装。

如果所述代码“有效”,为什么它对图书馆不起作用?

make: *** No rule to make target `loadtilemap.o', needed by `.\src\__obj\library.md.o'.  Stop.

使用%.o:%。asm规则不应该足够吗?

makefile gnu-make
1个回答
3
投票

首先,我建议您在使用makefile中的路径时始终使用正斜杠而不是反斜杠。几乎所有Windows命令都将接受路径中的任一样式。如果需要调用不接受正斜杠作为路径分隔符的命令,请在需要它的配方内进行转换。 make是一个UNIX / POSIX工具,因此它通常使用目录分隔符和反斜杠的正斜杠作为转义序列。在针对Windows编译时,DTRT会针对反斜杠做出一些努力,但它可能无法在任何地方使用。只需使用正斜杠,然后转到其他东西。

这是makefile的提示:

%.o: %.asm
        $(V68k) $(BUILDARGS) -L $(LST)\$(notdir $(basename $@)).txt -o $(OBJ)\$@ $<

除了$@之外,创建文件的目标(几乎)永远不会正确。这是我的Second Rule of Makefiles。每当你看到构建一个不仅仅是普通$@的文件的规则时,你就知道存在问题。想要建立一个目标。它知道它想要构建什么目标,并且它将该目标的路径放在$@变量中。如果你在你的食谱中觉得有必要创建一个不完全是$@的文件,那么你就知道你并且对基本的东西不同意,并且不同意make不会给你想要的结果:)。

如果要在与源不同的目录中创建文件,则该目录必须包含在规则中:

$(OBJ)/%.o: %.asm
        $(V68k) $(BUILDARGS) -L $(LST)\$(notdir $(basename $@)).txt -o $@ $<

这也意味着您的链接配方:

$(OBJ)\library.md.o: $(INPUT:.asm=.o)
        $(VLINK) -r -o $@ $(addprefix $(OBJ)\,$(notdir $^))

不行。为什么?因为先决条件不包括目录。您需要将其更改为:

$(OBJ)\library.md.o: $(INPUT:%.asm=$(OBJ)/%.o)
        $(VLINK) -r -o $@ $^

您可能认为将$(OBJ)添加到VPATH将有助于解决这个问题,但事实并非如此。这不是VPATH的设计工作方式; VPATH只能用于搜索源文件,从不生成像目标文件这样的文件。原因很复杂但如果你想要的细节有一个detailed explanation here

© www.soinside.com 2019 - 2024. All rights reserved.