考虑这个简单的规则:
foo.o: foo.c foo.d
gcc -c ...
foo.d: foo.c
gcc -M ...
现在,如果 foo.d 和 foo.o 都比 foo.c 新 - foo.o 的配方将不会被执行。
但是, foo.c 中包含的头文件之一可能已更改,因此我确实需要运行该配方。
所以问题是如何告诉 make 如果 foo.d 中列出的文件之一比 foo.o 新,那么它必须运行 foo.o 的配方?
谢谢。
考虑这个简单的规则:
foo.o: foo.c foo.d
gcc -c ...
foo.d: foo.c
gcc -M ...
现在,如果 foo.d 和 foo.o 都比 foo.c 新 - foo.o 的配方将不会被执行。
但是, foo.c 中包含的头文件之一可能已更改,因此我确实需要运行该配方。
所以问题是如何告诉 make 如果 foo.d 中列出的文件之一比 foo.o 新,那么它必须运行 foo.o 的配方?
谢谢。
依赖文件的重点不是它们是目标先决条件,而是它们使用正确的依赖关系完成您的目标。它们实际上需要包含在您的 Makefile 中。
这是一个基本示例:
SRC = foo.c main.c
OBJ = $(SRC:.c=.o)
DEPS = $(SRC:.c=.d)
-include $(DEPS)
all: myapp.o
myapp.o: foo.o main.o
gcc -c main.o foo.o -o myapp.o
main.o: main.c
gcc -M ...
foo.o: foo.c
gcc -M ...
.PHONY: all
现在发生的情况是 $(DEPS) 中每个文件的内容将被复制粘贴到您的 Makefile 中。由于main.c
可能使用foo.c
并因此包含foo.h
,因此main.d
如下所示:
main.o: \
foo.c \
foo.h
如果我们在 Makefile 中应用包含,这就是 GNU make 最终会分析的内容:
SRC = foo.c main.c
OBJ = $(SRC:.c=.o)
DEPS = $(SRC:.c=.d)
-include $(DEPS)
all: myapp.o
myapp.o: foo.o main.o
gcc -c main.o foo.o -o myapp.o
main.o: main.c foo.c foo.h
gcc -M ...
foo.o: foo.c
gcc -M ...
.PHONY: all
观察 foo.c 和 foo.h 现在如何成为 main.o 的先决条件。这意味着如果其中任何一个发生更改,则必须重建 main.o。