Makefile规则
如下图target为需要生成的目标,prerequisites为依赖项,command为make需要执行的命令(任意的Shell命令),command前必须以tab键开始。
target:prerequisites
command
(1)Makefile中内置变量 $@、$^、$<、$? 。
$@: 表示目标文件
$<: 表示第一个依赖文件
$^: 表示所有的依赖文件
$?: 表示比目标还要新的依赖文件列表
(2)wildcard、notdir、patsubst均是Makefile内置函数,各含义如下:
wildcard:扩展通配符
notdir:去除路径
patsubst:替换通配符
(3)Makefile的规则通配符%,用于规则描述,一般用于目标文件的生成
DIR_INC = ./include
DIR_SRC = ./src
DIR_OBJ = ./obj
DIR_BIN = ./
VERSION := $(shell git describe --always --long --dirty)
SRC = $(wildcard ${DIR_SRC}/*.c)
OBJ = $(patsubst %.c,${DIR_OBJ}/%.o,$(notdir ${SRC}))
TARGET = xxxx
BIN_TARGET = ${DIR_BIN}/${TARGET}
CC = gcc
CFLAGS = -DVERSION=\"$(VERSION)\" -D_FILE_OFFSET_BITS=64 -I $(DIR_INC) -lm -Wall
${BIN_TARGET}:${OBJ}
$(CC) $(OBJ) -o $(TARGET) $(CFLAGS)
${DIR_OBJ}/%.o:${DIR_SRC}/%.c
$(CC) -c $< -o $@ $(CFLAGS)
.PHONY:clean
clean:
rm -rf $(DIR_OBJ)/*.o $(TARGET)
wildcard用法
src=$(wildcard *.c ./sub/*.c)
dir=$(notdir $(src))
obj=$(patsubst %.c,%.o,$(dir) )
wildcard把 指定目录 ./ 和 ./sub/ 下的所有后缀是c的文件全部展开。
notdir把展开的文件去除掉路径信息。
在$(patsubst %.c,%.o,$(dir) )中,patsubst把$(dir)中的变量符合后缀是.c的全部替换成.o,
@ 这个符串通常用在“规则”行中,表示不显示命令本身,而只显示它的结果,例如Makefile中的内容为:
参考文档