天天看點

Makefile編譯目錄下多個檔案以及函數wildcard用法

編譯多個c檔案一般有兩個功能,一個是每個c檔案都有main函數,就是說每個c檔案的可執行檔案是獨立的,各自是各自的;第二個是多個c檔案用來編譯成一個可執行檔案。

首先說第一個,内容如下,這個makefile是為了編譯opencv代碼的。

[cpp]  view plain copy

  1. CFLAGS= -g -O3 `pkg-config opencv --cflags`  
  2. LIBS = `pkg-config opencv --libs`  
  3. C_SRC = $(wildcard *.c)  
  4. C_OBJ = $(patsubst %c, %o, $(C_SRC))  
  5. CPP_SRC = $(wildcard *.cpp)  
  6. CPP_OBJ = $(patsubst %cpp, %o, $(CPP_SRC))  
  7. .PHONY:all clean  
  8. all:$(CPP_OBJ) $(C_OBJ)  
  9. .c.o:  
  10.     gcc $(CFLAGS) -o [email protected] $< $(LIBS)   
  11. .cpp.o:  
  12.     g++ $(CFLAGS) -o [email protected] $< $(LIBS)  
  13. clean:  
  14.     rm *~ *.o -f  

cflags 和 libs就不說了, c_src和c_obj中,$(wildcard *.c, *.cpp, ***/*.c)是為了找出目錄和指定目錄下所有的字尾為c和cpp的檔案,這個功能也可以使用c_src=$(shell echo *.c)實作。 $(patsubst %cpp, %o, $(CPP_SRC))中是為了将所有的cpp檔案的字尾替換為o檔案,這個功能也可以通過CPP_OBJ=$(CPP_SRC:%.c=%.o)實作 PHONY是僞目标 all後是要生成的所有目标檔案 最後的.c.o和.cpp.o這兩個,是為了通配編譯c字尾和cpp字尾檔案的規則。 這樣即可編譯目錄下所有的源檔案,為各自生成可執行檔案了。 Makefile編譯目錄下多個檔案

參考網址:http://forkhope.diandian.com/post/2012-10-12/40040828841                     http://blog.csdn.net/jernymy/article/details/6401065

                    http://hi.baidu.com/zengzhaonong/item/f07c81e1da455210585dd89a

第二個是編譯所有c檔案,生成一個目标檔案。有了上一個的基礎,第二個目标的例子為 [cpp]  view plain copy

  1. 01 CC = gcc  
  2. 02 LD = gcc  
  3. 03 CFLAGS = -Wall -c -Dgliethttp -I../include -L lib_path  
  4. 04 LDFLAGS = -lpthread  
  5. 05   
  6. 06 SRCS = $(wildcard *.c source/*.c)  
  7. 07 OBJS = $(patsubst %c, %o, $(SRCS))  
  8. 08 TARGET = gliethttp  
  9. 09   
  10. 10 .PHONY: all clean  
  11. 11   
  12. 12 all: $(TARGET)  
  13. 13   
  14. 14 $(TARGET): $(OBJS)  
  15. 15     $(LD) $(LDFLAGS) -o [email protected] $^  
  16. 16   
  17. 17 %o: %c  
  18. 18     $(CC) $(CFLAGS) -o [email protected] $<  
  19. 19   
  20. 20 clean:  
  21. 21     rm -f *.o $(TARGET)  

Makfile相關函數說明:

1、wildcard : 擴充通配符

2、notdir : 去除路徑

3、patsubst :替換通配符

例子:

建立一個測試目錄,在測試目錄下建立一個名為sub的子目錄

$ mkdir test

$ cd test

$ mkdir sub

在test下,建立a.c和b.c2個檔案,在sub目錄下,建立sa.c和sb.c2 個檔案

建立一個簡單的Makefile

src=$(wildcard *.c ./sub/*.c)

dir=$(notdir $(src))

obj=$(patsubst %.c,%.o,$(dir) )

all:

 @echo $(src)

 @echo $(dir)

 @echo $(obj)

 @echo "end"

執行結果分析:

第一行輸出:

a.c b.c ./sub/sa.c ./sub/sb.c

wildcard把 指定目錄 ./ 和 ./sub/ 下的所有字尾是c的檔案全部展開。

第二行輸出:

a.c b.c sa.c sb.c

notdir把展開的檔案去除掉路徑資訊

第三行輸出:

a.o b.o sa.o sb.o

在$(patsubst %.c,%.o,$(dir) )中,patsubst把$(dir)中的變量符合字尾是.c的全部替換成.o,

任何輸出。

或者可以使用

obj=$(dir:%.c=%.o)

效果也是一樣的。

這裡用到makefile裡的替換引用規則,即用您指定的變量替換另一個變量。

它的标準格式是

$(var:a=b) 或 ${var:a=b}

它的含義是把變量var中的每一個值結尾用b替換掉a

繼續閱讀