一点一点学写Makefile-1
相信很多Linux开发者 都得自己来写Makefile,刚开始学习学写这个的时候都会碰到很多困难,我之前没有自己独立完成过Makefile,都是在公司已有的模板上添加。现在突然有一个很大的想法就是从零开始写Makefile,这个博客就是我的学习笔记。
开始准备我写的代码,总共七个文件,内容都很简单,工程的下载地址是: 下载地址
代码如下:
- //add.h
- #ifndef ADD_H
- #define ADD_H
- int add(int a, int b);
- #endif // ADD_H
- //add.cpp
- #include "add.h"
- int add(int a, int b)
- {
- return a + b;
- }
- //mul.h
- #ifndef MUL_A
- #define MUL_A
- int mul(int a, int b);
- #endif // MUL_A
- //mul.cpp
- #include "mul.h"
- int mul(int a, int b)
- {
- return a * b;
- }
- //sub.h
- #ifndef SUB_H
- #define SUB_H
- int sub(int a, int b);
- #endif // SUB_H
- //sub.cpp
- #include "sub.h"
- int sub(int a, int b)
- {
- return a - b;
- }
接下来就是最重要的Makefile文件了
- //Makefile
- //make.force
- CROSS =
- CC = $(CROSS)gcc
- CXX = $(CROSS)g++
- DEBUG = -g -O2
- CFLAGS = $(DEBUG) -Wall -c
- RM = rm -rf
- SRCS = add.cpp sub.cpp mul.cpp main.cpp
- OBJS = $(patsubst %.cpp, %.o, $(SRCS))
- VERSION = 1.0.0.0
- TARGET = test.$(VERSION)
- $(TARGET) : $(OBJS)
- $(CXX) $^ -o $@
- $(OBJS):%.o : %.cpp
- $(CXX) $(CFLAGS) $< -o $@
- clean:
- $(RM) $(TARGET) *.o
好了,这就是我的工程里面所有的代码和文件,这里面有Makefile文件和make.force两个文件,这两个文件的内容完全相同。在执行make命令的时候,系统会自动找到makefile或Makefile文件(注:尽可能使用Makefile名称,因为linux开发项目中,所有的文件名字都是小写,因此为了区分出make文件,将M大写),除此之外也可以手动指定make文件,使用"make
-f make.force"来指定将make.force文件作为执行make命令的文件,清理内容是("make clean -f
make.force")。
下来,开始一句一句的讲解Makefile文件的命令:
CROSS = //在开发时候,有时候会有嵌入式的选项
CC = $(CROSS)gcc
CXX = $(CROSS)g++
DEBUG = -g -O2 //这里一般设置为空,在编译时候手动指定,例如:make DEBUG="-g -O2"
CFLAGS = $(DEBUG) -Wall -c
RM = rm -rf
SRCS = add.cpp sub.cpp mul.cpp main.cpp //最笨的方法,将所有的.cpp文件添加到SRCS中
OBJS = $(patsubst %.cpp, %.o, $(SRCS)) //通过*.cpp文件获得同名的*.o文件
VERSION = 1.0.0.0 //版本信息
TARGET = test.$(VERSION) //组装文件名和版本信息
$(TARGET) : $(OBJS) //连接
$(CXX) $^ -o $@
$(OBJS):%.o : %.cpp //生成*.o文件
$(CXX) $(CFLAGS) $< -o $@
clean:
$(RM) $(TARGET) *.o