Makefile编译

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中的内容为:

参考文档

Makefile教程

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值