Enable checking duplicates in map
This commit is contained in:
@@ -11,7 +11,7 @@ class StatementNode(Node):
|
|||||||
from smnp.ast.node.ret import ReturnNode
|
from smnp.ast.node.ret import ReturnNode
|
||||||
|
|
||||||
return Parser.oneOf(
|
return Parser.oneOf(
|
||||||
|
ExpressionNode.parse,
|
||||||
BlockNode.parse,
|
BlockNode.parse,
|
||||||
ReturnNode.parse,
|
ReturnNode.parse,
|
||||||
ExpressionNode.parse
|
|
||||||
)(input)
|
)(input)
|
||||||
@@ -1,4 +1,6 @@
|
|||||||
from smnp.runtime.evaluator import Evaluator, evaluate
|
from smnp.error.runtime import RuntimeException
|
||||||
|
from smnp.runtime.evaluator import Evaluator
|
||||||
|
from smnp.runtime.evaluators.expression import expressionEvaluator
|
||||||
from smnp.type.model import Type
|
from smnp.type.model import Type
|
||||||
|
|
||||||
|
|
||||||
@@ -6,6 +8,12 @@ class MapEvaluator(Evaluator):
|
|||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def evaluator(cls, node, environment):
|
def evaluator(cls, node, environment):
|
||||||
keys = [ evaluate(entry.key, environment).value for entry in node.children ]
|
map = {}
|
||||||
values = [ evaluate(entry.value, environment).value for entry in node.children ]
|
exprEvaluator = expressionEvaluator(doAssert=True)
|
||||||
return Type.map(dict(zip(keys, values)))
|
for entry in node.children:
|
||||||
|
key = exprEvaluator(entry.key, environment).value
|
||||||
|
if key in map:
|
||||||
|
raise RuntimeException(f"Duplicated key '{key.stringify()}' found in map", entry.pos)
|
||||||
|
map[key] = exprEvaluator(entry.value, environment).value
|
||||||
|
|
||||||
|
return Type.map(map)
|
||||||
Reference in New Issue
Block a user