通用 Makefile(及makefile中的notdir,wildcard和patsubst)

notdir,wildcard和patsubst是makefile中几个有用的函数,以前没留意过makefile中函数的用法,今天稍微看看~

1、makefile里的函数

makefile里的函数使用,和取变量的值类似,是以一个‘$’开始,然后是一个括号里面是函数名和需要的参数列表,多个变量用逗号隔开,像这样

return = $(functionname  arg1,arg2,arg3...)。

可能这里的‘$‘更像是从某个地址取值类似的操作。

2、 wildcard

使用:SRC = $(wildcard *.c ./foo/*.c)

搜索当前目录及./foo/下所有以.c结尾的文件,生成一个以空格间隔的文件名列表,并赋值给SRC.当前目录文件只有文件名,子目录下的文件名包含路径信息,比如./foor/bar.c。

3、notdir

使用:SRC = $(notdir wildcard)

去除所有的目录信息,SRC里的文件名列表将只有文件名。

4、patsubst

使用:OBJ = $(patsubst %.c %.o $(SRC))

patsubst是patten substitude的缩写,匹配替代的意思。这句是在SRC中找到所有.c 结尾的文件,然后把所有的.c换成.o。

###########################################################
# Generic makefile 
# 
# by George Foot 
# email: [email protected] 
# 
# Copyright (c) 1997 George Foot 
# All rights reserved. 
# 保留所有版權 
# 
# No warranty, no liability; 
# you use this at your own risk. 
# 沒保險,不負責 
# 你要用這個,你自己擔風險 
# 
# You are free to modify and 
# distribute this without giving 
# credit to the original author. 
# 你可以隨便更改和散發這個文件 
# 而不需要給原作者什榮譽。 
# (你好意思?) 
# 
###################################### 

### Customising
#
# Adjust the following if necessary; EXECUTABLE is the target
# executable‘s filename, and LIBS is a list of libraries to link in
# (e.g. alleg, stdcx, iostr, etc). You can override these on make‘s
# command line of course, if you prefer to do it that way.
# 
# 如果需要,調整下面的東西。 EXECUTABLE 是目標的可執行文件名, LIBS
# 是一個需要連接的程序包列表(例如 alleg, stdcx, iostr 等等)。當然你
# 可以在 make 的命令行覆蓋它們,你願意就沒問題。
#  

EXECUTABLE := mushroom.exe
LIBS := alleg 

# Now alter any implicit rules‘ variables if you like, e.g.:
#
# 現在來改變任何你想改動的隱含規則中的變量,例如 

CFLAGS := -g -Wall -O3 -m486
CXXFLAGS := $(CFLAGS) 

# The next bit checks to see whether rm is in your djgpp bin
# directory; if not it uses del instead, but this can cause (harmless)
# `File not found‘ error messages. If you are not using DOS at all,
# set the variable to something which will unquestioningly remove
# files.
#
# 下面先檢查你的 djgpp 命令目錄下有沒有 rm 命令,如果沒有,我們使用
# del 命令來代替,但有可能給我們 ‘File not found‘ 這個錯誤信息,這沒
# 什大礙。如果你不是用 DOS ,把它設定成一個刪文件而不廢話的命令。
# (其實這一步在 UNIX 類的系統上是多余的,只是方便 DOS 用戶。 UNIX
# 用戶可以刪除這5行命令。) 

ifneq ($(wildcard $(DJDIR)/bin/rm.exe),)
RM-F := rm -f
else
RM-F := del
endif 

# You shouldn‘t need to change anything below this point.
#
# 從這裡開始,你應該不需要改動任何東西。(我是不太相信,太NB了!) 

SOURCE := $(wildcard *.c) $(wildcard *.cc)
OBJS := $(patsubst %.c,%.o,$(patsubst %.cc,%.o,$(SOURCE)))
DEPS := $(patsubst %.o,%.d,$(OBJS))
MISSING_DEPS := $(filter-out $(wildcard $(DEPS)),$(DEPS))
MISSING_DEPS_SOURCES := $(wildcard $(patsubst %.d,%.c,$(MISSING_DEPS)) \
$(patsubst %.d,%.cc,$(MISSING_DEPS)))
CPPFLAGS += -MD 

.PHONY : everything deps objs clean veryclean rebuild 

everything : $(EXECUTABLE) 

deps : $(DEPS) 

objs : $(OBJS) 

clean :
  @$(RM-F) *.o
  @$(RM-F) *.d 

veryclean: clean
  @$(RM-F) $(EXECUTABLE) 

rebuild: veryclean everything 

ifneq ($(MISSING_DEPS),)
$(MISSING_DEPS) :
  @$(RM-F) $(patsubst %.d,%.o,[email protected])
endif 

-include $(DEPS) 

$(EXECUTABLE) : $(OBJS)
  gcc -o $(EXECUTABLE) $(OBJS) $(addprefix -l,$(LIBS))
###

  

时间: 2024-10-13 19:13:50

通用 Makefile(及makefile中的notdir,wildcard和patsubst)的相关文章

Configure,Makefile.am, Makefile.in, Makefile文件之间关系

1.autoscan (autoconf): 扫描源代码以搜寻普通的可移植性问题,比如检查编译器,库,头文件等,生成文件configure.scan,它是configure.ac的一个雏形. your source files --> [autoscan*] --> [configure.scan] --> configure.ac 2.aclocal (automake):根据已经安装的宏,用户定义宏和acinclude.m4文件中的宏将configure.ac文件所需要的宏集中定义到

Makefile第三讲:终端传值给Makefile、Makefile传值给C++代码

摘要 终端传值给Makefile,咋传?只需在终端输入以下命令,那么就可以在Makefile文件中放心大担的使用$(abcde)这个变量了,它的值为BBB Makefile fun.h #include <iostream> class Test { public: void static display(const char *str); }; fun.cpp #include "fun.h" void Test::display(const char *str) { s

Configure,Makefile.am, Makefile.in, Makefile

无论对于一个初学者还是一个资深的Linux程序员,编写Makefile文件都是一件很麻烦的事:再者,开发人员应该把主要的精力放在程序代码的编写上,而在Makefile文件花费太多的精力显然是不明智的:还有,对于不同的处理器架构,往往编译器不同,环境不同,特别是一些嵌入式系统中的各种程序的编译,于是移植问题也使Makefile文件编写趋于复杂,也显得这个问题很重要.对于这些问题Linux的高手们早已想到了,所以他们开发了一些能够自动生成Makefile文件的工具.他们就是下面这些工具: 〉GNU

Configure,Makefile.am, Makefile.in, Makefile文件

一 软件安装关于 makefile文件问题 如果拿到的工程文件中,没有Makefile文件,而只有configure.in和Makefile.am文件,我们是不能够直接进行编译的,必须根据configure.in和Makefile.am文件生成编译所需的Makefile文件.具体操作步骤如下: 1.执行aclocal,产生aclocal.m4文件 aclocal是一个perl 脚本程序,它的定义是:“aclocal - create aclocal.m4 by scanning configur

make 查找的文件名顺序为:“GNUmakefile”、“makefile”、“Makefile”

默认的情况下,make会在工作目录(执行make的目录)下按照文件名顺序寻找makefile文件读取并执行,查找的文件名顺序为:“GNUmakefile”.“makefile”.“Makefile”.通 常应该使用“makefile”或者“Makefile”作为一个makefile的文件名(我们推荐使用“Makefile”,首字母大写而比较显著, 一般在一个目录中和当前目录的一些重要文件(README,Chagelist等)靠近,在寻找时会比较容易的发现它).而“GNUmakefile”是 我们

Makefile中的wildcard和patsubst

makefile 里的函数跟它的变量很相似——使用的时候,你用一个 $ 符号跟开括号,函数名,空格后跟一列由逗号分隔的参数,最后用关括号结束. 例如,在 GNU Make 里有一个叫 'wildcard' 的函数,它有一个参数,功能是展开成一列所有符合由其参数描述的文件名,文件间以空格间隔. 你可以像下面所示使用这个命令:    SOURCES = $(wildcard *.c)    这行会产生一个所有以 '.c' 结尾的文件的列表,然后存入变量 SOURCES 里.当然你不需要一定要把结果存

通用多目录makefile的写法

我的项目文件层次是:项目名称/include.output.src src/admin.stu.tch.common 最外层的Makefile: DEBUG = yMYDEBUG = DEBUGifeq ($(DEBUG),y)DEBFLAGS = -O -g -D$(MYDEBUG)elseDEBFLAGS =endif PRJ_HOME := $(shell pwd)SOURCES := $(wildcard *.c)OBJECTS := ${SOURCES:%.c=%.o}INCPATH

【makefile】Makefile:16: *** 遗漏分隔符 。停止。

随手写了一个makefile文件,如下: 然后在执行make 报错,错误情况如下: 在网上度娘了一下,原因如下: gcc.rm.cp前面是tab分割符,不能用空格. 修改后的Makefile如下: 看到没?rm及make的字体颜色都变了. 原文地址:https://www.cnblogs.com/vossveen/p/8167054.html

窗体内元素遍历-通用方法(DevExpress 中BarManager的遍历)

需求:WinForm窗体中对于各个元素进行遍历设置. 本身因为程序绝大部分功能已经开发完毕,但是权限控制没有追加,在后续开发中要求对窗体内各个资源的使用权限进行控制,最初各个资源并非动态添加的,所以通过数据库和所有窗体基类配合使用的方法进行控制. 实现方案:在基类中对子窗体中的实例化控件是否显示进行控制. 遇到问题1:DevExpress.XtraBars.BarManager 没有继承Control基类,所以无法使用this.Controls进行遍历 遇到问题2:在基类中使用子类的实例化控件对