From 2c7de55cdbdbc37652195f0ddd1cb541274103e6 Mon Sep 17 00:00:00 2001 From: Adam Chidlow Date: Tue, 12 Dec 2023 14:26:11 +0800 Subject: [PATCH] fix: resolves some bugs with match statements (#25) --- pyproject.toml | 2 +- src/puya/ir/models.py | 2 +- src/puya/ir/optimize/constant_propagation.py | 3 ++- src/puyapy-stubs/_primitives.pyi | 1 - 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 80c8317e05..8ab634f113 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "puya" -version = "0.1.2" +version = "0.1.3" description = "An optimising Python to TEAL compiler" authors = ["Algorand Foundation "] readme = "README.md" diff --git a/src/puya/ir/models.py b/src/puya/ir/models.py index 306a98518f..ead4607fbe 100644 --- a/src/puya/ir/models.py +++ b/src/puya/ir/models.py @@ -438,7 +438,7 @@ class Switch(ControlOp): @cases.validator def _check_cases(self, _attribute: object, cases: dict[Value, BasicBlock]) -> None: - if any(case.atype != self.value.atype for case in cases): + if not all(case.atype & self.value.atype for case in cases): raise CodeError( "Switch cases types mismatch with value to match", self.source_location ) diff --git a/src/puya/ir/optimize/constant_propagation.py b/src/puya/ir/optimize/constant_propagation.py index 726b7068b4..9bc68055b1 100644 --- a/src/puya/ir/optimize/constant_propagation.py +++ b/src/puya/ir/optimize/constant_propagation.py @@ -8,6 +8,7 @@ from puya.ir.models import Assignment, Intrinsic from puya.ir.ssa import TrivialPhiRemover from puya.ir.visitor_mutator import IRMutator +from puya.utils import unique logger: structlog.typing.FilteringBoundLogger = structlog.get_logger(__name__) @@ -180,7 +181,7 @@ def remove_target(parent: models.BasicBlock, to_remove: models.BasicBlock) -> No block.terminator = models.Goto( source_location=terminator.source_location, target=goto ) - for target in terminator.targets(): + for target in unique(terminator.targets()): if target is not goto: remove_target(block, target) # TODO: do these belong in constant_propagation? diff --git a/src/puyapy-stubs/_primitives.pyi b/src/puyapy-stubs/_primitives.pyi index f189d0628b..dabbda9a7c 100644 --- a/src/puyapy-stubs/_primitives.pyi +++ b/src/puyapy-stubs/_primitives.pyi @@ -69,7 +69,6 @@ class UInt64: def __ior__(self, other: UInt64 | int) -> UInt64: ... # ~ def __invert__(self) -> UInt64: ... - # used to turn this into an index e.g. to a list class Bytes(t.Iterable[Bytes]): @t.overload