【C基础知识】一个避免手写所有文件依赖关系的Makefile模板

【C基础知识】一个避免手写所有文件依赖关系的Makefile模板

背景

构建可执行程序的时候有很多种方法,包括CMake, make等工具。虽然makefile有比较固定的语法规范,但是很多人写makefile的习惯不太一样。有些人写makefile要把某个目录下的所有文件都写到makefile里,这样维护起来有点麻烦。下面给出一个makefile模板,适用于目录下的所有文件编译成一个可执行程序。由于makefile可以执行部分shell语句,所以模板经过改造也可以适用于编译一个库。

 

Makefile 代码

C__SOURCES := $(wildcard *.c)

CPP__SOURCES := $(wildcard *.cpp)

E_TARGET = socket_test

obj-y += $(C__SOURCES:%.c=%.o)

obj-y += $(CPP__SOURCES:%.cpp=%.o)

CC := gcc

CPP := g++

PREFIX_CC := $(CPP)

%.o: %.c
    $(CPP) -c -o $@ $<

all: $(E_TARGET)

$(E_TARGET): $(obj-y)

    $(PREFIX_CC) -o $@ $(filter $(obj-y), $^) $(LD_FLAGS) $(EXTRA_LDFLAGS)

 

.PHONY: clean

clean:

rm -rf $(E_TARGET) *.o

 

 

运行

假设该目录有main.cpp, depend.cpp depend.h, 修改Makefile的E_TARGET=depend_test

执行make 或make all即可得到depend_test

要清除生成文件,输入make clean

References:

[1] 无

posted @ 2019-06-12 15:10  stackupdown  阅读(481)  评论(0)    收藏  举报