Makefile ifeq logical AND

冷暖自知 提交于 2019-11-27 02:03:53

问题


I would like to check multiple conditions in an if loop of GNU make file. Here's an example:

ifeq ($(TEST_FLAG),TRUE && ($(DEBUG_FLAG),FALSE))
true statement 
else 
false statement
endif

What's the right way to do it?


回答1:


You can use ifeq with a concatenation of your values, eg.

ifeq ($(TEST_FLAG)$(DEBUG_FLAG),TRUEFALSE)
   do something
endif

It's also possible to use the Conditional functions, which are more likely to be useful in a loop (as ifeq will probably not do what you expect in a loop, it will be tested exactly once).




回答2:


Although Hasturkun's solution will work, I think the idiomatic way to write this is:

ifeq ($(TEST_FLAG),TRUE)
ifeq ($(DEBUG_FLAG),FALSE)
# Stuff
endif
endif


来源:https://stackoverflow.com/questions/6451477/makefile-ifeq-logical-and

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!