Makefile 变量如果是shell 语句,需要变成执行之后的结果

博客讲述了作者在Makefile中遇到的一个ifeq判断不生效的问题。作者发现`ifeq`可能并不执行命令的结果,而是直接比较字符串。通过使用`shell`命令确保变量`VENDOR`为执行结果后,ifeq语句才正常工作。文章强调了正确理解和使用Makefile中的变量赋值以及条件判断的重要性。
摘要由CSDN通过智能技术生成

在Makefile里面写了如下语句

在shell上执行`cat $(CY_BUILD_DIR)/auto.version |awk 'BEGIN{FS="-"} {print $$4}'`的结果也是HD,但是总是满足不了 ifeq这个语句,想了半天没想明白.

后来执行make -np 把相关调试信息打印出来,发现echo $VENDOR的地方是个语句

怀疑ifeq不是执行之后的结果,所以导致ifeq语句匹配不上,修改VENDOR语句如下:

export VENDOR=$(shell cat $(CY_BUILD_DIR)/auto.version |awk 'BEGIN{FS="-"} {print $$4}')

保证VENDOR是执行之后的结果,就满足ifeq语句了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值