通用的Makefile及解釋

通用的Makefile及解釋

######################################
# Copyright (c) 1997 George Foot ([email protected])
# 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))
#結束
  • ":="賦值,和"="不同的是,":="在賦值的同時,會將賦值語句中所有的變量就地展開,也就是說,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),依靠列表(:後面的部分)中的第一個依靠文件,所有依靠文件

Makefile 更詳細使用總結:http://www.cnblogs.com/wang_yb/p/3990952.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章