使用makefile编译头依赖项

我正在用C编程语言编写UDP客户端服务器应用程序;我希望每当依赖项发生变化时自动编译2个源文件和3个头文件,所以我决定使用make实用程序.

makefile目标称为“编辑”:

    edit : server_UDP.o  client_UDP.o \
            gcc -o edit server_UDP.o  client_UDP.o \


    client_UDP.o : client_UDP.c cliHeader_UDP.h  wrapHeader.h
            gcc -c client_UDP.c

    server_UDP.o : server_UDP.c servHeader_UDP.h  wrapHeader.h
            gcc -c  server_UDP.c

当我在wrapHeader.h中更改几行代码时,它不会触发重新编译.

当wrapHeader.h发生更改以重新编译server_UDP和client_UDP时,如何修改编辑makefile规则?

**注意:wrapHeader.h是主标题

cliHeader_UDP.h:包含“wrapHeader.h”

servHeader_UDP.h:包含“wrapHeader.h”

最佳答案 我想你想要的是Make依赖文件.

您可以使用’-MMD -MP’参数指定编译器为您生成依赖文件,该参数创建一个与源文件同名的新文件,但扩展名为* .d,与源文件夹在同一文件夹中.

依赖项文件包含代码所依赖的所有头文件,如果修改了它使用的头文件,这将导致GNU make编译源文件.

启用makefile的示例依赖项文件:

# Makefile

CC   := gcc
LD   := g++

# The output executable.
BIN   := program

# Toolchain arguments.
CFLAGS    := 
CXXFLAGS  := $(CFLAGS)
LDFLAGS   := 

# Project sources.
C_SOURCE_FILES := mysourcefile1.c src/myothersrc.c
C_OBJECT_FILES := $(patsubst %.c,%.o,$(C_SOURCE_FILES))

# The dependency file names.
DEPS := $(C_OBJECT_FILES:.o=.d)

all: $(BIN)

clean:
    $(RM) $(C_OBJECT_FILES) $(DEPS) $(BIN)

rebuild: clean all

$(BIN): $(C_OBJECT_FILES)
    $(LD) $(C_OBJECT_FILES) $(LDFLAGS) -o $@

%.o: %.c
    $(CC) -c -MMD -MP $< -o $@ $(CFLAGS)

# Let make read the dependency files and handle them.
-include $(DEPS)

这应该适合您的情况:

SOURCES := server_UDP.c client_UDP.c
OBJECTS := $(patsubst %.c,%.o,$(SOURCES))

DEPS := $(OBJECTS:.o=.d)

edit: $(OBJECTS)
    gcc -o edit $(OBJECTS)

%.o: %.c
    gcc -c $< -o $@

-include $(DEPS)
点赞