一.makefile中的include关键字
类似C语言中的include
将其他文件的内容原封不动的搬入当前文件
make对include关键字的处理方式:
在当前目录搜索或指定目录搜索目标文件
搜索成功:将文件内容搬入当前makefile中
搜索失败:产生警告,并以文件名作为目标查找并执行对应规则
实验1 :当前目录中没有 test.txt文件,makefile 中有对应规则
.PHONY : all
include test.txt
all :
@echo "this is all"
test.txt :
@echo "test.txt"
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ make all
makefile:4: test.txt: No such file or directory
this is test.txt
this is all
mhr@ubuntu:~/work/makefile1$
实验2 :makefile 中 没有 include关键字后面 所对应的目标,当前目录也没有对应文件
.PHONY : all
include test.txt
all :
@echo "this is all"
/makefile1$ make all
makefile:4: test.txt: No such file or directory
make: *** No rule to make target 'test.txt'. Stop.
mhr@ubuntu:~/work/makefile1$
实验3:当前目录中没有 test.txt文件,makefile 中有对应规则,并在规则中创建 test.txt .执行两次 make all
.PHONY : all
include test.txt
all :
@echo "this is all"
test.txt :
@echo "test.txt"
#创建 test.txt
@touch test.txt
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ ls
func.c func.h func.o hello.out main.c main.o makefile
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ make all
makefile:5: test.txt: No such file or directory
this is test.txt
this is all
mhr@ubuntu:~/work/makefile1$ ls
func.c func.h func.o hello.out main.c main.o makefile test.txt
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ make all
this is all
mhr@ubuntu:~/work/makefile1$
第一次执行 make all 时候,执行include关键字 所对应的规则,打印字符串病创建 test.txt文件。结果在当前目录生成了test.txt文件。
第二次执行 make all的时候,include关键字找到了 对应的test,txt文件,于是将 test.txt文件里面的内容拷贝过来了,就没必要再去执行 对应的规则了。
二.makefile中命令的执行机制
规则中的每个命令默认是在一个新的进程中执行(shell)
可以通过接续符(;)将多个命令组合成一个命令
组成的命令依次在同一进程中被执行
实验 :规则中的每一个命令默认是在一个新的进程中执行
.PHONY : all
all :
mkdir test
cd test
mkdir subtest
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ make
mkdir test
cd test
mkdir subtest
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ ls -l
total 48
-rw-rw-r-- 1 mhr mhr 93 Dec 27 04:13 func.c
-rw-rw-r-- 1 mhr mhr 83 Dec 27 05:58 func.h
-rw-rw-r-- 1 mhr mhr 1552 Dec 27 05:58 func.o
-rwxrwxr-x 1 mhr mhr 8656 Dec 27 05:58 hello.out
-rw-rw-r-- 1 mhr mhr 81 Dec 27 04:13 main.c
-rw-rw-r-- 1 mhr mhr 1368 Dec 27 05:58 main.o
-rw-rw-r-- 1 mhr mhr 62 Dec 27 07:02 makefile
drwxrwxr-x 2 mhr mhr 4096 Dec 27 07:03 subtest
drwxrwxr-x 2 mhr mhr 4096 Dec 27 07:03 test
-rw-rw-r-- 1 mhr mhr 28 Dec 27 06:57 test.txt
mhr@ubuntu:~/work/makefile1$
结果是分别创建了test 和 subtest文件夹,并不是我们想要的结果。就是因为makefile 中 规则中的每一个命令默认是在一个新的进程中执行,上面规则中的三个命令是在三个进程中执行的 没有连贯性
进程x :mkdir test
进程结束
进程y: cd test
进程结束
进程z:mkdir subtest
进程结束
实验:规则中的每一个命令默认是在一个新的进程中执行,使用接续符让所有命令在同一进程中执行。
注意 这里的 \ 仅仅是格式的连接符,表示这些代码在同一行。而 ;才是makefile的命令接续符,表示这些命令在同一个进程中执行。
.PHONY : all
all :
set -e; \
mkdir test; \
cd test; \
mkdir subtest
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ make
set -e; \
mkdir test; \
cd test; \
mkdir subtest
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ ll
total 52
drwxrwxr-x 3 mhr mhr 4096 Dec 27 07:10 ./
drwxrwxr-x 4 mhr mhr 4096 Dec 15 03:18 ../
-rw-rw-r-- 1 mhr mhr 93 Dec 27 04:13 func.c
-rw-rw-r-- 1 mhr mhr 83 Dec 27 05:58 func.h
-rw-rw-r-- 1 mhr mhr 1552 Dec 27 05:58 func.o
-rwxrwxr-x 1 mhr mhr 8656 Dec 27 05:58 hello.out*
-rw-rw-r-- 1 mhr mhr 81 Dec 27 04:13 main.c
-rw-rw-r-- 1 mhr mhr 1368 Dec 27 05:58 main.o
-rw-rw-r-- 1 mhr mhr 79 Dec 27 07:07 makefile
drwxrwxr-x 3 mhr mhr 4096 Dec 27 07:10 test/
-rw-rw-r-- 1 mhr mhr 28 Dec 27 06:57 test.txt
mhr@ubuntu:~/work/makefile1$ cd test/
mhr@ubuntu:~/work/makefile1/test$ ll
total 12
drwxrwxr-x 3 mhr mhr 4096 Dec 27 07:10 ./
drwxrwxr-x 3 mhr mhr 4096 Dec 27 07:10 ../
drwxrwxr-x 2 mhr mhr 4096 Dec 27 07:10 subtest/
mhr@ubuntu:~/work/makefile1/test$