makefile中if then写法

合集下载

Makefile文件语法

Makefile文件语法

Makefile⽂件语法概述本⽂将介绍Makefile种注释、回显、通配符、变量、循环判断、函数注释Makefile中只有单⾏注释,没有多⾏注释,注释以 # 开头。

以下Makefile注释⽚段节选⾃的Makefile# Makefile for installing Lua# See doc/readme.html for installation and customization instructions.# == CHANGE THE SETTINGS BELOW TO SUIT YOUR ENVIRONMENT =======================# Your platform. See PLATS for possible values.PLAT= noneechoing(回显)通常,make在执⾏命令⾏之前会把要执⾏的命令⾏进⾏输出。

我们称之为“回显”,就好像我们输⼊命令执⾏⼀样。

@如果要执⾏的命令⾏以字符“@”开始,则make在执⾏时这个命令就不会被回显。

典型的⽤法是我们在使⽤“echo”命令输出⼀些信息时。

如:@echo 开始编译XXX模块......当make执⾏时,将输出“开始编译XXX模块......”这个信息。

如果在命令⾏之前没有字符“@”,那么,make的输出就是:echo编译XXX模块......编译XXX模块......“-n”或“--just-print”如果使⽤make的命令⾏参数“-n”或“--just-print”,那么make执⾏时只显⽰所要执⾏的命令,但不会真正的去执⾏这些命令。

只有在这种情况下make才会打印出所有make需要执⾏的命令,其中也包括了使⽤“@”字符开始的命令。

这个选项对于我们调试Makefile⾮常有⽤,使⽤这个选项我们可以按执⾏顺序打印出Makefile中所有需要执⾏的命令。

“-s”或“--slient”make参数“-s”或“--slient”则是禁⽌所有执⾏命令的显⽰,就好像所有的命令⾏均使⽤“@”开始⼀样。

makefile正则表达式

makefile正则表达式

makefile正则表达式makefile是一种常用的工具,可以用于自动化构建和管理项目。

在makefile中,正则表达式是一个强大的工具,可以帮助我们更方便地匹配和处理文本内容。

makefile中常用的正则表达式包括:1. ^(起始符):匹配字符串的开头。

2. $(结束符):匹配字符串的结尾。

3. .(点号):匹配除了换行符外的任意一个字符。

4. *(星号):匹配前面的字符出现0个或多个。

5. +(加号):匹配前面的字符出现1个或多个。

6. ?(问号):匹配前面的字符出现0个或1个。

7. [ ](中括号):匹配中括号中任意一个字符。

8. [^ ](中括号取反):匹配不在中括号中的任意一个字符。

9. ( )(圆括号):将括号中的内容视为一个整体,可以和其他正则表达式一起使用。

除了这些常用的正则表达式外,还有一些特殊的符号和语法可以帮助我们更精确地匹配文本内容,比如:1. (反斜杠):转义符,可以将特殊字符转义为普通字符。

2. |(竖线):或运算符,可以匹配多个表达式中的一个。

3. { }(花括号):重复次数符号,可以指定一个字符或表达式的重复次数。

在使用正则表达式时,我们需要注意一些事项,比如:1. 正则表达式是区分大小写的。

2. 正则表达式中的空格和换行符也会被匹配。

3. 正则表达式可能会匹配到我们不需要的内容,因此需要通过进一步筛选和处理来达到我们的目的。

总之,正则表达式在makefile中的应用非常广泛,可以帮助我们更方便地编写自动化构建和管理脚本。

熟练掌握正则表达式的使用方法,可以极大地提高我们的工作效率。

Makefile 语法分析

Makefile 语法分析

Makefile 语法分析第一部分VERSION = 2# 给变量VERSION赋值PATCHLEVEL = 6# 给变量PATCHLEVEL赋值SUBLEVEL = 22# 给变量SUBLEVEL赋值EXTRAVERSION = .6# 给变量EXTRAVERSION赋值NAME = Holy Dancing Manatees, Batman!# 给变量NAME赋值# *DOCUMENTATION*# To see a list of typical targets execute "make help"# More info can be located in ./README# Comments in this file are targeted only to the developer, do not# expect to learn how to build the kernel reading this file.# Do not:# o use make's built-in rules and variables# (this increases performance and avoid hard-to-debug behavour);# o print "Entering directory ...";MAKEFLAGS += -rR --no-print-directory# 操作符“+=”的作用是给变量(“+=”前面的MAKEFLAGS)追加值。

# 如果变量(“+=”前面的MAKEFLAGS)之前没有定义过,那么,“+=”会自动变成“=”;# 如果前面有变量(“+=”前面的MAKEFLAGS)定义,那么“+=”会继承于前次操作的赋值符;# 如果前一次的是“:=”,那么“+=”会以“:=”作为其赋值符# 在执行make时的命令行选项参数被通过变量“MAKEFLAGS”传递给子目录下的make程序。

