命令模式——示例——程序组织

#在内核中将生成的目标文件与源文件放在一起,此处将生成的目标文件放在一个目录下,类似于 android的lk目录下的组织。
#当头文件更新时,更新cpp文件的时间戳,进而重新生成依赖文件,并执行源文件到目标文件的编译。
#tools目录下的depend.sh,可以直接写在Makefile中,但是太长,所以单独列出。
#本文件在运行时,显示“has modification time 3.2e+05s in the future",系统的时间混乱了(强制关机时,ubuntu好像都这样),设置正确的系统时间即可
#如您无意看到此肆文(当然,所有内容均备自己查阅),有不当之处,请指出。
 1 # Makefile

 2 
 3 #关于下文中{}与()的不良用法说明:
4 #1、承如徐海兵先生译文所述,应保文件中()与{}用法的一致性。 5 #2、本实例中之所以没有在环境中统一()与{}的用法,但秉承: 6 # ()用于函数调用 7 # {}用于变量 8 # 原因在于:bash中区分()与{},so…….如果先学习Makefile,请遵循良好的习惯 9 10 include rule.mk 11 target = mytest 12 GCC = g++ 13 14 .PHONY : all 15 all : ${target} 16 17 ${target} : ${objects} 18 ${Q}${GCC} -o $@ $^ 19 20 #注意: 21 # include 放在最终目标关系之下,否则会造成将include文件的目标作为最终目标 22 ifneq ($(filter-out distclean clean tags, ${MAKECMDGOALS}), ) 23 -include ${depends} 24 endif 25 ifeq (${MAKECMDGOALS}, ) 26 sinclude ${depends} 27 endif 28 29 #1、此处主要生成cpp与h之间的依赖关系 30 # 一般情况下,cpp与h之间没有什么依赖关系, 31 # 在depened.sh中主要是在命令行写明:如相关的h文件变化,则更新cpp的时间戳, 32 # 从而使得目标文件也变化. 33 #2、当然我们也可以轻松地写出:%.d, %.o: %.cpp的规则,承如徐海兵先生译文所示; 34 # 此处则采用如上1中解释所述的规则(自造). 35 #3、使用续航符,以使得在同一shell进程中执行. 36 #4、@放在行首. 37 ${DEP}/%.d : ${CUR_DIR}/%.cpp 38 ${Q}${GCC} -MM ${CFLAGS} $< -MF $@; \ 39 mv $@ $@.$$$$; \ 40 /bin/bash tools/depend.sh $@.$$$$ > $@; \ 41 rm $@.$$$$ 42 43 ${OBJ}/%.o : ${CUR_DIR}/%.cpp 44 ${Q} ${GCC} -c ${CFLAGS} $< -o $@ 45 46 47 .PHONY : distclean clean tags 48 distclean : clean 49 -$(RM) -r tags 50 51 clean : 52 -$(RM) -r ${target} ${OBJ} ${DEP} 53 54 tags : 55 ctags -R 56 57 .PHONY: FROCE 58 FORCE : ;
 1 # rule.mk

 2 

 3 # V=1时不显示命令执行过程

 4 ifeq ("$(origin V)", "command line")

 5   BUILD_VERBOSE = ${V}

 6 endif

 7 ifndef BUILD_VERBOSE

 8   BUILD_VERBOSE = 0

 9 endif

10 

11 ifeq (${BUILD_VERBOSE}, 1)

12   Q = @

13 else

14   Q = 

15 endif

16 

17 SHELL := /bin/bash

18 

19 CUR_DIR := $(shell pwd)

20 

21 INCS := ${CUR_DIR}/include

22 CFLAGS := -Wall -I${INCS}

23 

24 DEP := ${CUR_DIR}/depend

25 

26 OBJ := ${CUR_DIR}/object

27 

28 ifeq ($(wildcard ${DEP}), )

29   $(shell mkdir -p ${DEP})

30 endif

31 

32 ifeq ($(wildcard ${OBJ}), )

33   $(shell mkdir -p ${OBJ})

34 endif

35 

36 src_cpp = $(wildcard *.cpp)

37 objects = $(patsubst %.cpp, ${OBJ}/%.o, $(src_cpp))

38 depends = $(patsubst %.cpp, ${DEP}/%.d, $(src_cpp))
 
    
 1 #! /bin/sh

 2 

 3 depend_temp=/tmp/depend.$$$$

 4 rm -rf ${depend_temp}

 5                                                                                                                     

 6 #注意对首行的解析,尤其是续航符后不能有其它字符(立即换行)

 7 #sed -n -e '1p' $1 | cut -d ' ' -f 2- | awk 'BEGIN{x = 1} {printf "%s : ", $x; x++} END {while (x < NF) {printf "%s", $x; x++} if(NF > 1){printf "%s" ,$NF} printf "\n"}' > ${depend_temp}

 8 

 9 sed -n -e '1p' $1 | cut -d ' ' -f 2- > ${depend_temp}

10 

11 sed -n -e '1p' ${depend_temp} | grep '^\\' 1>&/dev/null && rm ${depend_temp} && touch ${depend_temp}

12 

13 awk 'NR>1 {print $0}' $1 >> ${depend_temp}

14 #tail -n +2 $1 >> ${depend_temp}

15 

16 cp ${depend_temp} ${depend_temp}.bak

17 

18 rm ${depend_temp} && touch ${depend_temp}

19 

20 sed -n -e '1p' ${depend_temp}.bak | awk 'BEGIN{x =1 }  {printf "%s : ", $x; x++} END{while (x < NF) {printf "%s", $x; x++} if(NF >1) {printf "%s", $NF} printf "\n"}' > ${depend_temp}

21 awk 'NR>1 {print $0}' ${depend_temp}.bak >> ${depend_temp}

22 rm ${depend_temp}.bak

23 

24 add_line=`head -n 1 ${depend_temp} | cut -d ' ' -f 1`

25 #在最后一行加入touch命令

26 #${parameter%word},可以看下bash中的此用法

27 echo -e "\ttouch ${add_line}" >> ${depend_temp}

28 cat ${depend_temp}

29 

30 rm -rf ${depend_temp}
 
    

 

 
   

 

你可能感兴趣的:(命令模式)