Skip to content

Commit

Permalink
Fix: Register named parameters earlier (#301)
Browse files Browse the repository at this point in the history
  • Loading branch information
glx22 authored Nov 1, 2023
1 parent 58ee7b7 commit 2491279
Showing 1 changed file with 13 additions and 9 deletions.
22 changes: 13 additions & 9 deletions nml/actions/actionD.py
Original file line number Diff line number Diff line change
Expand Up @@ -91,16 +91,9 @@ def __init__(self, param, value):
self.param = param
self.value = value

def pre_process(self):
self.value = self.value.reduce(global_constants.const_list)

def register_names(self):
self.param = self.param.reduce(global_constants.const_list, unknown_id_fatal=False)
if isinstance(self.param, expression.SpecialParameter):
if not self.param.can_assign():
raise generic.ScriptError(
"Trying to assign a value to the read-only variable '{}'".format(self.param.name), self.param.pos
)
elif isinstance(self.param, expression.Identifier):
if isinstance(self.param, expression.Identifier):
if global_constants.identifier_refcount[self.param.value] == 0:
generic.print_warning(
generic.Warning.OPTIMISATION,
Expand All @@ -110,6 +103,17 @@ def pre_process(self):
return
num = action6.free_parameters.pop_unique(self.pos)
global_constants.named_parameters[self.param.value] = num

def pre_process(self):
self.value = self.value.reduce(global_constants.const_list)

if isinstance(self.param, expression.SpecialParameter):
if not self.param.can_assign():
raise generic.ScriptError(
"Trying to assign a value to the read-only variable '{}'".format(self.param.name), self.param.pos
)
elif isinstance(self.param, expression.Identifier):
return
elif not isinstance(self.param, expression.Parameter):
raise generic.ScriptError("Left side of an assignment must be a parameter.", self.param.pos)

Expand Down

0 comments on commit 2491279

Please sign in to comment.