Makefile变量使用条件及判断使用

Makefile变量使用条件及判断使用

Makefile变量使用条件及判断使用使用变量————在Makefile中的定义的变量,就像是C/C++语言中的宏一样,他代表了一个文本字串,在Makefile中执行的时候其会自动原模原样地展开在所使用的地方。

其与C/C++所不同的是,你可以在Makefile中改变其值。

在Makefile中,变量可以使用在“目标”,“依赖目标”,“命令”或是Makefile的其它部分中。

变量的命名字可以包含字符、数字,下划线(可以是数字开头),但不应该含有“:”、“#”、“=”或是空字符(空格、回车等)。

变量是大小写敏感的,“foo”、“Foo”和“FOO”是三个不同的变量名。

传统的Makefile的变量名是全大写的命名方式,但我推荐使用大小写搭配的变量名,如:MakeFlags。

这样可以避免和系统的变量冲突,而发生意外的事情。

有一些变量是很奇怪字串,如“$<”、“$@”等,这些是自动化变量,我会在后面介绍。

一、变量的基础变量在声明时需要给予初值,而在使用时,需要给在变量名前加上“$”符号,但最好用小括号“()”或是大括号“{}”把变量给包括起来。

如果你要使用真实的“$”字符,那么你需要用“$$”来表示。

变量可以使用在许多地方,如规则中的“目标”、“依赖”、“命令”以及新的变量中。

先看一个例子:objects = program.o foo.o utils.oprogram : $(objects)cc -o program $(objects)$(objects) : defs.h变量会在使用它的地方精确地展开,就像C/C++中的宏一样,例如:foo = cprog.o : prog.$(foo)$(foo)$(foo) -$(foo) prog.$(foo)展开后得到:prog.o : prog.ccc -c prog.c当然,千万不要在你的Makefile中这样干,这里只是举个例子来表明Makefile中的变量在使用处展开的真实样子。

手把手教你如何写Makefile

手把手教你如何写Makefile

手把手教你如何写Makefile陈皓 2005.04.01一、Makefile的规则在讲述这个Makefile之前,还是让我们先来粗略地看一看Makefile的规则。

target ... : prerequisites ...commandtarget也就是一个目标文件,可以是Object File,也可以是执行文件。

还可以是一个标签(Label),对于标签这种特性,在后续的“伪目标”章节中会有叙述。

prerequisites就是,要生成那个target所需要的文件或是目标。

command也就是make需要执行的命令。

(任意的Shell命令)这是一个文件的依赖关系,也就是说,target这一个或多个的目标文件依赖于prerequisites 中的文件,其生成规则定义在command中。

说白一点就是说,prerequisites中如果有一个以上的文件比target文件要新的话,command所定义的命令就会被执行。

这就是Makefile的规则。

也就是Makefile中最核心的内容。

说到底,Makefile的东西就是这样一点,好像我的这篇文档也该结束了。

呵呵。

还不尽然,这是Makefile的主线和核心,但要写好一个Makefile还不够,我会以后面一点一点地结合我的工作经验给你慢慢到来。

内容还多着呢。

:)二、一个示例正如前面所说的,如果一个工程有3个头文件,和8个C文件,我们为了完成前面所述的那三个规则,我们的Makefile应该是下面的这个样子的。

edit : main.o kbd.o command.o display.o \insert.o search.o files.o utils.occ -o edit main.o kbd.o command.o display.o \insert.o search.o files.o utils.omain.o : main.c defs.hcc -c main.ckbd.o : kbd.c defs.h command.hcc -c kbd.ccommand.o : command.c defs.h command.hcc -c command.cdisplay.o : display.c defs.h buffer.hcc -c display.cinsert.o : insert.c defs.h buffer.hcc -c insert.csearch.o : search.c defs.h buffer.hcc -c search.cfiles.o : files.c defs.h buffer.h command.hcc -c files.cutils.o : utils.c defs.hcc -c utils.cclean :rm edit main.o kbd.o command.o display.o \insert.o search.o files.o utils.o反斜杠(\)是换行符的意思。

多目录的MAKEFILE

多目录的MAKEFILE

由于涉及到多目录下makefile文件的编写,每个目录下makefile 文件都不相同。

现在简单说下我的多目录下makefile文件的编写。

