变量如何在 makefile 中扩展?

问题描述

在这个简单的 makefile 中:

var = foo

func = $(info $1 -> $($1) )

$(call func,var)

我希望 $($1) 扩展为 foo,但输出

 var ->  

为什么?以及如何让它发挥作用?

解决方法

不幸的是,make 对空格的处理不一致。一般来说,编写 makefile 时最好的经验法则是,永远不要在变量和函数中不需要的地方使用空格。

这里的问题是 $(call func,var)$1 设置为值“ var”(即包含空格)。在许多情况下,这不是问题,但在这种情况下,这意味着当您使用 $($1) 时,它会扩展为 $( var),这当然不是一个集合变量。

如果删除空格:

$(call func,var)

它会起作用。

根据规则 make 通常 使用这不应该发生,因为 make 的正常规则是忽略 前面 空格和 后续 空格被保留下来。但不幸的是,该规则似乎对 call 无效。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...