Linux MakeFile (编写、函数以及指定位置存放)


 

Linux MakeFile (编写、函数以及指定位置存放)

  1 1、MakeFile 编写
  2 正如前面所说的,如果一个工程有3个头文件,和8个C文件,我们为了完成前面所述的那三个规则,我们的Makefile应该是下面的这个样子的。
  3 
  4 
  5 edit : main.o kbd.o command.o display.o \
  6     insert.o search.o files.o utils.o
  7     cc -o edit main.o kbd.o command.o display.o \
  8     insert.o search.o files.o utils.o
  9 main.o : main.c defs.h
 10     cc -c main.c
 11 kbd.o : kbd.c defs.h command.h
 12     cc -c kbd.c
 13 command.o : command.c defs.h command.h
 14     cc -c command.c
 15 display.o : display.c defs.h buffer.h
 16     cc -c display.c
 17 insert.o : insert.c defs.h buffer.h
 18     cc -c insert.c
 19 search.o : search.c defs.h buffer.h
 20     cc -c search.c
 21 files.o : files.c defs.h buffer.h command.h
 22     cc -c files.c
 23 utils.o : utils.c defs.h
 24     cc -c utils.c
 25 clean :
 26     rm edit main.o kbd.o command.o display.o \
 27     insert.o search.o files.o utils.o
 28 
 29 
 30 反斜杠(\)是换行符的意思。这样比较便于Makefile的易读。我们可以把这个内容保存在文件为“Makefile”或“makefile”的文件中,然后在该目录下直接输入命令“make”就可
 31 以生成执行文件edit。如果要删除执行文件和所有的中间目标文件,那么,只要简单地执行一下“make clean”就可以了。
 32 
 33 第一次优化
 34 本段 Makefile 用到了三处啊 main.o ..,故用一个变量去代替
 35 
 36 
 37 objects = main.o kbd.o command.o display.o \
 38     insert.o search.o files.o utils.o
 39 edit : $(objects)
 40     cc -o edit $(objects)
 41 main.o : main.c defs.h
 42     cc -c main.c
 43 kbd.o : kbd.c defs.h command.h
 44     cc -c kbd.c
 45 command.o : command.c defs.h command.h
 46     cc -c command.c
 47 display.o : display.c defs.h buffer.h
 48     cc -c display.c
 49 insert.o : insert.c defs.h buffer.h
 50     cc -c insert.c
 51 search.o : search.c defs.h buffer.h
 52     cc -c search.c
 53 files.o : files.c defs.h buffer.h command.h
 54     cc -c files.c
 55 utils.o : utils.c defs.h
 56     cc -c utils.c
 57 clean :
 58     rm edit $(objects)
 59 
 60 第二次优化
 61 试想如果我们的“%.o”有几百个,此时上述方法肯定很繁琐,下述方法是常用的。
 62 
 63 CFLAGS=  
 64 LIBS = 
 65 CC=gcc
 66 project=outputName
 67  
 68 objects=main.o kbd.o command.o display.o \
 69     insert.o search.o files.o utils.o
 70 $(project):$(objects)
 71     $(CC) $< -o $@
 72 $(objects):%.o:%.c
 73     $(CC) $(CFLAGS)  -c $< $(LIBS)
 74 clean :
 75     rm  $(objects)  $(project) 
 76 这个是一个简洁版的:
 77 
 78 all:commtest
 79 CFLAGS=-fPIC -g -Wall
 80 ARIA_INCLUDE=-I/usr/local/Aria/include
 81 ARIA_LINK=-L/usr/local/Aria/lib -lAria -lpthread -ldl -lrt
 82  
 83 %: %.cpp
 84     $(CXX) $(CFLAGS) $(ARIA_INCLUDE) $< -o $@ $(ARIA_LINK)
 85 .PHONY:clean
 86 clean:
 87     rm -f commtest *.o
 88 2、MakeFile 函数
 89 在Makefile规则中,通配符会被自动展开。但在变量的定义和函数引用时,通配符将失效。这种情况下如果需要通配符有效,就需要使用函数“wildcard”,它的用法是:$(wildcard PATTERN...) 。在Makefile中,它被展开为已经存在的、使用空格分开的、匹配此模式的所有文件列表。如果不存在任何符合此模式的文件,函数会忽略模式字符并返回空。需要注意的是:这种情况下规则中通配符的展开和上一小节匹配通配符的区别。
 90 
 91 一般我们可以使用“$(wildcard *.c)”来获取工作目录下的所有的.c文件列表。复杂一些用法;可以使用“$(patsubst %.c,%.o,$(wildcard *.c))”,首先使用“wildcard”函数获取工作目录下的.c文件列表;之后将列表中所有文件名的后缀.c替换为.o。这样我们就可以得到在当前目录可生成的.o文件列表。因此在一个目录下可以使用如下内容的Makefile来将工作目录下的所有的.c文件进行编译并最后连接成为一个可执行文件:
 92 
 93 
 94 CFLAGS=  
 95 LIBS =  
 96 C_SRC = $(wildcard *.c)  
 97 C_OBJ = $(patsubst %c, %o, $(C_SRC))  
 98 CPP_SRC = $(wildcard *.cpp)  
 99 CPP_OBJ = $(patsubst %cpp, %o, $(CPP_SRC))  
