gpt4 book ai didi

makefile - 在makefile中获取没有扩展名的文件名

转载 作者:行者123 更新时间:2023-12-04 02:19:13 26 4
gpt4 key购买 nike

我的 生成文件 看起来像这样:

SRCS    = $(wildcard *.asm)
OBJS = ${SRCS:.asm=.o}

# define a suffix rule for .asm -> .o
.asm.o : $(SRCS)
nasm -f elf $<

all: $(OBJS)
gcc -o ?? $<
^need the name of the target without file extension here ($* is blank)

然而, $*正在 .asm.o 内工作但在 all内为空白.
我将如何将 gcc 输出文件名设置为 的文件名目标文件 没有任何扩展?

比如我想让它执行如下(在nasm生成.o文件之后)
gcc filename filename.o

最佳答案

我想你正在寻找

.PHONY: all
all: $(patsubst %.o,%,$(OBJS))
%: %.o
gcc -o $@ $<

您的尝试将定义一个目标 all它依赖于所有目标文件,就好像它包含所有目标文件一样;我想你真的希望每个目标文件都是独立的,对于 all目标依赖于它们的全部制作。

(从技术上讲,您现在可以使用 $* 因为在这种情况下它与 $@ 相同,但这只是模糊的。)

这基本上与您现有的 nasm 同构规则,除非没有后缀,否则不能使用后缀语法。换句话说,你的规则相当于
OBJS = $(patsubst %.asm,%.o,$(SRCS))
%.o: %.asm
nasm -f elf $<

唯一剩下的区别是 .PHONY仅记录 all 的声明不是文件名。

关于makefile - 在makefile中获取没有扩展名的文件名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13995906/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com