Makefile 相关


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)



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CMake是一个跨平台的构建工具,用于构建C ++代码的工具,同时支持多个平台和编译器。相比于传统的Makefile,CMake提供了更加简洁、易于维护、易于理解的构建方式,而且相对于Makefile的生成方式,Cmake的生成方式更加容易自动化,很适合在大型项目中使用。对于想要深入学习CMake的用户,可以参考一些著名的CMake书籍,如《CMake Cookbook》,该书针对不同的用例提供了详细的使用指南;《Mastering CMake》讨论了如何使用CMake来构建C ++和C软件;《Professional Cmake: A Practical Guide》则强调了CMake的最佳实践和如何解决常见问题。 而Makefile则是UNIX及其衍生系统常见的程序构建工具,主要用于通过执行一个包含编译规则的脚本自动化构建过程。如果想要深入了解Makefile的使用,可以先了解一下GNU make的语法规则,很多的Makefile编写风格比较接近于GNU make的语法。相关的书籍也很丰富,如《Managing Projects with GNU Make, Third Edition》,该书对GNU make的使用做了全面的介绍,从基础概念到高级特性等方面都有所讲解;《跟我一起写Makefile》则是一本为Makefile初学者准备的教程,通过实例讲解了什么是Makefile以及如何使用Makefile来构建项目。 总之,CMake和Makefile都是重要的构建工具,在程序员的工作中扮演着不可替代的角色。随着工具的不断发展,它们的使用也越来越普及,相应地,相关的书籍越来越多,选择一本适合自己的书籍,深入学习这两种工具,相信可以让自己的构建工作更加高效、便捷。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值