100   
101 .PHONY:all clean  
102   
103 all:$(CPP_OBJ) $(C_OBJ)  
104   
105 %.o:%.c  
106     gcc $(CFLAGS) -o $@ $< $(LIBS)   
107 %.o:%.c  
108     g++ $(CFLAGS) -o $@ $< $(LIBS)  
109   
110   
111 clean:  
112     rm *~ *.o -f  
113 
114 下面我们要介绍的函数主要是处理文件名的。每个函数的参数字符串都会被当做一个或是一系列的文件名来对待。
115 $(dir ) 名称:取目录函数——dir。功能:从文件名序列中取出目录部分。目录部分是指最后一个反斜杠(“/”)之前的部分。如果没有反斜杠,那么返回“./”。返回:返回文件名序列的目录部分。示例: $(dir src/foo.c hacks)返回值是“src/ ./”。
116 $(notdir ) 名称:取文件函数——notdir。功能:从文件名序列中取出非目录部分。非目录部分是指最后一个反斜杠(“/”)之后的部分。返回:返回文件名序列的非目录部分。示例: $(notdir src/foo.c hacks)返回值是“foo.c hacks”。
117 $(suffix ) 名称:取后缀函数——suffix。功能:从文件名序列中取出各个文件名的后缀。返回:返回文件名序列的后缀序列,如果文件没有后缀,则返回空字串。示例:$(suffix src/foo.c src-1.0/bar.c hacks)返回值是“.c .c”。
118 $(basename )名称:取前缀函数——basename。功能:从文件名序列中取出各个文件名的前缀部分。返回:返回文件名序列的前缀序列,如果文件没有前缀,则返回空字串。示例:$(basename src/foo.c src-1.0/bar.c hacks)返回值是“src/foo src-1.0/bar hacks”。
119 $(addsuffix , ) 名称:加后缀函数——addsuffix。功能:把后缀加到中的每个单词后面。返回:返回加过后缀的文件名序列。示例:$(addsuffix .c,foo bar)返回值是“foo.c bar.c”。
120 $(addprefix , ) 名称:加前缀函数——addprefix。功能:把前缀加到中的每个单词后面。返回:返回加过前缀的文件名序列。示例:$(addprefix src/,foo bar)返回值是“src/foo src/bar”。
121 $(join , )名称:连接函数——join。功能:把中的单词对应地加到的单词后面。如果的单词个数要比的多,那么,中的多出来的单词将保持原样。如果的单词个数要比多,那么,多出来的单词将被复制到中。返回:返回连接过后的字符串。示例:$(join aaa bbb , 111 222 333)返回值是“aaa111 bbb222 333”。
122 
123 3、指定输出文件存放位置
124 
125 最常用的方法就是,需要先创建一个目录去存储
126 
127 
128 CFLAGS=  
129 LIBS =
130 CC=gcc
131 OBJDIR=./dir
132 project=$(OBJDIR)/outputName  
133 C_SRC = $(wildcard *.c)  
134 C_OBJ = $(patsubst %c, %o, $(C_SRC))  
135 CPP_SRC = $(wildcard *.cpp)  
136 CPP_OBJ = $(patsubst %cpp, %o, $(CPP_SRC))  
137           
138 $(project):$(CPP_OBJ) $(C_OBJ)  
139     $(CC) $(CFLAGS) -o $@ $< $(LIBS)
140 %.o:%.c  
141     $(CC) $(CFLAGS) -c $< $(LIBS)   
142 %.o:%.cpp  
143     $(CC)++ $(CFLAGS) -o $< $(LIBS)  
144 .PHONY:clean
145 clean:  
146     rm *~ *.o -f $(project) 
147 
148 倘若这个目录不存在呢?这个时候应该先创建这个目录,再编译

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM