From e0b4c8433c54ec702276e85dbed10df455c0bb8a Mon Sep 17 00:00:00 2001 From: glx22 Date: Fri, 4 Aug 2023 22:35:26 +0200 Subject: [PATCH] Fix: delay disable_item 'id' validations to allow use of user-defined constants --- nml/ast/disable_item.py | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/nml/ast/disable_item.py b/nml/ast/disable_item.py index 076265e1..f2edf10c 100644 --- a/nml/ast/disable_item.py +++ b/nml/ast/disable_item.py @@ -39,18 +39,17 @@ def __init__(self, param_list, pos): "disable_item() requires between 1 and 3 parameters, encountered {:d}.".format(len(param_list)), pos ) self.feature = general.parse_feature(param_list[0]) + self.first_id = param_list[1] if len(param_list) > 1 else None + self.last_id = param_list[2] if len(param_list) > 2 else None - if len(param_list) > 1: - self.first_id = param_list[1].reduce_constant(global_constants.const_list) - else: - self.first_id = None + def pre_process(self): + if self.first_id is not None: + self.first_id = self.first_id.reduce_constant(global_constants.const_list) - if len(param_list) > 2: - self.last_id = param_list[2].reduce_constant(global_constants.const_list) + if self.last_id is not None: + self.last_id = self.last_id.reduce_constant(global_constants.const_list) if self.last_id.value < self.first_id.value: - raise generic.ScriptError("Last id to disable may not be lower than the first id.", pos) - else: - self.last_id = None + raise generic.ScriptError("Last id to disable may not be lower than the first id.", self.last_id.pos) def debug_print(self, indentation): generic.print_dbg(indentation, "Disable items, feature=" + str(self.feature.value))