简介
makefile结构
关于makefile的结构,这个网上介绍的文章很多,就不重复了。需要的读者可以参考网上的文章。这里主要介绍几个重要的内置变量。
$@ 表示目标文件
$^ 表示所有的依赖文件
$< 表示第一个依赖文件
$? 表示比目标还要新的依赖文件列表
以及几个在makefile里用到的默认规则。
wildcard
# 扩展通配符 $(wildcard <PATTERN...>)
# 下面的例子中,$(wildcard ./*.cpp)的用法是
# 将所有的匹配.cpp文件列,展开成一个列表返回
patsubst
# 替换通配符 $(patsubst <PATTERN>,<DST>,<SRC>),将SRC用PATTERN替换成DST
# 下面的脚本例子中$(patsubst %.cpp,%.o,$(SRCS))的用法是
# 取$(SRC)中的内容,将所有的.cpp替换成.o
makefile实例
TARGET是最终编译后生成的发布目录,执行gmake/make
都可以。
# myprogram替换成实际的应用名称
TARGET:=./dist/myprogram
build=release
arch=x86_64
CC=g++
CPPFLAGS=-Wall -std=c++11
INCLUDES=-I./\
-I./include/rapidxml/\
-I./include/nsp/
SRCS+={
mathJaxContainer[1]}(wildcard ./include/nsp/*.cpp)
OBJS:={
mathJaxContainer[2]}(SRCS))
LDFLAGS+=-lm -lpthread -ldl -lrt
ifeq ($(build), debug)
CPPFLAGS+=-g
else
CPPFLAGS+=-O2
endif
LDFLAGS +=/usr/lib64/libpcap.so \
./lib/nshost.so.9.7.8 \
-Wl,-rpath=/usr/local/lib64/ -L /usr/local/lib64/
{
mathJaxContainer[3]}(OBJS)
{
mathJaxContainer[4]}^ -o {
mathJaxContainer[5]}(LDFLAGS)
all:
$(TARGET)
.cpp.o:
{
mathJaxContainer[6]}< {
mathJaxContainer[7]}(INCLUDES) -o $@
.PHONY:clean all install
clean:
{
mathJaxContainer[8]}(OBJS) $(TARGET)