1.常用参数:
-f : 指定makefile的名称,这样,就可以不用makefile做为规则文件的名字了。
-i : 使make程序忽略运行时的错误,继续运行。
-C: 指定目录运行make ; make -C dir
-j: 多线程编译 -j 8
-I dir, --include-dir=dir 指定一个目录作为make.include的头文件
-n 不执行make,但是打印所有命令行, 即时使用了 @ 在命令前
-p 打印当前 环境下 包含自定义的 所有规则 信息,可以用于debug
-s silence mode
-t make touch it
2. 语法
$@: 规则中的目标名
$<: 规则中的依赖项目,只代表规则所有依赖项目中的<第一项>!$^: 规则中所有的依赖项目。
$?: 规则中时间新于目标的依赖项目
函数:
abc -> abc.o -> dir/abc.o
$(addprefix $(DIR), $(addsuffix .o, $(SRC)))
对于一些操作,也可以预定义好,在使用的地方直接引用
DO_CLEAN = $(RM) -frv $(TARGET_BIN) $(OBJS)
makefile:
clean:
$(DO_CLEAN)
默认规则摘要:
1. *.c ==> * 直接将.c 编译成exe
%: %.c | 431 # commands to execute (built-in):
# commands to execute (built-in): | 432 $(TEX) $<
$(LINK.c) $^ $(LOADLIBES) $(LDLIBS) -o $@
应用: 只有一个源文件时:
all: src_file_no_suffix
clean:
$(RM) -rfv src_file_no_suffix *.o
2. %.c ==> %.o
编译器: C
编译选项 CFLAGS
3. %.cc ==> %.o
4. %.cpp ==> %.o
编译器: CXX
编译选项 CXXFLAGS CPPFLAGS
new_in:
1. define 操作
类似于宏, 可以放在include的地方,做一些执行类的操作
一般的执行类操作只能放在 标号所在位置
define macro_ok
[tab] echo "OK"
[tab] echo $1
endef
使用 call 函数来调用 define
$(call macro_ok, arg1, arg2)
2. MAKEFILE_LIST
现在已经载入的所有 文件, 第一个就是自己, 后续都是include出来的文件名称
3. abspath
4. filter && filter-out
$(filter-out $(MK_SELF), $(MAKEFILE_LIST)
把 MK_SELF从 MAKEFILE_LIST中删除掉
5. firstword, lastword
获取列表中的 第一个,或者最后一个字符
6. ifreq ifudef ifdef
6.1 ifudef str
endif
as
if( str == "undefined")
6.2 ifreq ($str, "hello")
VAR=....
all:
ops
endif
7. shell 获取 文件绝对路径
abspath=$(cd `dirname $MAKE_PATH` ; pwd)
echo $abspath
example:
Makefile.root.include
#-- for deduce the abspath of the project root
MK_ROOT_INC_DIR := $(dir $(word 2, $(MAKEFILE_LIST)))
MK_ROOT_INC_RELATE_TO_SRC_ROOT := ..
SRC_ROOT_DIR := $(abspath $(MK_ROOT_INC_DIR)$(MK_ROOT_INC_RELATE_TO_SRC_ROOT))
Makefile
include ../../mk/Makefile.root.include
all:$(TARGET_BIN)
@echo $(MAKEFILE_LIST)
@echo $(MK_ROOT_INC_DIR)
@echo $(MK_ROOT_INC_RELATE_TO_SRC_ROOT)
@echo $(MK_ROOT_INC_DIR)$(MK_ROOT_INC_RELATE_TO_SRC_ROOT)
@echo $(SRC_ROOT_DIR)