通用的Makefile实例

原创
2018/05/03 20:26
阅读数 130

通用的Makefile实例

1. 什么是Makefile

Windows平台的开发者或许不清楚Makefile是什么东西,因为你的开发大部分工作都是IDE在做。但是Linux平台上的开发者不知道就不太合格了。

解释性语言我们不谈,我们以C/C++这样的编译性语言举例,一个hello.cpp文件需要经过在:预处理,编译,汇编,链接四个过程,简单一点你使用g++ hello.cpp 编译器会自动给你进行这四个过程,当然你可以带参数逐个执行。

上述的g++ hello.cpp 只能处理单个文件,但是大型项目文件成百上千,我们会想用shell写一个批处理脚本吧。Bingo, 这就是Makefile。

2. Demo

# dir
DIR=$(shell pwd)
SRC_DIR=$(DIR)/src
INCLUDE_DIR=$(DIR)/include
DEBUG_DIR=$(DIR)/debug
OBJS=$(DEBUG_DIR)/*.o

# setting
CC=gcc
CFLAGS=-g -c
PROJNAME=build
MODULE=main exercise

# link
$(PROJNAME):$(foreach i,$(MODULE),$(i).o)
	$(CC) -o $(DEBUG_DIR)/$(PROJNAME) $(OBJS)

# compile
define funC
$(1).o:$(INCLUDE_DIR)/*.h
	$(CC) $(CFLAGS) -o $(DEBUG_DIR)/$(1).o $(SRC_DIR)/$(1).c
endef

$(foreach j,$(MODULE),$(eval $(call funC,$(j))))

# make clean
clean:
	rm $(DEBUG_DIR)/*.o $(DEBUG_DIR)/$(PROJNAME)

原文地址 http://codeyourlife.cn

展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部