Posted on 2009-06-01 14:26
Prayer 閱讀(1228)
評論(0) 編輯 收藏 引用 所屬分類:
LINUX/UNIX/AIX
######################################
# Copyright (c) 1997 George Foot (george.foot@merton.ox.ac.uk)
# All rights reserved.
######################################
#目標(可執行文檔)名稱,庫(譬如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))
#結束
- 原作者是Gorge Foot,寫這個Makefile的時候還是一個學生
- ":="賦值,和"="不同的是,":="在賦值的同時,會將賦值語句中所有的變量就地展開,也就是說,A:=$(B)后,B的值的改變不再影響A
- 隱含規則。GUN Make在不特別指定的情況下會使用諸如以下編譯命令:$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $< -o $@,這也是為什么這個Makefile最后一個命令沒有添加$(CPPFLAGS)的原因,因為缺省是包含這個變量的
- 函數和變量很相似:"$ (函數名,空格,一列由逗號分隔的參數)"
- SOURCES = $(wildcard *.cpp) 列出工作目錄下文件名滿足"*.cpp"條件的文件,以空格分隔,并將列表賦給SOURCE變量
- patsubst函數:3個參數。功能是將第三個參數中的每一項(由空格分隔)符合第一個參數描述的部分替換成第二個參數制定的值
- addprefix函數:2個參數。將源串(第2個參數,由空格分隔)中的每一項添加前綴(第1個參數)
- filter-out函數:2個參數。從第二串中過濾掉包含在第一個串中的項
- $(CC) -MM -MMD $(SOURCE) : 對每個源文件生成依賴(dependence,Make通過依賴規則來判斷是否需要重新編譯某個文件),"D"生成".d"文件,-MM表示去掉 depends里面的系統的頭文件(使用<>包含的頭文件)(若使用-M則全部包含,事實上,系統頭文件被修改的可能性極小,不需要執行依賴檢查)
- .PHONY,不檢查后面制定各項是否存在同名文件
- ifneg...else...endif,Makefile中的條件語句
- -include $(DEPS) : 將DEPS中的文件包含進來,"-"表示忽略文件不存在的錯誤
- @$(RM) *.o : 開頭的"@"表示在Make的時候,不顯示這條命令(GNU Make缺省是顯示的)
- all : 作為第一個出現的目標項目,Make會將它作為主要和缺省項目("make"就表示"make all")
- deps : 只生成依賴文件(.d文件)
- objs : 為每一個源碼程序生成或更新 '.d' 文件和'.o'文件
- clean : 刪除所有'.d','.o'和可執行文件
- rebuild : clean然后重建
- 內部變量$@, $< $^ : 分別表示目標名(:前面的部分,比如all),依靠列表(:后面的部分)中的第一個依靠文件,所有依靠文件