makefile 分析 -- 内置变量及自动变量

本文涉及的产品
函数计算FC,每月15万CU 3个月
简介: makefile 分析1  -p 选项,可以打印出make过程中的数据库, 下面研究一下内置的变量和规则。 -n 选项, 只运行,不执行, -d 选项,相当于--debug=a,  b(basic),v(verbose),i(implicity),j(innvocation of command),m(remake files)  这里着重解释一下 -p make -p -f /dev/null 可以打印出内置变量和内置规则 变量可以分为3类, 第一类: 环境变量, 比较重要的是PATH, PWD 就不一一列举了。

makefile 分析1 
 
-p 选项,可以打印出make过程中的数据库, 下面研究一下内置的变量和规则。 
-n 选项, 只运行,不执行, 
-d 选项,相当于--debug=a,  b(basic),v(verbose),i(implicity),j(innvocation of command),m(remake files) 
 
这里着重解释一下 -p 
make -p -f /dev/null 可以打印出内置变量和内置规则 
变量可以分为3类, 
第一类: 环境变量, 比较重要的是PATH, PWD 就不一一列举了。 
第二类: 内置变量, 比较重要的是cc, CXX, .INCLUDE_DIRS, .DEFAULT_GOAL等 
例如: 
cc 是 /usr/bin/cc -> /usr/bin/gcc 
CXX 是 g++ 
 
