Skip to content

Commit

Permalink
restoring mathics-title
Browse files Browse the repository at this point in the history
  • Loading branch information
mmatera committed Sep 17, 2024
1 parent b392036 commit c7da800
Show file tree
Hide file tree
Showing 3 changed files with 455 additions and 693 deletions.
18 changes: 8 additions & 10 deletions mathics/builtin/patterns.py
Original file line number Diff line number Diff line change
Expand Up @@ -1005,10 +1005,10 @@ def __repr__(self):
def get_match_count(self, vars={}):
return self.pattern.get_match_count(vars)

def match(self, yield_func, expression, vars_dict, evaluation, **kwargs):
existing = vars_dict.get(self.varname, None)
def match(self, yield_func, expression, vars, evaluation, **kwargs):
existing = vars.get(self.varname, None)
if existing is None:
new_vars = vars_dict.copy()
new_vars = vars.copy()
new_vars[self.varname] = expression
# for vars_2, rest in self.pattern.match(
# expression, new_vars, evaluation):
Expand All @@ -1021,24 +1021,22 @@ def match(self, yield_func, expression, vars_dict, evaluation, **kwargs):
self.pattern.match(yield_func, expression, new_vars, evaluation)
else:
if existing.sameQ(expression):
yield_func(vars_dict, None)
yield_func(vars, None)

def get_match_candidates(
self, elements: tuple, expression, attributes, evaluation, vars_dict=None
self, elements: tuple, expression, attributes, evaluation, vars={}
):
if vars_dict is None:
vars_dict = {}
existing = vars_dict.get(self.varname, None)
existing = vars.get(self.varname, None)
if existing is None:
return self.pattern.get_match_candidates(
elements, expression, attributes, evaluation, vars_dict
elements, expression, attributes, evaluation, vars
)
else:
# Treat existing variable as verbatim
verbatim_expr = Expression(SymbolVerbatim, existing)
verbatim = Verbatim(verbatim_expr)
return verbatim.get_match_candidates(
elements, expression, attributes, evaluation, vars_dict
elements, expression, attributes, evaluation, vars
)


Expand Down
Loading

0 comments on commit c7da800

Please sign in to comment.