GNU Make 总结篇

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/for_cxc/article/details/89004862

您需要一个名为makefile的文件来告诉make要做什么。通常,makefile告诉make如何编译和链接程序。

一个简单的Makefile:

edit : main.o kbd.o command.o display.o insert.o search.o files.o utils.o
cc -o edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
main.o : main.c defs.h
cc -c main.c
kbd.o : kbd.c defs.h command.h
cc -c kbd.c
command.o : command.c defs.h command.h
cc -c command.c
display.o : display.c defs.h buffer.h
cc -c display.c
insert.o : insert.c defs.h buffer.h
cc -c insert.c
search.o : search.c defs.h buffer.h
cc -c search.c
files.o : files.c defs.h buffer.h command.h
cc -c files.c
utils.o : utils.c defs.h
cc -c utils.c
clean :
rm edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o

To use this makefile to create the executable file called edit, type:
make
To use this makefile to delete the executable file and all the object files from the directory,
type:
make clean

上面是一个文件依赖树,有文件更新就会按规则重新生成。

每个makefile都有一个名为object、object、objs、objs、obj或obj的变量,obj是所有对象文件名的列表,这是标准实践。

我们将在makefile中定义这样一个变量对象,其中包含这样一行:

objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o

然后,在我们希望放置对象文件名列表的每个位置,我们可以通过写入' $(objects) '来替换变量的值。

下面是完整的简单makefile的外观,当您为对象文件使用一个变量时:

objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit : $(objects)
cc -o edit $(objects)
main.o : main.c defs.h
cc -c main.c
kbd.o : kbd.c defs.h command.h
cc -c kbd.c
command.o : command.c defs.h command.h
cc -c command.c
display.o : display.c defs.h buffer.h
cc -c display.c
insert.o : insert.c defs.h buffer.h
cc -c insert.c
search.o : search.c defs.h buffer.h
cc -c search.c
files.o : files.c defs.h buffer.h command.h
cc -c files.c
utils.o : utils.c defs.h
cc -c utils.c
clean :
rm edit $(objects)

使用隐式规则还有更简单的写法:

objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit : $(objects)
cc -o edit $(objects)
main.o : defs.h
kbd.o : defs.h command.h
command.o : defs.h command.h
display.o : defs.h buffer.h
insert.o : defs.h buffer.h
search.o : defs.h buffer.h
files.o : defs.h buffer.h command.h
utils.o : defs.h
.PHONY : clean
clean :
rm edit $(objects)

另一种风格的Makefile:

objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit : $(objects)
cc -o edit $(objects)
$(objects) : defs.h
kbd.o command.o files.o : command.h
display.o insert.o search.o files.o : buffer.h

Makefile包含5类东西:显式规则、隐式规则、变量定义、指令、注释

默认情况下,当make寻找Makefile文件时,它按照如下顺序:
GNUmakefile、makefile、Makefile

或者make提供了一个 -f 选项可以指定一个文件作为Makefile

可以使用include指令来包含其它的Makefile,例如:

include foo *.mk $(bar)
等价于
include foo a.mk b.mk c.mk bish bash

猜你喜欢

转载自blog.csdn.net/for_cxc/article/details/89004862