一套完整的makefile样板(转)

近来,经常看到有人询问makefile的写法,这里根据本人经验给出一个应用系统的完整例子,便于各位参考。


应用系统的目录结构如下:
代码:

~/bin 可执行程序目录
~/etc 配置文件目录
~/inc 头文件目录
~/lib 函数库文件目录
~/log 日志文件目录
~/src 源程序文件目录
~/src/lib 函数库源程序目录
~/src/lib/LIB_1 函数库libLIB_1源程序目录
~/src/APP_A 子系统APP_A源程序目录
~/src/APP_A/mod_a 子系统APP_A模块mod_a源程序目录
~/.profile
~/makefile

~/makefile文件内容如下:
代码:

all:
@MakeSubDir()
{
for DIR in `ls|grep ''lib'';ls|grep -v ''lib''`; do
if [ -d $${DIR} ]; then
cd $${DIR};
MakeSubDir;
if [ -f makefile -o -f Makefile ]; then
echo "";
pwd;
make all;
fi;
cd ..;
fi;
done;
};
MakeSubDir

tar:
@tar -cf `date +%Y%m%d-%H%M%S`.tar .profile `ls|grep -v ''.tar''`

~/src/lib/LIB_1/makefile文件内容如下:
代码:

ALL: INFO all

BASEDIR = $(HOME)
INC = $(BASEDIR)/inc
LIB = $(BASEDIR)/lib

PRDNAME = $(LIB)/libLIB_1

PRODUCT = $(PRDNAME).a $(PRDNAME).so

OBJS = LIB_1_f1.o LIB_1_f2.o

AR = ar <特定平台ar可选参数>
CC = cc <特定平台cc可选参数>

all: $(PRODUCT)

$(PRDNAME).a: $(OBJS)
@echo " Making $@ ..."
@$(AR) -r $@ $(OBJS)

$(PRDNAME).so: $(OBJS)
@echo " Making $@ ..."
@$(CC) -G -o $@ $(OBJS)

.c.o: *.h $(INC)/*.h
@echo " Compiling $< ..."
@$(CC) -c -I$(INC) $<

INFO:
@echo " make all - same with ''make'' except this message"
@echo " make clear - remove object files"
@echo " make clean - remove all object and target files"
@echo ""

clear: FORCE
@rm -f *.o

clean: FORCE clear
@rm -f $(PRODUCT)

FORCE:

~/src/APP_A/mod_a/makefile文件内容如下:
代码:

ALL: INFO all

BASEDIR = $(HOME)
INC = $(BASEDIR)/inc
LIB = $(BASEDIR)/lib
BIN = $(BASEDIR)/bin

MODULE = $(BIN)/APP_A_mod_a
TESTER = APP_A_mod_a_t
PRODUCT = $(SERVER) $(TESTER)

CC = cc <特定平台cc可选参数>

all: $(PRODUCT)

$(MODULE): APP_A_mod_a.o
@echo " Making $@ ..."
@$(CC) $? -o$@ -L$(LIB) -lLIB_1

APP_A_mod_a_t: APP_A_mod_a_t.o
@echo " Making $@ ..."
@$(CC) $? -o$@ -L$(LIB) -lLIB_1

.c.o: *.h $(INC)/*.h
@echo " Compiling $< ..."
@$(CC) -c -I$(INC) $<

INFO:
@echo " make all - same with ''make'' except this message"
@echo " make clear - remove object files"
@echo " make clean - remove all object and target files"
@echo ""

clear: FORCE
@rm -f *.o

clean: FORCE clear
@rm -f $(PRODUCT)

FORCE:

使用方法:
1.在主目录下使用''make''命令能够首先建立函数库,然后建立所有目标。
2.在主目录下使用''make tar''命令能够对整个系统进行打包,生成的文件以日期和时间命名。
3.在最下层子目录中直接使用''make''命令会首先给出用法提示,然后建立本目录所有目标。
4.在最下层子目录中使用''make all''命令不出现提示信息,直接建立本目录所有目标。
5.在最下层子目录中使用''make clear''命令可以清除本目录的所有.o文件。
6.在最下层子目录中使用''make clean''命令可以清除本目录的所有.o文件和建立的所有目标。

注:在某些环境下,由于make中调用shell命令的机制,可能不支持递归。

posted on 2008-08-25 21:52  y轴  阅读(143)  评论(0编辑  收藏  举报

导航