`
wx1569578408
  • 浏览: 71393 次
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

多目录下的Makefile

 
阅读更多

1、测试文件夹目录:

├── bin
│   └── main
├── include
│   ├── test1.h
│   ├── test2.h
│   └── test.h
├── Makefile
├── obj
└── src
    ├── main.c
    ├── test
    │   ├── include
    │   │   └── test3.h
    │   └── src
    │       └── test3.c
    ├── test1.c
    └── test2.c
 

2、测试Makefile

DIR_CUR = /home/aniu/workspace/ldd/makefile_dir

DIR_SRC = ./src
DIR_OBJ = ./obj
DIR_BIN = ./bin

DIR_INC = -I${DIR_CUR}/include  \
          -I${DIR_CUR}/src/test/include

SRC = ${wildcard ${DIR_SRC}/*c} \
	  ${wildcard ${DIR_SRC}/test/src/*.c}

OBJ = $(patsubst %.c, ${DIR_OBJ}/%.o, $(notdir ${SRC}))

TARGET = main

BIN_TARGET = ${DIR_BIN}/$(TARGET)

 CC = gcc
 CFLAGS = -g -Wall ${DIR_INC} 

$(BIN_TARGET): ${OBJ} 
	@echo "\r\nCompile target."
	$(CC) $(OBJ) -o $@

${DIR_OBJ}/%.o:${DIR_SRC}/test/src/%.c
	@echo "\r\nCompile test obj." 
	$(CC) $(CFLAGS) -c $< -o $@

${DIR_OBJ}/%.o:${DIR_SRC}/%.c
	@echo "\r\nCompile src obj."
	$(CC) $(CFLAGS) -c $< -o $@

.PHONY:clean
clean:
	find ${DIR_OBJ} -name *.o -exec rm -rf {}  \;

解释如下:

(1)Makefile中的 符号 $@, $^, $< 的意思:
  $@  表示目标文件
  $^  表示所有的依赖文件
  $<  表示第一个依赖文件
  $?  表示比目标还要新的依赖文件列表

(2)wildcard、notdir、patsubst的意思:

  wildcard : 扩展通配符
  notdir : 去除路径
  patsubst :替换通配符

3、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。

4、传说中的万能Makefile

########################################################### 
# Generic makefile  
#  
# by George Foot  
# email: george.foot@merton.ox.ac.uk  
#  
# 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,$@) 
endif 

-include $(DEPS) 

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

 

转载于:https://my.oschina.net/u/3415127/blog/1070079

分享到:
评论

相关推荐

    linux下构建多目录下Makefile产生a静态库样例

    3. **子目录Makefile**:在每个模块目录下,编写Makefile,例如`module1/Makefile`,定义目标、源文件、头文件路径等。一般包括规则如: ```makefile OBJS = src/file1.o CFLAGS = -Iinclude all: libmodule1.a...

    linux下构建多目录下Makefile产生so动态库样例

    在Linux环境下,构建多目录下的Makefile以生成.so动态库是一项常见的任务,特别是在大型软件项目中。这样的项目通常包含多个源文件,分布在不同的目录结构中,每个目录可能有自己的子Makefile,最终通过主Makefile来...

    Makefile 多目录编译Demo

    在编程世界中,Makefile是一个极其重要的工具,它允许开发者自动化构建项目,特别是当项目包含多个目录和大量源代码文件时。"Makefile 多目录编译Demo"着重讲解了如何在复杂的项目结构中有效利用Makefile进行编译。...

    如何构建多目录的Makefile样例

    让我们来看一个简单的多目录Makefile示例: ```makefile CC = gcc CFLAGS = -Wall -Iinclude SRCDIR = src OBJDIR = obj BINDIR = bin SOURCES = $(wildcard $(SRCDIR)/*.c) OBJECTS = $(patsubst $(SRCDIR)/%.c, ...

    多目录makefile

    "多目录Makefile"是处理包含多个子目录(如源码、库、测试等)的项目时,管理整个项目构建的一种方式。这种结构有助于代码组织和模块化,使得大型项目更容易维护。 1. **多目录结构**:在项目中,将代码按功能或...

    makefile输出目录管理

    本文将深入探讨如何使用Makefile进行多目录的管理,特别是如何将生成的中间文件(如.o文件)放置到不同的目录,以保持工作空间的整洁。 首先,我们需要了解Makefile的基本结构。一个简单的Makefile通常包含目标...

    多目录Makefile示例

    本文将深入探讨如何创建和理解一个多目录Makefile,这对于初学者来说是一个重要的学习点。 首先,让我们了解Makefile的基本结构。Makefile由一系列目标(target)和依赖关系(dependency)组成。每个目标都有一个或...

    多目录Makefile的写法.zip

    "多目录Makefile的写法"是一个常见但又复杂的主题,尤其对于大型项目来说,源代码往往分布在多个子目录中。下面将详细解释这个主题。 1. **Makefile的基本结构**:一个Makefile通常由目标(target)、依赖项...

    linux makefile 工程目录下,所有c文件

    在这个特定的场景中,我们的任务是编写一个Makefile来处理工程目录下所有C语言源文件的编译,包括可能存在的子目录中的文件。下面我们将详细探讨如何实现这一目标。 首先,我们需要理解Makefile的基本结构和规则。...

    makefile多目录文件

    在多目录结构中,`Makefile`需要处理各个目录下的源文件,确保它们按需编译和链接。 首先,理解目录结构至关重要。假设我们有如下的目录布局: ``` project/ |-- src/ | |-- main/ | | |-- c files (如:main.c) |...

    主目录下的makefile 翻译

    内核2.6.22主目录下的makefile 翻译

    多文件夹下编写Makefile

    以下将详细介绍如何在多文件夹结构下编写有效的Makefile。 1. **Makefile基本结构** Makefile通常包含目标(targets)、依赖项(dependencies)和规则(rules)。目标是你想要构建的产品,依赖项是构建目标所需的...

    韦东山通用Makefile文件

    修改顶层目录Makefile的CROSS_COMPILE, 用来指定工具链的前缀(比如arm-linux-) 5. 确定应用程序的名字: 修改顶层目录Makefile的TARGET, 这是用来指定编译出来的程序的名字 6. 执行"make"来编译,执行...

    Linux多个Makefile文件编译,多层次Makefile文件编译和多目标Makefile文件编译

    make文件夹包含了两个子文件夹,a_b子文件夹实现多目标Makefile编译,projects子文件夹实现多层次Makefile文件编译。make文件夹中实现多个Makefile文件编译,即调用a_b和project2子文件夹中Makefile编译。

    多目录makefile编写示例

    本示例中的"多目录makefile编写"旨在展示如何在一个项目中组织多个源码目录,并通过`Makefile`有效地管理它们。同时,它还利用了`sh`脚本来增强灵活性,允许用户通过传递不同的参数来控制编译选项。 首先,`...

    linux下驱动程序模块编程多文件makefile编写示例

    在多文件的情况下,你需要列出所有源文件,并将它们与目标文件关联起来。例如,如果你有`driver1.c`, `driver2.c`, 和 `driver3.c`三个源文件,你需要在Makefile中添加相应的规则,如下所示: ```makefile obj-m += ...

    多级目录Makefile示例

    本程序的Makefile分为3类: 1. 顶层目录的Makefile 2. 顶层目录的Makefile.build 3. 各级子目录的Makefile 分别介绍每个Makefile和Makefile.build文件,以及说明怎么使用这套Makefile

    Makefile自动构建方法

    在`helloworld`目录下创建`Makefile.am`文件,并填写以下内容: ```makefile AUTOMAKE_OPTIONS = foreign bin_PROGRAMS = helloworld helloworld_SOURCES = helloworld.c ``` ##### 5. 运行autoheader 运行`...

Global site tag (gtag.js) - Google Analytics