######################################
# Copyright (c) 1997 George Foot (george.foot@merton.ox.ac.uk)
# All rights reserved.
######################################
#目標(biāo)(可執(zhí)行文檔)名稱,庫(譬如stdcx,iostr,mysql等),頭文件路徑
DESTINATION := test
LIBS :=
INCLUDES := .
RM := rm -f
#C,CC或CPP文件的后綴
PS=cpp
# GNU Make的隱含變量定義
CC=g++
CPPFLAGS = -g -Wall -O3 -march=i486
CPPFLAGS += $(addprefix -I,$(INCLUDES))
CPPFLAGS += -MMD
#以下部分無需修改
SOURCE := $(wildcard *.$(PS))
OBJS := $(patsubst %.$(PS),%.o,$(SOURCE))
DEPS := $(patsubst %.o,%.d,$(OBJS))
MISSING_DEPS := $(filter-out $(wildcard $(DEPS)),$(DEPS))
MISSING_DEPS_SOURCES := $(wildcard $(patsubst %.d,%.$(PS),$(MISSING_DEPS)))
.PHONY : all deps objs clean rebuild
all : $(DESTINATION)
deps : $(DEPS)
$(CC) -MM -MMD $(SOURCE)
objs : $(OBJS)
clean :
@$(RM) *.o
@$(RM) *.d
@$(RM) $(DESTINATION)
rebuild: clean all
ifneq ($(MISSING_DEPS),)
$(MISSING_DEPS) :
@$(RM) $(patsubst %.d,%.o,$@)
endif
-include $(DEPS)
$(DESTINATION) : $(OBJS)
$(CC) -o $(DESTINATION) $(OBJS) $(addprefix -l,$(LIBS))
#結(jié)束
- 原作者是Gorge Foot,寫這個(gè)Makefile的時(shí)候還是一個(gè)學(xué)生
- ":="賦值,和"="不同的是,":="在賦值的同時(shí),會(huì)將賦值語句中所有的變量就地展開,也就是說,A:=$(B)后,B的值的改變不再影響A
- 隱含規(guī)則。GUN Make在不特別指定的情況下會(huì)使用諸如以下編譯命令:$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $< -o $@,這也是為什么這個(gè)Makefile最后一個(gè)命令沒有添加$(CPPFLAGS)的原因,因?yàn)槿笔∈前@個(gè)變量的
- 函數(shù)和變量很相似:"$ (函數(shù)名,空格,一列由逗號(hào)分隔的參數(shù))"
- SOURCES = $(wildcard *.cpp) 列出工作目錄下文件名滿足"*.cpp"條件的文件,以空格分隔,并將列表賦給SOURCE變量
- patsubst函數(shù):3個(gè)參數(shù)。功能是將第三個(gè)參數(shù)中的每一項(xiàng)(由空格分隔)符合第一個(gè)參數(shù)描述的部分替換成第二個(gè)參數(shù)制定的值
- addprefix函數(shù):2個(gè)參數(shù)。將源串(第2個(gè)參數(shù),由空格分隔)中的每一項(xiàng)添加前綴(第1個(gè)參數(shù))
- filter-out函數(shù):2個(gè)參數(shù)。從第二串中過濾掉包含在第一個(gè)串中的項(xiàng)
- $(CC) -MM -MMD $(SOURCE) : 對(duì)每個(gè)源文件生成依賴(dependence,Make通過依賴規(guī)則來判斷是否需要重新編譯某個(gè)文件),"D"生成".d"文件,-MM表示去掉 depends里面的系統(tǒng)的頭文件(使用<>包含的頭文件)(若使用-M則全部包含,事實(shí)上,系統(tǒng)頭文件被修改的可能性極小,不需要執(zhí)行依賴檢查)
- .PHONY,不檢查后面制定各項(xiàng)是否存在同名文件
- ifneg...else...endif,Makefile中的條件語句
- -include $(DEPS) : 將DEPS中的文件包含進(jìn)來,"-"表示忽略文件不存在的錯(cuò)誤
- @$(RM) *.o : 開頭的"@"表示在Make的時(shí)候,不顯示這條命令(GNU Make缺省是顯示的)
- all : 作為第一個(gè)出現(xiàn)的目標(biāo)項(xiàng)目,Make會(huì)將它作為主要和缺省項(xiàng)目("make"就表示"make all")
- deps : 只生成依賴文件(.d文件)
- objs : 為每一個(gè)源碼程序生成或更新 '.d' 文件和'.o'文件
- clean : 刪除所有'.d','.o'和可執(zhí)行文件
- rebuild : clean然后重建
- 內(nèi)部變量$@, $< $^ : 分別表示目標(biāo)名(:前面的部分,比如all),依靠列表(:后面的部分)中的第一個(gè)依靠文件,所有依靠文件