我被要求编写一个 Makefile,需要在两个编译器之间进行选择,并且每个编译器都应该支持 3 个构建版本(调试、发布、测试)。
有很多变量会根据输入(编译器、编译器选项、输出目录、包含目录等)而变化。我的第一个选择是浏览特定于目标的变量并根据目标配置变量。你认为这是个好主意吗?
我对这类变量不是很熟悉。在我看来,如果我做这样的事情:
release: variable1=value1 #release is target
release: variable2=value2
release:
# some compilation rule
仅配置
variable1
。我的说法对吗?
谢谢您的回复。我正在尝试通过根据目标配置的附加变量来处理编译器选择问题。但是,问题就在这里。我有以下几行:
release: CFLAGS = -DCORE_SW_VERSION='"$(CORE_SW_VERSION)"' -Wall
release: CFLAGS += -fgnu89-inline -mno-volatile-cache $(INCLUDE)
release: TARGET=release
在这行之后,我执行一些
ifeq
序列,在其中决定使用哪个编译器(根据 TARGET 变量值)。
CFLAGS 配置正确,但 TARGET 变量为空。这使我得出结论:您只能配置一个特定于目标的变量。我说得对吗?如果没有,我不知道我做错了什么。你能帮我吗?
特定于目标的变量仅在构建该目标以及该目标的任何先决条件时定义。您不能在整个 makefile 中任意使用特定于目标的变量(因为听起来您正在尝试使用
ifeq
来做)。为此,您可能需要查看$(MAKECMDGOALS)
。我不认为目标特定变量的数量有任何限制,当然不是一个限制。
需要特定于目标的变量或
$(MAKECMDGOALS)
可能是一个警告,表明您正在尝试强制 make 做一些它不应该做的事情。
我不清楚您是否想要构建三个版本(每个版本使用一个编译器进行调试/测试/发布),还是六个版本。假设有三个,这是一个 unix-y Makefile,根据目标使用不同的编译器和 CFLAGS 进行构建。但是,请注意,这可以很容易地使用
RELEASE_CFLAGS
、RELEASE_CC
、DEBUG_CFLAGS
等变量进行编码。
all: release debug test
release: CC=gcc
release: CFLAGS=
debug: CC=gcc
debug: CFLAGS=-g
test: CC=cc
test: CFLAGS=-Wall
.PHONY: release debug test
release: release/exe
debug: debug/exe
test: test/exe
OBJECTS := test.o
release/%.o: %.c
$(CC) $(CLFAGS) -c -o $@ $<
debug/%.o: %.c
$(CC) $(CLFAGS) -c -o $@ $<
test/%.o: %.c
$(CC) $(CLFAGS) -c -o $@ $<
release/exe: $(OBJECTS:%=release/%)
$(CC) $(CFLAGS) -o $@ $^
debug/exe: $(OBJECTS:%=debug/%)
$(CC) $(CFLAGS) -o $@ $^
test/exe: $(OBJECTS:%=test/%)
$(CC) $(CFLAGS) -o $@ $^