我把所需要的目录都放在src里面,如图所示其中libs存放库文件,bin存放可执行文件,app存放源文件目录,include存放所要包含的头文件makefile编写如下:TOPDIR := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi)export TOPDIRLIBPATH := $(TOPDIR)/libsexport LIBPATH######################################################################### sub directoriesSUBDIRS = app.PHONY : $(SUBDIRS)########################################################################all: depend $(SUBDIRS)depend dep:@for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir .depend ; done$(SUBDIRS):$(MAKE) -C $@ allclean:@for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir clean ; done在app下有自己的源文件目录,如图:里面有一个项目叫ebook,当然还可以放更多的项目进来,ebook里面放的就是源文件了,makefile如下:SUBDIRS = ebook #项目是什么,就改什么.PHONY : $(SUBDIRS)all: .depend $(SUBDIRS)$(SUBDIRS):$(MAKE) -C $@ all.depend dep:@for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir .depend ; doneclean:@for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir clean ; done同样在ebook中也要写makefile,也是最后一个makefile了INCLUDEDIRS += -I. -I/usr/include/microwin -I/$(TOPDIR)/includeCC = gccCFLAGS = -O4 $(INCLUDEDIRS)ELF = ../../bin/ebook #相对于可执行文件AOBJS = $(patsubst %.s, %.o, $(wildcard *.s))COBJS = $(patsubst %.c, %.o, $(wildcard *.c))CPPOBJS = $(patsubst %.cpp, %.o, $(wildcard *.cpp))OBJS = $(AOBJS) $(COBJS) $(CPPOBJS)all: .depend $(OBJS)$(CC) $(CFLAGS) $(OBJS) \-L $(LIBPATH) -lini\-L /usr/lib -ljpeg -lnano-X -lfreetype -lttf -lz -lpthread\-L /usr/X11R6/lib -lX11\-o $(ELF)chmod 755 $(ELF)########################################################################.depend: Makefile $(AOBJS:.o=.S) $(COBJS:.o=.c) $(CPPOBJS:.o=.cpp)$(CC) -M $(CFLAGS) $(AOBJS:.o=.S) $(COBJS:.o=.c) $(CPPOBJS:.o=.cpp) > $@sinclude .depend########################################################################clean:rm -f *.o .dependrm -f $(ELF)好了,现在就可以在src下敲写make了。

Makefile经典教程(最掌握这部分足够---因为汇集全部精华)!!!!!!!!!!

Makefile经典教程(最掌握这部分足够---因为汇集全部精华)!!!!!!!!!!

Makefile经典教程0 Makefile概述什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。

这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义。

特别在Unix下的软件编译,你就不能不自己写makefile了,会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力。

因为,makefile关系到了整个工程的编译规则。

一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。

makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。

make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。

可见,makefile都成为了一种在工程方面的编译方法。

现在讲述如何写makefile的文章比较少,这是我想写这篇文章的原因。

当然,不同产商的make各不相同,也有不同的语法,但其本质都是在“文件依赖性”上做文章,这里,我仅对GNU的make进行讲述,我的环境是RedHat Linux 8.0,make的版本是3.80。

必竟,这个make是应用最为广泛的,也是用得最多的。

而且其还是最遵循于IEEE 1003.2-1992 标准的(POSIX.2)。

在这篇文档中,将以C/C++的源码作为我们基础,所以必然涉及一些关于C/C++的编译的知识,相关于这方面的内容,还请各位查看相关的编译器的文档。

makefile中的curdir函数

makefile中的curdir函数

makefile中的curdir函数Makefile中的curdir函数是一个内建函数,它用于获取当前Makefile文件所在的目录路径。

在本文中,我将逐步回答有关curdir函数的问题,包括它的作用、语法和使用方法。

1. curdir函数的作用是什么?curdir函数可以帮助我们获取当前Makefile文件所在的目录路径。

这在构建复杂的项目时非常有用,因为有时我们需要根据当前目录的位置来执行特定的命令或设置相应的变量。

2. curdir函数的语法是什么?curdir函数的语法非常简单,只需使用(curdir)即可。

与其他Makefile函数一样,它需要用美元符号和括号来引用。

3. 如何使用curdir函数?使用curdir函数非常简单。

只需在需要获取当前目录路径的位置使用(curdir),它将被替换为当前Makefile文件所在的目录路径。

以下是一个示例,展示了如何使用curdir函数来获取当前目录路径:# 当前目录路径CUR_DIR := (curdir)all:echo "当前目录路径: (CUR_DIR)"在以上示例中,(CUR_DIR)将被替换为当前Makefile文件所在的目录路径,并输出到终端。

4. curdir函数示例下面是一个更详细的示例,展示了如何使用curdir函数进行条件判断和设置路径变量:# 当前目录路径CUR_DIR := (curdir)# 设置目录路径变量TARGET_DIR := (CUR_DIR)/buildall: create_direcho "目录已创建: (TARGET_DIR)"create_dir:# 如果目录不存在,则创建目录if [ ! -d "(TARGET_DIR)" ]; then \mkdir -p "(TARGET_DIR)"; \fi在以上示例中,我们首先使用curdir函数获取当前Makefile文件的目录路径,并将其存储在CUR_DIR变量中。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

