【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] 无

浙公网安备 33010602011771号