Linux的热爱者
分类: LINUX
2013-05-03 11:13:08
Makefile 学习笔记--记录用来忘记的东东
Makefile总是一边学一边忘,好记性不如烂笔头,这次把遇到的东东全都写下来,下次再用到的时候直接查就是了。
1. Makefile $@, $^, $< 这三个自动化变量老是忘,先记下来
$@ 表示目标文件
$^ 表示所有的依赖文件
$< 表示第一个依赖文件
$? 表示比目标还要新的依赖文件列表
2. Makefile 中添加调试信息
执行到error时会中断,warning不中断makefile的执行, info不打印当前makefile名和行号。 用法:$(warning "some text")
3. -include 与include的区别
include rules.mk 当rules.mk不存在时,"Makefile:1: rules.mk: No such file or directory", 当使用-include时,继续执行不会报错而停止。
补充:- 在每一个命令前加上-, 会忽略出错,不打断执行流程。最典型的例子是:
-rm 1.o 2.o 3.o, 当1.o找不到时不会中止Makefile的执行流程,继续往下执行。
4. @echo 与 echo的区别
在要执行语句前加@不会打印该语句,如:echo "some text"和 @echo "some text"分别会打印:echo "some text" some text 和 some text
5. ifeq判断字符串为空
类似于 ifeq ($(VAL),) 当VAL为空时条件成立
6. filter 与 filter-out
objects=main1.o foo.o bar.o main2.o mains=main1.o main2.o
$(filter-out $(mains), $(objects)) 值为 foo.o bar.o
$(filter-out $(mains), $(objects)) 值为 main1.o main2.o
7. FORCE每次都更新目标,测试Makefile如下
all: hello
hello: hello.c
gcc -g -o hello hello.c
FORCE:
.PHONY: FORCE
每次make时都会重新生成一次hello. 否则会打印make: Nothing to be done for `all'