From: Marc-André Lureau <marcandre.lur...@redhat.com> Refactor IfAll class, to introduce a base class IfPredicateList and add IfAny for the 'any' conditions.
Signed-off-by: Marc-André Lureau <marcandre.lur...@redhat.com> Reviewed-by: Stefan Hajnoczi <stefa...@redhat.com> Tested-by: John Snow <js...@redhat.com> --- scripts/qapi/common.py | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/scripts/qapi/common.py b/scripts/qapi/common.py index 86dc2b228b..4e5c3ebaae 100644 --- a/scripts/qapi/common.py +++ b/scripts/qapi/common.py @@ -239,15 +239,26 @@ def __eq__(self, other: object) -> bool: return self.option == other.option -class IfAll(IfPredicate): +class IfPredicateList(IfPredicate): + C_SEP = "" + DOC_SEP = "" + def __init__(self, pred_list: Sequence[IfPredicate]): self.pred_list = pred_list def cgen(self) -> str: - return " && ".join([p.cgen() for p in self.pred_list]) + sep = " " + self.C_SEP + " " + gen = sep.join([p.cgen() for p in self.pred_list]) + if len(self.pred_list) <= 1: + return gen + return "(%s)" % gen def docgen(self) -> str: - return " and ".join([p.docgen() for p in self.pred_list]) + sep = " " + self.DOC_SEP + " " + gen = sep.join([p.docgen() for p in self.pred_list]) + if len(self.pred_list) <= 1: + return gen + return "(%s)" % gen def __bool__(self) -> bool: return bool(self.pred_list) @@ -256,6 +267,16 @@ def __repr__(self) -> str: return f"{type(self).__name__}({self.pred_list!r})" def __eq__(self, other: object) -> bool: - if not isinstance(other, IfAll): + if not isinstance(other, type(self)): return NotImplemented return self.pred_list == other.pred_list + + +class IfAll(IfPredicateList): + C_SEP = "&&" + DOC_SEP = "and" + + +class IfAny(IfPredicateList): + C_SEP = "||" + DOC_SEP = "or" -- 2.29.0