如何解决变量如何在 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
无效。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。