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!
"。