查找makefile 维护的目标 
.DEFAULT_GOAL  默认的维护的目标(命令行未指定目标)
MAKECMDGOALS  命令行指定的维护目标。 
为完整起见,贴出我机器上的内置变量。大可不必死记硬背,掌握重要的,领会其含义即可。 
[hjj@hjj ~]$ cat 2.txt 
.FEATURES := target-specific order-only second-expansion else-if archives jobserver check-symlink 
.INCLUDE_DIRS = /usr/include /usr/local/include /usr/include 
.LIBPATTERNS = lib%.so lib%.a 
.VARIABLES :=  
AR = ar 
ARFLAGS = rv 
AS = as 
CC = cc 
CHECKOUT,v = +$(if $(wildcard $@),,$(CO) $(COFLAGS) $< $@) 
CO = co 
COFLAGS =  
COMPILE.C = $(COMPILE.cc) 
COMPILE.F = $(FC) $(FFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c 
COMPILE.S = $(CC) $(ASFLAGS) $(CPPFLAGS) $(TARGET_MACH) -c 
COMPILE.c = $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c 
COMPILE.cc = $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c 
COMPILE.cpp = $(COMPILE.cc) 
COMPILE.def = $(M2C) $(M2FLAGS) $(DEFFLAGS) $(TARGET_ARCH) 
COMPILE.f = $(FC) $(FFLAGS) $(TARGET_ARCH) -c 
COMPILE.mod = $(M2C) $(M2FLAGS) $(MODFLAGS) $(TARGET_ARCH) 
COMPILE.p = $(PC) $(PFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c 
COMPILE.r = $(FC) $(FFLAGS) $(RFLAGS) $(TARGET_ARCH) -c 
COMPILE.s = $(AS) $(ASFLAGS) $(TARGET_MACH) 
CPP = $(CC) -E 
CTANGLE = ctangle 
CWEAVE = cweave 
CXX = g++ 
F77 = $(FC) 
F77FLAGS = $(FFLAGS) 
FC = f77 
GET = get 
LD = ld 
LEX = lex 
LEX.l = $(LEX) $(LFLAGS) -t 
LINK.C = $(LINK.cc) 
LINK.F = $(FC) $(FFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH) 
LINK.S = $(CC) $(ASFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_MACH) 
LINK.c = $(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH) 
LINK.cc = $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH) 
LINK.cpp = $(LINK.cc) 
LINK.f = $(FC) $(FFLAGS) $(LDFLAGS) $(TARGET_ARCH) 
LINK.o = $(CC) $(LDFLAGS) $(TARGET_ARCH) 
LINK.p = $(PC) $(PFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH) 
LINK.r = $(FC) $(FFLAGS) $(RFLAGS) $(LDFLAGS) $(TARGET_ARCH) 
LINK.s = $(CC) $(ASFLAGS) $(LDFLAGS) $(TARGET_MACH) 
LINT = lint 
LINT.c = $(LINT) $(LINTFLAGS) $(CPPFLAGS) $(TARGET_ARCH) 
M2C = m2c 
MAKE = $(MAKE_COMMAND) 
MAKEFILES :=  
MAKEINFO = makeinfo 
MAKE_COMMAND := make 
MAKE_VERSION := 3.81 
OUTPUT_OPTION = -o $@ 
PC = pc 
PREPROCESS.F = $(FC) $(FFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -F 
PREPROCESS.S = $(CC) -E $(CPPFLAGS) 
PREPROCESS.r = $(FC) $(FFLAGS) $(RFLAGS) $(TARGET_ARCH) -F 
RM = rm -f 
SUFFIXES := .out .a .ln .o .c .cc .C .cpp .p .f .F .r .y .l .s .S .mod .sym .def .h .info .dvi .tex .texinfo .texi .txinfo .w .ch .web .sh .elc .el 
TANGLE = tangle 
TEX = tex 
TEXI2DVI = texi2dvi 
WEAVE = weave 
YACC = yacc 
YACC.y = $(YACC) $(YFLAGS) 
 
第三类:自动变量。我的机器是这样的。 
[hjj@hjj ~]$ cat 3.txt 
%D = $(patsubst %/,%,$(dir $%)) 
*D = $(patsubst %/,%,$(dir $*)) 
+D = $(patsubst %/,%,$(dir $+)) 
?D = $(patsubst %/,%,$(dir $?)) 
@D = $(patsubst %/,%,$(dir $@)) 
^D = $(patsubst %/,%,$(dir $^)) 
%F = $(notdir $%) 
*F = $(notdir $*) 
+F = $(notdir $+) 
<F = $(notdir $<) 
?F = $(notdir $?) 
@F = $(notdir $@) 
^F = $(notdir $^) 
 
代表文件(4个) 
$@--目标文件, 
$<--第一个依赖文件。 
$*--代表"茎",例如:文件“dir/a.foo.b”,当目标的模式为“a.%.b ”时,“$* ”的值为“dir/a.foo ” 
$%--当规则的目标文件是一个静态库文件时,代表静态库的一个成员名 
代表文件列表(3个) 
$^--所有的依赖文件, 
$?--所有比目标文件更新的依赖文件列表 
$+--类似“$^”,但是它保留了依赖文件中重复出现的文件 
 
$(@D) -- 目标的目录部分,文件名部分 
$(@F)  
$(*D) -- 代表"茎"的目录部分,文件名部分 
$(*F)  
$(<D) -- 第一个依赖文件目录部分,文件名部分 
$(<F)  
$(?D) -- 被更新的依赖文件目录部分,文件名部分  
$(?F)  
$(^D) -- 所有依赖文件目录部分,文件名部分 
$(^F)  
$(%D) -- 库文件成员目录部分,文件名部分 
$(%F)  
$(+D) -- 所有依赖的目录部分,文件名部分(可存在重复文件) 
$(+F)  

相关实践学习
【AI破次元壁合照】少年白马醉春风,函数计算一键部署AI绘画平台
本次实验基于阿里云函数计算产品能力开发AI绘画平台,可让您实现“破次元壁”与角色合照,为角色换背景效果,用AI绘图技术绘出属于自己的少年江湖。
从 0 入门函数计算
在函数计算的架构中,开发者只需要编写业务代码,并监控业务运行情况就可以了。这将开发者从繁重的运维工作中解放出来,将精力投入到更有意义的开发任务上。
目录
相关文章
|
搜索推荐 数据库 C语言
C语言实现冒泡排序(超详细)
C语言实现冒泡排序(超详细)
555 1
|
编译器 Shell Android开发
工具技能学习(一):前置技能-makfile、make、.mk
工具技能学习(一):前置技能-makfile、make、.mk
449 0
|
编解码 程序员 atlas
Unity 之 图集属性详解和代码示例 -- 拓展一键自动打包图集工具
图集只是当所有给低昂的纹理需要相同的着色器时采用的一种方法,如果一些纹理需要通过着色器应用独立的图形效果,它们就必须分离到自己的材质中,并在单独的组中打图集。
2075 0
Unity 之 图集属性详解和代码示例 -- 拓展一键自动打包图集工具
|
网络性能优化
【AXI】解读AXI协议的额外信号(QOS信号,REGION信号,与USER信号)
【AXI】解读AXI协议的额外信号(QOS信号,REGION信号,与USER信号)
【AXI】解读AXI协议的额外信号(QOS信号,REGION信号,与USER信号)
|
网络协议 Linux 编译器
【原创】EtherCAT主站IgH解析(二)-- 如何将Igh移植到Linux/Windows/RTOS等多操作系统移植指南
EtherCAT主站方案对比:商业的如Acontis、TwinCAT3和开源的igh、SOEM。SOEM易移植但功能和实时性不足,适合简单应用;igh功能强大,实时性能优秀,基于内核态,适合复杂场景。igh能移植到其他RTOS,但需克服多任务无调度的挑战。依赖操作系统服务如定时器、内存分配,适合Linux内核,但移植到裸机复杂。
783 0
|
缓存 NoSQL 数据库
高性能Web服务器架构设计
【8月更文第28天】在当今互联网时代,网站的响应速度直接影响用户体验和业务成功率。因此,构建一个高性能的Web服务器架构至关重要。本文将从硬件配置、软件架构以及网络设置三个方面探讨如何提高Web服务器的性能,并提供一些实际的代码示例。
611 0
|
Python
Python小技巧:一种字符串的排序方式
该文介绍了如何对包含数字的字符串列表进行特定排序。首先,示例了一个初始问题,使用Python内置的`sorted()`函数未能达到预期(按数字部分升序排序)。然后,文章提出通过自定义排序键`sort_key`来解决,利用正则表达式提取字符串尾部数字并进行排序。进一步,文章扩展到处理如&#39;nxxx_name_nxxx&#39;格式的字符串,通过给前缀和后缀数字赋予不同权重进行复合排序,展示了如何实现先按前缀、再按后缀排序的功能。提供的代码示例成功地完成了任务。
163 0
|
中间件 Linux 芯片
一张图秒懂嵌入式Linux系统的启动流程
一张图秒懂嵌入式Linux系统的启动流程
648 0
|
算法 Java API
浅谈日出日落的计算方法以及替代工具 - 日出日落 API
如果你想知道精确的日落日出时间,又或者你想设计一个日出日落时间查询的应用,又或者你只是好奇点进来了,还是可以过来围观一下涨涨知识,今天想跟大家聊一聊的是日出日落的计算方法以及替代工具 - 日出日落 API 。
1573 0
|
Java Maven 开发工具
【IntelliJ IDEA】使用Maven方式构建Spring Boot Web 项目(超详细)1
【IntelliJ IDEA】使用Maven方式构建Spring Boot Web 项目(超详细)
390 2