总结一个简单的makefile模板,以备不时之需。
关键字说明
-Wl关键字
-Wl,-Bstatic这两个参数一起使用就是告诉ld后面是静态链接
-Wl,-Bdynamic这两个参数一起使用告诉ld后面是动态链接
在man手册中说,如果有必要,这两个参数组合可以写多次,告诉链接器对于不同的库采用不同的方法处理。
makefile常用关键字
- wildcard: 扩展通配符
- patsubst : 替换通配符
- notdir: 去除路径
例子:
建立如下目录
在test下,建立a.c和b.c2个文件,在sub目录下,建立sa.c和sb.c2 个文件
建立一个简单的Makefile
src=$(wildcard *.c ./sub/*.c)
dir=$(notdir $(src) )
obj=$(patsubst %.c,%.o,$(dir) )
all:
@echo $(src)
@echo $(dir)
@echo $(obj)
@echo "end"
执行结果:
执行结果分析:
第一行输出:
a.c b.c ./sub/sa.c ./sub/sb.c
wildcard把 指定目录 ./ 和 ./sub/ 下的所有后缀是c的文件全部展开。
第二行输出:
a.c b.c sa.c sb.c
notdir把展开的文件去除掉路径信息
第三行输出:
a.o b.o sa.o sb.o
在
(
p
a
t
s
u
b
s
t
(patsubst %.c,%.o,
(patsubst(dir) )中,patsubst把
(
d
i
r
)
中
的
变
量
符
合
后
缀
是
.
c
的
全
部
替
换
成
.
o
,
任
何
输
出
。
或
者
可
以
使
用
o
b
j
=
(dir)中的变量符合后缀是.c的全部替换成.o, 任何输出。 或者可以使用 obj=
(dir)中的变量符合后缀是.c的全部替换成.o,任何输出。或者可以使用obj=(dir:%.c=%.o)
效果也是一样的。
这里用到makefile里的替换引用规则,即用您指定的变量替换另一个变量。
它的标准格式是
$(var:a=b) 或 ${var:a=b}
它的含义是把变量var中的每一个值结尾用b替换掉a
#设置编译选项
CC = gcc
INC =
LIB = -lpthread
CFLAGS = -g -D_REENTRANT -Wall
#源文件
SOURCES = $(wildcard *.c src/*.c) #列出当前目录下所有.c文件
@echo $(SOURCES)
#目标依赖文件.o
OBJS = $(patsubst %.c,%.o,$(SOURCES))
#目标文件
TARGET = wxmtest
%.o:%.c
$(CC) $(CFLAGS) $(INC) $(LIB) -c $< -o $@
$(TARGET):$(OBJS)
$(CC) $(CFLAGS) $(INC) $(LIB) $(OBJS) -o $(TARGET)
.PHONY: clean
clean:
rm -rf *.o $(OBJS) $(TARGET)
引用块内容