请阅读【ARM GCC Makefile 编译专栏导读】

Makefile 解析阶段的打印函数

Makefile中,除了使用echo命令打印信息外,还可以使用$(info )$(warning )$(error )函数。

$(info ):这个函数用于在解析Makefile时打印一些信息。它不会像echo那样等到目标被执行时才打印,而是在Makefile解析时就会打印。例如:

$(info "Start parsing the makefile") 
all: 
	@echo "Compiling the program..."

这将在make all命令执行之前就打印出"Start parsing the makefile"。

$(warning ):这个函数用于在解析Makefile时打印一些警告信息,并继续解析和执行。例如:

$(warning "This is a warning") 
all: 
	@echo "Compiling the program..."

这将在解析Makefile时打印出"This is a warning",然后继续解析和执行。

$(error ):这个函数用于在解析Makefile时打印一些错误信息,并停止解析和执行。例如:

$(error "This is an error") 
all: 
	@echo "Compiling the program..."

这将在解析Makefile时打印出"This is an error",然后停止解析和执行。$(error )函数通常用于在某些条件不满足时停止Makefile的执行。

注意,这三个函数都是在 Makefile 解析阶段,而不是目标执行阶段打印信息的,所以它们通常用于打印一些Makefile本身的信息,而不是目标的执行结果

Makefile 中如何打印变量?

Makefile中,我们可以使用$(info )函数或echo命令来打印变量的值。

例如,假设我们在Makefile中定义了一个变量SRC,并且我们想要打印其值,我们可以采用以下两种方法

使用$(info )函数

SRC = main.c foo.c bar.c 
all: 
	$(info $(SRC))

当我们运行make all时,Make将在解析Makefile时打印出SRC变量的值。

使用echo命令

SRC = main.c foo.c bar.c 
all: 
	@echo $(SRC)

当我们运行make all时,Make将在执行all目标时打印出SRC变量的值。

注意,在使用echo命令时,我们通常在命令前面加上一个@字符,这样Make就不会打印出命令本身,只会打印出命令的输出。

另外,如果你的变量的值包含了空格或者特殊字符,你可能需要用引号来保护它们,例如@echo "$(SRC)"

Makefile 中如何打印字符串?

在Makefile中,我们可以用$(info )函数和echo命令来打印字符串。以下是一些示例:

使用$(info )函数打印字符串:

all: 
	$(info "Hello, World!")

这将在解析Makefile时打印出"Hello, World!"。

使用echo命令打印字符串:

all: 
	@echo "Hello, World!"

这将在执行all目标时,打印出"Hello, World!"。注意,我们在命令前面加上@以避免Make打印出命令本身。

使用变量和字符串:

MESSAGE = "Hello, World!" 
all: 
	$(info $(MESSAGE)) 
	@echo $(MESSAGE)

上面的两行命令分别在解析Makefile和执行all目标时,打印出"Hello, World!"。

Logo

技术共进,成长同行——讯飞AI开发者社区

更多推荐