从一个makefile模板开始
简介
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+=$(wildcard ./*.cpp) $(wildcard ./include/nsp/*.cpp)
OBJS:=$(patsubst %.cpp,%.o,$(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/
$(TARGET): $(OBJS)
$(CC) $^ -o $@ $(LDFLAGS)
all:
$(TARGET)
.cpp.o:
$(CC) -c $< $(CPPFLAGS) $(INCLUDES) -o $@
.PHONY:clean all install
clean:
$(RM) $(OBJS) $(TARGET)

本文介绍了Makefile的基本结构,重点讲解了内置变量如$@、$^、$<和$?的用法,以及wildcard和patsubst的使用示例。通过一个具体的makefile实例展示了如何配置编译选项和依赖关系,包括清洁和安装规则。

被折叠的 条评论
为什么被折叠?



