Makefile ifneq和filter语句

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zxc024000/article/details/80284978

Makefile语句

  • 某项目中mk文件中,用到了ifneq和filter。发现它们俩搭配时,蛮有用的。

ifneq语句

  • ifneq : 判断语句,用于比较两个参数,如果两个参数不等,则该语句通过
# 如果a和b不相等,则do something
ifneq ($(a), $(b))
    # do something
endif

filter语句

  • filter: 过滤语句,过滤调不符合指定的模式的内容。仅保留符合指定的模式的内容。
sources := a b c d f g
# 指定的模式为 a b c ,多个模式间,用空格区分
$(filter a b c , $(sources))
# 上式返回值为
# a b c

ifneq + filter

  • 场景:某项目多个版本(A,B, C),同时进行开发。除了代码中的一些宏开关外,在编译时,也需要进行不同版本的判断。
  • 接上:版本A、B,编译某模块时需要一个特殊参数。版本C,编译该模块时,不需要该特殊参数。如何控制?
# 如果 TARGET 为A 或 B(即不为空),那么加入某些特殊参数
# 这里ifneq第二个参数为NULL
ifneq ($(filter A B , $(TARGET)),)
   #某些特殊参数
endif

猜你喜欢

转载自blog.csdn.net/zxc024000/article/details/80284978