makefile中if then写法
如何在Makefile 中使用if-then 写法
Makefile 是一种软件构建工具,广泛用于管理和构建软件项目。

它使用一系列规则和命令来指导构建过程。

其中,条件语句if-then 是Makefile 中常用的控制语句之一。

在本文中,我们将逐步介绍如何在Makefile 中使用if-then 写法,以及它的用途和常见示例。

一、if-then 写法的基本语法
在Makefile 中,if-then 语句的基本语法如下所示:
ifeq (条件, 值)
#条件为真时执行的命令
else
#条件为假时执行的命令
endif
在上述语法中,ifeq 是条件语句的关键字,用于判断一个条件是否为真。

条件是通过与指定的值进行比较来确定的。

若条件为真,则执行ifeq 和else 之间的命令块;若条件为假,则执行else 和endif 之间的命令块。

二、if-then 语句的使用场景
if-then 语句在Makefile 中具有广泛的应用场景。

它可以用于实现以下功能:
1. 根据不同的条件选择性地执行命令。

2. 根据环境变量的值选择性地执行命令。

3. 根据文件存在与否选择性地执行命令。

4. 根据命令执行结果选择性地执行不同的命令。

下面让我们逐步来看每个使用场景的示例。

三、根据不同的条件选择性地执行命令
首先,我们来看一个根据不同的条件选择性地执行命令的示例。

假设我们有一个变量MODE,它的值可以是release 或debug。

根据MODE 的不同,我们可以选择性地执行不同的命令。

makefile
MODE := release
ifeq ((MODE), release)
# release 模式下执行的命令
(info Building release version...)
gcc -O3 -o myprogram main.c
else
# debug 模式下执行的命令
(info Building debug version...)
gcc -g -o myprogram main.c
endif
在上述示例中,(info ...) 是一个内置函数,用于在Makefile 执行过程中打印文本消息。

当MODE 的值为release 时,将打印Building release version...;当MODE 的值为debug 时,将打印Building debug version...。

四、根据环境变量的值选择性地执行命令
其次,让我们看一个根据环境变量的值选择性地执行命令的示例。

假设我们有一个环境变量BUILD_TYPE,它的值可以是release 或debug。

根据BUILD_TYPE 的不同,我们可以选择性地执行不同的命令。

makefile
BUILD_TYPE := (shell echo BUILD_TYPE)
ifeq ((BUILD_TYPE), release)
# release 模式下执行的命令
(info Building release version...)
gcc -O3 -o myprogram main.c
else
# debug 模式下执行的命令
(info Building debug version...)
gcc -g -o myprogram main.c
endif
在上述示例中,(shell ...) 是一个内置函数,用于执行一个shell 命令,并将结果返回给变量。

这里使用(shell echo BUILD_TYPE) 的目的是获取BUILD_TYPE 环境变量的值。

五、根据文件存在与否选择性地执行命令
再次,让我们看一个根据文件存在与否选择性地执行命令的示例。

假设我们的项目中存在一个名为config.h 的头文件。

如果config.h 存在,我们执行一段特定的命令;反之,我们执行另一段命令。

makefile
ifeq ((wildcard config.h), )
# 当config.h 不存在时执行的命令
(info config.h doesn't exist. Creating one...)
touch config.h
else
# 当config.h 存在时执行的命令
(info config.h already exists.)
endif
在上述示例中,(wildcard ...) 是一个内置函数,用于检查文件是否存在。

当config.h 不存在时,(wildcard config.h) 返回一个空字符串,所以条件(wildcard config.h), ) 是真的,将执行if 块中的命令;反之,将执行else 块中的命令。

六、根据命令执行结果选择性地执行不同的命令
最后,让我们看一个根据命令执行结果选择性地执行不同的命令的示例。

假设我们有一个命令git rev-parse abbrev-ref HEAD,它用于获取当前git 分支的名称。

如果当前分支的名称为master,我们执行一段特定的命令;反之,我们执行另一段命令。

makefile
BRANCH := (shell git rev-parse abbrev-ref HEAD)
ifeq ((BRANCH), master)
# 当前分支为master 时执行的命令
(info Building from master branch...)
gcc -O3 -o myprogram main.c
else
# 当前分支不为master 时执行的命令
(info Building from non-master branch...)
gcc -g -o myprogram main.c
endif
在上述示例中,(shell ...) 内部的命令用于获取当前git 分支的名称,并将结果返回给变量BRANCH。

根据BRANCH 变量的值,我们可以选择性地执行不同的命令。

七、总结
在本文中,我们详细介绍了如何在Makefile 中使用if-then 写法,并提供了该写法的基本语法和常见应用场景的示例。

if-then 写法在Makefile 中是非常有用的,它可以根据不同的条件选择性地执行命令,从而更好地管理和构建软件项目。

希望本文对您理解和使用Makefile 中的if-then 写法有所帮助。

相关文档
最新文档