diff --git a/examples/marketplace/contract.py b/examples/marketplace/contract.py index 27ed50b..6390050 100644 --- a/examples/marketplace/contract.py +++ b/examples/marketplace/contract.py @@ -130,7 +130,7 @@ def deposit(self, xfer: gtxn.AssetTransferTransaction, nonce: arc4.UInt64) -> No assert xfer.asset_amount > 0 self.listings[key].deposited = arc4.UInt64( - self.listings[key].deposited.native + xfer.asset_amount + self.listings[key].deposited.as_uint64() + xfer.asset_amount ) @abimethod @@ -161,14 +161,14 @@ def buy( listing = self.listings[key].copy() amount_to_be_paid = self.quantity_price( - quantity, listing.unitary_price.native, asset.decimals + quantity, listing.unitary_price.as_uint64(), asset.decimals ) assert buy_pay.sender == Txn.sender assert buy_pay.receiver.bytes == owner.bytes assert buy_pay.amount == amount_to_be_paid - self.listings[key].deposited = arc4.UInt64(listing.deposited.native - quantity) + self.listings[key].deposited = arc4.UInt64(listing.deposited.as_uint64() - quantity) itxn.AssetTransfer( xfer_asset=asset, @@ -187,8 +187,8 @@ def withdraw(self, asset: Asset, nonce: arc4.UInt64) -> None: listing = self.listings[key].copy() if listing.bidder != arc4.Address(): current_bid_deposit = self.quantity_price( - listing.bid.native, - listing.bid_unitary_price.native, + listing.bid.as_uint64(), + listing.bid_unitary_price.as_uint64(), asset.decimals, ) itxn.Payment(receiver=listing.bidder.native, amount=current_bid_deposit).submit() @@ -200,7 +200,7 @@ def withdraw(self, asset: Asset, nonce: arc4.UInt64) -> None: itxn.AssetTransfer( xfer_asset=asset, asset_receiver=Txn.sender, - asset_amount=listing.deposited.native, + asset_amount=listing.deposited.as_uint64(), ).submit() @abimethod @@ -220,13 +220,13 @@ def bid( # noqa: PLR0913 assert unitary_price > listing.bid_unitary_price current_bid_amount = self.quantity_price( - listing.bid.native, listing.bid_unitary_price.native, asset.decimals + listing.bid.as_uint64(), listing.bid_unitary_price.as_uint64(), asset.decimals ) itxn.Payment(receiver=listing.bidder.native, amount=current_bid_amount).submit() amount_to_be_bid = self.quantity_price( - quantity.native, unitary_price.native, asset.decimals + quantity.as_uint64(), unitary_price.as_uint64(), asset.decimals ) assert bid_pay.sender == Txn.sender @@ -245,12 +245,12 @@ def accept_bid(self, asset: Asset, nonce: arc4.UInt64) -> None: assert listing.bidder != arc4.Address() min_quantity = ( - listing.deposited.native - if listing.deposited.native < listing.bid.native - else listing.bid.native + listing.deposited.as_uint64() + if listing.deposited.as_uint64() < listing.bid.as_uint64() + else listing.bid.as_uint64() ) best_bid_amount = self.quantity_price( - min_quantity, listing.bid_unitary_price.native, asset.decimals + min_quantity, listing.bid_unitary_price.as_uint64(), asset.decimals ) itxn.Payment(receiver=Txn.sender, amount=best_bid_amount).submit() @@ -262,6 +262,6 @@ def accept_bid(self, asset: Asset, nonce: arc4.UInt64) -> None: ).submit() self.listings[key].deposited = arc4.UInt64( - self.listings[key].deposited.native - min_quantity + self.listings[key].deposited.as_uint64() - min_quantity ) - self.listings[key].bid = arc4.UInt64(self.listings[key].bid.native - min_quantity) + self.listings[key].bid = arc4.UInt64(self.listings[key].bid.as_uint64() - min_quantity) diff --git a/examples/marketplace/test_contract.py b/examples/marketplace/test_contract.py index c57acc0..807e6df 100644 --- a/examples/marketplace/test_contract.py +++ b/examples/marketplace/test_contract.py @@ -162,19 +162,19 @@ def test_buy( buy_pay=context.any.txn.payment( receiver=context.default_sender, amount=contract.quantity_price( - quantity=test_buy_quantity.native, - price=test_unitary_price.native, + quantity=test_buy_quantity.as_uint64(), + price=test_unitary_price.as_uint64(), asset_decimals=test_asset.decimals, ), ), - quantity=test_buy_quantity.native, + quantity=test_buy_quantity.as_uint64(), ) # Assert updated_listing = ListingValue.from_bytes( context.ledger.get_box(contract, b"listings" + listing_key.bytes) ) - assert updated_listing.deposited == initial_deposit.native - test_buy_quantity.native + assert updated_listing.deposited == initial_deposit.as_uint64() - test_buy_quantity.as_uint64() assert ( context.txn.last_group.get_itxn_group(0).asset_transfer(0).asset_receiver == context.default_sender @@ -215,7 +215,7 @@ def test_withdraw( asset_transfer_txn = context.txn.last_group.get_itxn_group(1).asset_transfer(0) assert asset_transfer_txn.xfer_asset == test_asset assert asset_transfer_txn.asset_receiver == test_owner.native - assert asset_transfer_txn.asset_amount == initial_deposit.native + assert asset_transfer_txn.asset_amount == initial_deposit.as_uint64() def test_bid( @@ -240,12 +240,12 @@ def test_bid( ) bidder = context.any.account() - bid_quantity = context.any.arc4.uint64(max_value=int(initial_deposit.native)) + bid_quantity = context.any.arc4.uint64(max_value=int(initial_deposit.as_uint64())) bid_price = context.any.arc4.uint64( - min_value=int(initial_price.native) + 1, max_value=int(10e6) + min_value=int(initial_price.as_uint64()) + 1, max_value=int(10e6) ) bid_amount = contract.quantity_price( - bid_quantity.native, bid_price.native, test_asset.decimals + bid_quantity.as_uint64(), bid_price.as_uint64(), test_asset.decimals ) # Act @@ -277,7 +277,7 @@ def test_accept_bid( # Arrange owner = context.default_sender initial_deposit = context.any.arc4.uint64(min_value=1, max_value=int(1e6)) - bid_quantity = context.any.arc4.uint64(max_value=int(initial_deposit.native)) + bid_quantity = context.any.arc4.uint64(max_value=int(initial_deposit.as_uint64())) bid_price = context.any.arc4.uint64(max_value=int(10e6)) bidder = context.any.account() @@ -294,10 +294,10 @@ def test_accept_bid( bid_unitary_price=bid_price, ) - min_quantity = min(initial_deposit.native, bid_quantity.native) + min_quantity = min(initial_deposit.as_uint64(), bid_quantity.as_uint64()) expected_payment = contract.quantity_price( min_quantity, - bid_price.native, + bid_price.as_uint64(), asset_decimals=test_asset.decimals, ) @@ -306,7 +306,7 @@ def test_accept_bid( # Assert updated_listing = contract.listings[listing_key] - assert updated_listing.deposited == initial_deposit.native - min_quantity + assert updated_listing.deposited == initial_deposit.as_uint64() - min_quantity assert len(context.txn.last_group.itxn_groups) == 2 diff --git a/pyproject.toml b/pyproject.toml index df6b1b5..5f67782 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -32,7 +32,7 @@ dependencies = [ "coincurve>=19.0.1", # TODO: uncomment below and remove direct git reference once puya 5.0 is released # "algorand-python>=3", - "algorand-python@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.6#subdirectory=stubs", + "algorand-python@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.7#subdirectory=stubs", ] [project.urls] @@ -54,7 +54,7 @@ python = "3.12" dependencies = [ # TODO: uncomment below and remove direct git reference once puya 5.0 is released # "puyapy>=5", - "puyapy@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.6", + "puyapy@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.7", "pytest>=7.4", "pytest-mock>=3.10.0", "pytest-xdist[psutil]>=3.3", @@ -138,7 +138,7 @@ dependencies = [ "algokit-utils>=3.0.0", # TODO: uncomment below and remove direct git reference once puya 5.0 is released # "puyapy>=5", - "puyapy@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.6", + "puyapy@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.7", ] [tool.hatch.envs.test.scripts] @@ -191,7 +191,7 @@ post-install-commands = [ dependencies = [ # TODO: uncomment below and remove direct git reference once puya 5.0 is released # "algorand-python>=3", - "algorand-python@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.6#subdirectory=stubs", + "algorand-python@git+https://github.com/algorandfoundation/puya.git@v5.0.0-rc.7#subdirectory=stubs", "pytest>=7.4", "pytest-mock>=3.10.0", "pytest-xdist[psutil]>=3.3", diff --git a/src/_algopy_testing/arc4.py b/src/_algopy_testing/arc4.py index 26de796..f080154 100644 --- a/src/_algopy_testing/arc4.py +++ b/src/_algopy_testing/arc4.py @@ -8,6 +8,7 @@ import algosdk from Cryptodome.Hash import SHA512 +from typing_extensions import deprecated from _algopy_testing.constants import ( ARC4_RETURN_PREFIX, @@ -313,31 +314,44 @@ class UIntN(_UIntN, typing.Generic[_TBitSize]): # type: ignore[type-arg] """ @property + @deprecated("Use `as_uint64` instead") def native(self) -> algopy.UInt64: """Return the UInt64 representation of the value after ARC4 decoding.""" import algopy return algopy.UInt64(int.from_bytes(self._value)) + def as_uint64(self) -> algopy.UInt64: + """Return the UInt64 representation of the value after ARC4 decoding.""" + import algopy + + return algopy.UInt64(int.from_bytes(self._value)) + + def as_biguint(self) -> algopy.BigUInt: + """Return the BigUInt representation of the value after ARC4 decoding.""" + import algopy + + return algopy.BigUInt.from_bytes(self._value) + def __eq__(self, other: object) -> bool: try: other_int = as_int64(other) except (TypeError, ValueError): return NotImplemented - return as_int64(self.native) == other_int + return as_int64(self.as_uint64()) == other_int def __lt__(self, other: object) -> bool: try: other_int = as_int64(other) except (TypeError, ValueError): return NotImplemented - return as_int64(self.native) < other_int + return as_int64(self.as_uint64()) < other_int def __bool__(self) -> bool: - return bool(self.native) + return bool(self.as_uint64()) def __str__(self) -> str: - return str(self.native) + return str(self.as_uint64()) def __repr__(self) -> str: return _arc4_repr(self) @@ -351,10 +365,26 @@ class BigUIntN(_UIntN, typing.Generic[_TBitSize]): # type: ignore[type-arg] """ @property + @deprecated("Use `as_biguint` instead") def native(self) -> algopy.BigUInt: + """Return the BigUInt representation of the value after ARC4 decoding.""" + import algopy + + return algopy.BigUInt.from_bytes(self._value) + + def as_uint64(self) -> algopy.UInt64: """Return the UInt64 representation of the value after ARC4 decoding.""" import algopy + biguint = algopy.BigUInt.from_bytes(self._value) + if biguint.value > MAX_UINT64: + raise OverflowError("value too large to fit in UInt64") + return algopy.UInt64(biguint.value) + + def as_biguint(self) -> algopy.BigUInt: + """Return the BigUInt representation of the value after ARC4 decoding.""" + import algopy + return algopy.BigUInt.from_bytes(self._value) def __eq__(self, other: object) -> bool: @@ -362,20 +392,20 @@ def __eq__(self, other: object) -> bool: other_int = as_int512(other) except (TypeError, ValueError): return NotImplemented - return as_int512(self.native) == other_int + return as_int512(self.as_biguint()) == other_int def __lt__(self, other: object) -> bool: try: other_int = as_int512(other) except (TypeError, ValueError): return NotImplemented - return as_int512(self.native) < other_int + return as_int512(self.as_biguint()) < other_int def __bool__(self) -> bool: - return bool(self.native) + return bool(self.as_biguint()) def __str__(self) -> str: - return str(self.native) + return str(self.as_biguint()) def __repr__(self) -> str: return _arc4_repr(self) @@ -959,7 +989,7 @@ def __init__(self, *value: algopy.Bytes | bytes | Byte | UInt8 | int): raise ValueError("expected single Bytes value") items.extend([Byte(b) for b in as_bytes(x)]) case UIntN(_type_info=_UIntTypeInfo(bit_size=8)) as uint: - items.append(Byte(as_int(uint.native, max=2**8))) + items.append(Byte(as_int(uint.as_uint64(), max=2**8))) case int(int_value): items.append(Byte(int_value)) case _: diff --git a/src/_algopy_testing/op/pure.py b/src/_algopy_testing/op/pure.py index 11c9ae1..8061e84 100644 --- a/src/_algopy_testing/op/pure.py +++ b/src/_algopy_testing/op/pure.py @@ -109,7 +109,7 @@ def extract_uint64(a: Bytes | bytes, b: UInt64 | int, /) -> UInt64: return UInt64(result_int) -def getbit(a: Bytes | UInt64 | bytes | int, b: UInt64 | int, /) -> UInt64: +def getbit(a: Bytes | UInt64 | bytes | int, b: UInt64 | int, /) -> bool: if isinstance(a, Bytes | bytes): return _getbit_bytes(a, b) if isinstance(a, UInt64 | int): @@ -162,11 +162,11 @@ def select_uint64(a: UInt64 | int, b: UInt64 | int, c: bool | UInt64 | int, /) - return UInt64(b if c != 0 else a) -def setbit_bytes(a: Bytes | bytes, b: UInt64 | int, c: UInt64 | int, /) -> Bytes: +def setbit_bytes(a: Bytes | bytes, b: UInt64 | int, c: bool, /) -> Bytes: # noqa: FBT001 return _setbit_bytes(a, b, c) -def setbit_uint64(a: UInt64 | int, b: UInt64 | int, c: UInt64 | int, /) -> UInt64: +def setbit_uint64(a: UInt64 | int, b: UInt64 | int, c: bool, /) -> UInt64: # noqa: FBT001 a_bytes = _uint64_to_bytes(a) result = _setbit_bytes(a_bytes, b, c, "little") return UInt64(int.from_bytes(result.value)) @@ -241,7 +241,7 @@ def _int_list_to_bytes(a: list[int]) -> bytes: def _getbit_bytes( a: Bytes | bytes, b: UInt64 | int, byteorder: typing.Literal["little", "big"] = "big" -) -> UInt64: +) -> bool: a = as_bytes(a) if byteorder != "big": # reverse bytes if NOT big endian a = bytes(reversed(a)) @@ -256,13 +256,13 @@ def _getbit_bytes( bit_index = 7 - bit_index bit = _get_bit(int_list[byte_index], bit_index) - return UInt64(bit) + return bit != 0 def _setbit_bytes( a: Bytes | bytes, b: UInt64 | int, - c: UInt64 | int, + c: bool, # noqa: FBT001 byteorder: typing.Literal["little", "big"] = "big", ) -> Bytes: a = as_bytes(a) @@ -272,7 +272,6 @@ def _setbit_bytes( int_list = list(a) max_index = len(int_list) * BITS_IN_BYTE - 1 b = as_int(b, max=max_index) - c = as_int(c, max=1) byte_index = b // BITS_IN_BYTE bit_index = b % BITS_IN_BYTE @@ -291,7 +290,7 @@ def _get_bit(v: int, index: int) -> int: return (v >> index) & 1 -def _set_bit(v: int, index: int, x: int) -> int: +def _set_bit(v: int, index: int, x: bool) -> int: # noqa: FBT001 """Set the index:th bit of v to 1 if x is truthy, else to 0, and return the new value.""" mask = 1 << index # Compute mask, an integer with just bit 'index' set. diff --git a/src/_algopy_testing/serialize.py b/src/_algopy_testing/serialize.py index fd5b86f..3e4a18e 100644 --- a/src/_algopy_testing/serialize.py +++ b/src/_algopy_testing/serialize.py @@ -50,7 +50,11 @@ def get_native_to_arc4_serializer( # noqa: PLR0911 return _Serializer( arc4_type=simple_arc4_type, native_to_arc4=simple_arc4_type, - arc4_to_native=lambda n: n.native, + arc4_to_native=lambda n: ( + n.as_uint64() + if isinstance(n, arc4.UIntN) + else n.as_biguint() if isinstance(n, arc4.BigUIntN) else n.native + ), ) if issubclass(typ, UInt64Backed): return _Serializer( diff --git a/src/_algopy_testing/utils.py b/src/_algopy_testing/utils.py index de25df8..8338e5d 100644 --- a/src/_algopy_testing/utils.py +++ b/src/_algopy_testing/utils.py @@ -68,10 +68,10 @@ def as_int(value: object, *, max: int | None) -> int: # noqa: A002 pass case _algopy_testing.BigUInt(value=int_value): pass - case _algopy_testing.arc4.UIntN(native=native): - int_value = native.value - case _algopy_testing.arc4.BigUIntN(native=native): - int_value = native.value + case _algopy_testing.arc4.UIntN(): + int_value = value.as_uint64().value + case _algopy_testing.arc4.BigUIntN(): + int_value = value.as_biguint().value case _: raise TypeError(f"value must be a numeric type, not {type(value).__name__!r}") if int_value < 0: diff --git a/tests/arc4/test_address.py b/tests/arc4/test_address.py index b0659fb..aae4cd3 100644 --- a/tests/arc4/test_address.py +++ b/tests/arc4/test_address.py @@ -252,4 +252,4 @@ def test_to_native() -> None: a1 = arc4.Address("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ") native_a1 = a1.to_native(arc4.Byte) assert native_a1.length == 32 - assert [x.native for x in native_a1] == [0] * 32 + assert [x.as_uint64() for x in native_a1] == [0] * 32 diff --git a/tests/arc4/test_dynamic_array.py b/tests/arc4/test_dynamic_array.py index 2f9dbb6..c561278 100644 --- a/tests/arc4/test_dynamic_array.py +++ b/tests/arc4/test_dynamic_array.py @@ -1091,6 +1091,8 @@ def _compare_abi_and_arc4_values( while j < len(x): _compare_abi_and_arc4_values(x[j], abi_value[j]) j += 1 + elif hasattr(arc4_value, "as_biguint"): + assert arc4_value.as_biguint() == abi_value elif hasattr(arc4_value, "native"): assert arc4_value.native == abi_value else: diff --git a/tests/arc4/test_dynamic_bytes.py b/tests/arc4/test_dynamic_bytes.py index 9a27382..381e096 100644 --- a/tests/arc4/test_dynamic_bytes.py +++ b/tests/arc4/test_dynamic_bytes.py @@ -135,8 +135,8 @@ def test_get_item( ) -> None: i = 0 while i < arc4_value.length: - if hasattr(arc4_value[i], "native"): - assert arc4_value[i].native == abi_values[i] + if hasattr(arc4_value[i], "as_uint64"): + assert arc4_value[i].as_uint64() == abi_values[i] i += 1 assert len(abi_values) == arc4_value.length @@ -273,8 +273,8 @@ def test_from_bytes( i = 0 arc4_value = arc4.DynamicBytes.from_bytes(_abi_dynamic_bytes_type.encode(abi_values)) while i < arc4_value.length: - if hasattr(arc4_value[i], "native"): - assert arc4_value[i].native == abi_values[i] + if hasattr(arc4_value[i], "as_uint64"): + assert arc4_value[i].as_uint64() == abi_values[i] i += 1 assert len(abi_values) == arc4_value.length @@ -347,8 +347,8 @@ def test_pop( arc4_value_2 = arc4.pop() arc4_result = arc4.bytes - assert arc4_value_1.native == abi_value_1 - assert arc4_value_2.native == abi_value_2 + assert arc4_value_1.as_uint64() == abi_value_1 + assert arc4_value_2.as_uint64() == abi_value_2 assert abi_result == arc4_result diff --git a/tests/arc4/test_emit.py b/tests/arc4/test_emit.py index 4f577d0..44f29cb 100644 --- a/tests/arc4/test_emit.py +++ b/tests/arc4/test_emit.py @@ -93,8 +93,8 @@ def test_emit(get_avm_result: AVMInvoker, context: AlgopyTestContext) -> None: f=_test_data.f, g=_test_data.g, h=_test_data.h, - m=_test_data_arc4.m.native.value, - n=_test_data_arc4.n.native.value, + m=_test_data_arc4.m.as_uint64().value, + n=_test_data_arc4.n.as_biguint().value, o=int.from_bytes(_test_data_arc4.o.bytes.value), p=int.from_bytes(_test_data_arc4.p.bytes.value), q=_test_data_arc4.q.native, diff --git a/tests/arc4/test_static_array.py b/tests/arc4/test_static_array.py index d58a64e..36c0103 100644 --- a/tests/arc4/test_static_array.py +++ b/tests/arc4/test_static_array.py @@ -557,6 +557,8 @@ def _compare_abi_and_arc4_values( while j < len(x): _compare_abi_and_arc4_values(x[j], abi_value[j]) j += 1 + elif hasattr(arc4_value, "as_biguint"): + assert arc4_value.as_biguint() == abi_value elif hasattr(arc4_value, "native"): assert arc4_value.native == abi_value else: diff --git a/tests/arc4/test_struct.py b/tests/arc4/test_struct.py index 24f399b..6ae136b 100644 --- a/tests/arc4/test_struct.py +++ b/tests/arc4/test_struct.py @@ -369,6 +369,8 @@ def _compare_abi_and_arc4_values( while j < len(x): _compare_abi_and_arc4_values(x[j], abi_value[j]) j += 1 + elif hasattr(arc4_value, "as_uint64"): + assert arc4_value.as_uint64() == abi_value elif hasattr(arc4_value, "native"): assert arc4_value.native == abi_value else: diff --git a/tests/arc4/test_tuple.py b/tests/arc4/test_tuple.py index 2b19644..a4bb617 100644 --- a/tests/arc4/test_tuple.py +++ b/tests/arc4/test_tuple.py @@ -285,6 +285,8 @@ def _compare_abi_and_arc4_values( while j < len(x): _compare_abi_and_arc4_values(x[j], abi_value[j]) j += 1 + elif hasattr(arc4_value, "as_uint64"): + assert arc4_value.as_uint64() == abi_value elif hasattr(arc4_value, "native"): assert arc4_value.native == abi_value else: diff --git a/tests/arc4/test_uintn.py b/tests/arc4/test_uintn.py index 40e7161..62e81b4 100644 --- a/tests/arc4/test_uintn.py +++ b/tests/arc4/test_uintn.py @@ -105,7 +105,7 @@ def test_uintn_overflow(get_avm_result: AVMInvoker, value: int, expected: int | if expected is None: with pytest.raises(algokit_utils.LogicError, match="assert failed"): get_avm_result("verify_uintn_init", a=int_to_bytes(value)) - with pytest.raises(ValueError, match=f"expected value <= {2**32-1}"): + with pytest.raises(ValueError, match=f"expected value <= {2**32 - 1}"): arc4.UInt32(value) else: avm_result = get_avm_result("verify_uintn_init", a=int_to_bytes(value)) @@ -300,3 +300,71 @@ def test_biguintn_from_log_invalid_length(get_avm_result: AVMInvoker, value: byt result = arc4.UInt256.from_log(Bytes(ARC4_RETURN_PREFIX + value)) assert result == int.from_bytes(value) + + +@pytest.mark.parametrize( + ("value"), + [ + (int_to_bytes(1, 32)), + (int_to_bytes(MAX_UINT64, 32)), + ], +) +def test_biguintn_as_uint64(get_avm_result: AVMInvoker, value: bytes) -> None: + avm_result = get_avm_result("verify_biguintn_as_uint64", a=value) + result = arc4.UInt256.from_bytes(Bytes(value)).as_uint64() + assert avm_result == result + + +@pytest.mark.parametrize( + ("value"), + [ + (int_to_bytes(MAX_UINT64 + 1, 32)), + (int_to_bytes(2**256 - 1, 32)), + ], +) +def test_biguintn_as_uint64_overflow(get_avm_result: AVMInvoker, value: bytes) -> None: + with pytest.raises(algokit_utils.LogicError, match="assert failed"): + get_avm_result("verify_biguintn_as_uint64", a=value) + with pytest.raises(OverflowError, match="value too large to fit in UInt64"): + arc4.UInt256.from_bytes(Bytes(value)).as_uint64() + + +@pytest.mark.parametrize( + ("value"), + [ + (int_to_bytes(1, 32)), + (int_to_bytes(MAX_UINT64, 32)), + (int_to_bytes(MAX_UINT64 + 1, 32)), + (int_to_bytes(2**256 - 1, 32)), + ], +) +def test_biguintn_as_biguint(get_avm_result: AVMInvoker, value: bytes) -> None: + avm_result = get_avm_result("verify_biguintn_as_biguint", a=value) + result = arc4.UInt256.from_bytes(Bytes(value)).as_biguint() + assert avm_result == result + + +@pytest.mark.parametrize( + ("value"), + [ + (int_to_bytes(1, 8)), + (int_to_bytes(MAX_UINT64, 8)), + ], +) +def test_uintn64_as_uint64(get_avm_result: AVMInvoker, value: bytes) -> None: + avm_result = get_avm_result("verify_uintn64_as_uint64", a=value) + result = arc4.UInt64.from_bytes(Bytes(value)).as_uint64() + assert avm_result == result + + +@pytest.mark.parametrize( + ("value"), + [ + (int_to_bytes(1, 8)), + (int_to_bytes(MAX_UINT64, 8)), + ], +) +def test_uintn64_as_biguint(get_avm_result: AVMInvoker, value: bytes) -> None: + avm_result = get_avm_result("verify_uintn64_as_biguint", a=value) + result = arc4.UInt64.from_bytes(Bytes(value)).as_biguint() + assert avm_result == result diff --git a/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.approval.teal b/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.approval.teal index 64ecfc1..cc718cb 100644 --- a/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.approval.teal +++ b/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.approval.teal @@ -3,579 +3,343 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 0 4 6 + intcblock 1 0 6 123 bytecblock 0x0000 0x151f7c75 0x0000000000000001 0x000132 - // a/contract.py:25 + // tests/artifacts/Arc4ABIMethod/contract.py:25 // class SignaturesContract(ARC4Contract): - txn NumAppArgs - bz main_after_if_else@16 - pushbytess 0x4c5c61ba 0xe18922d8 0x3b05cf17 0x0658dcc3 0x5b6447de 0x061f4e77 0xeaa89139 0x510e72a4 0xd6c2ac7f 0x48142d5e // method "create()void", method "sink(string,uint8[])void", method "alias(string,uint8[])void", method "with_txn(string,pay,uint8[])void", method "with_asset(string,asset,uint8[])void", method "with_app(string,application,uint64,uint8[])void", method "with_acc(string,account,uint8[])void", method "complex_sig(((uint64,string),(uint64,string),uint128,uint128),txn,account,uint8[])((uint64,string),((uint64,string),(uint64,string),uint128,uint128))", method "echo_resource_by_index(asset,application,account)(uint64,uint64,address)", method "echo_resource_by_value(uint64,uint64,address)(uint64,uint64,address)" - txna ApplicationArgs 0 - match main_create_route@3 main_sink_route@4 main_alias_route@5 main_with_txn_route@6 main_with_asset_route@7 main_with_app_route@8 main_with_acc_route@9 main_complex_sig_route@10 main_echo_resource_by_index_route@11 main_echo_resource_by_value_route@12 - -main_after_if_else@16: - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - intc_1 // 0 - return - -main_echo_resource_by_value_route@12: - // a/contract.py:120-122 - // @arc4.abimethod( - // resource_encoding="value", - // ) - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - txna ApplicationArgs 3 - // a/contract.py:120-122 - // @arc4.abimethod( - // resource_encoding="value", - // ) - callsub echo_resource_by_value - uncover 2 - itob - uncover 2 - itob - concat - swap - concat - bytec_1 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_echo_resource_by_index_route@11: - // a/contract.py:106-108 - // @arc4.abimethod( - // resource_encoding="index", - // ) - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - txna ApplicationArgs 2 - btoi - txnas Applications - txna ApplicationArgs 3 - btoi - txnas Accounts - // a/contract.py:106-108 - // @arc4.abimethod( - // resource_encoding="index", - // ) - callsub echo_resource_by_index - uncover 2 - itob - uncover 2 - itob - concat - swap - concat - bytec_1 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_complex_sig_route@10: - // a/contract.py:83 - // @arc4.abimethod(resource_encoding="index") - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - txn GroupIndex - intc_0 // 1 - - - txna ApplicationArgs 2 - btoi - txnas Accounts - txna ApplicationArgs 3 - // a/contract.py:83 - // @arc4.abimethod(resource_encoding="index") - callsub complex_sig - dig 1 - len - intc_2 // 4 - + - itob - extract 6 2 - pushbytes 0x0004 - swap - concat - uncover 2 - concat - swap - concat - bytec_1 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_with_acc_route@9: - // a/contract.py:75 - // @arc4.abimethod(resource_encoding="index") - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - btoi - txnas Accounts - txna ApplicationArgs 3 - // a/contract.py:75 - // @arc4.abimethod(resource_encoding="index") - callsub with_acc - intc_0 // 1 - return - -main_with_app_route@8: - // a/contract.py:61 - // @arc4.abimethod(resource_encoding="index") - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - btoi - txnas Applications - txna ApplicationArgs 3 - txna ApplicationArgs 4 - // a/contract.py:61 - // @arc4.abimethod(resource_encoding="index") - callsub with_app - intc_0 // 1 - return - -main_with_asset_route@7: - // a/contract.py:54 - // @arc4.abimethod(resource_encoding="index") - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - btoi - txnas Assets - txna ApplicationArgs 3 - // a/contract.py:54 - // @arc4.abimethod(resource_encoding="index") - callsub with_asset - intc_0 // 1 - return - -main_with_txn_route@6: - // a/contract.py:46 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - txn GroupIndex - intc_0 // 1 - - - dup - gtxns TypeEnum - intc_0 // pay - == - assert // transaction type is pay - txna ApplicationArgs 2 - // a/contract.py:46 - // @arc4.abimethod - callsub with_txn - intc_0 // 1 - return - -main_alias_route@5: - // a/contract.py:41 - // @arc4.abimethod(name="alias") txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 - // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - // a/contract.py:41 - // @arc4.abimethod(name="alias") - callsub sink2 - intc_0 // 1 - return + bz main_create_NoOp@13 + pushbytess 0xe18922d8 0x3b05cf17 0x0658dcc3 0x5b6447de 0x061f4e77 0xeaa89139 0x510e72a4 0xd6c2ac7f 0x48142d5e // method "sink(string,uint8[])void", method "alias(string,uint8[])void", method "with_txn(string,pay,uint8[])void", method "with_asset(string,asset,uint8[])void", method "with_app(string,application,uint64,uint8[])void", method "with_acc(string,account,uint8[])void", method "complex_sig(((uint64,string),(uint64,string),uint128,uint128),txn,account,uint8[])((uint64,string),((uint64,string),(uint64,string),uint128,uint128))", method "echo_resource_by_index(asset,application,account)(uint64,uint64,address)", method "echo_resource_by_value(uint64,uint64,address)(uint64,uint64,address)" + txna ApplicationArgs 0 + match sink sink2 with_txn with_asset with_app with_acc complex_sig echo_resource_by_index echo_resource_by_value + err -main_sink_route@4: - // a/contract.py:36 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // a/contract.py:25 +main_create_NoOp@13: + // tests/artifacts/Arc4ABIMethod/contract.py:25 // class SignaturesContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - // a/contract.py:36 - // @arc4.abimethod - callsub sink - intc_0 // 1 - return - -main_create_route@3: - // a/contract.py:26 - // @arc4.abimethod(create="require") - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - ! - assert // can only call when creating - callsub create - intc_0 // 1 - return + pushbytes 0x4c5c61ba // method "create()void" + txna ApplicationArgs 0 + match create + err -// test_cases.a.contract.SignaturesContract.create() -> void: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.create[routing]() -> void: create: - // a/contract.py:28 + // tests/artifacts/Arc4ABIMethod/contract.py:28 // app_txn = gtxn.ApplicationCallTransaction(0) intc_1 // 0 gtxns TypeEnum - intc_3 // appl + intc_2 // appl == assert // transaction type is appl - // a/contract.py:29 + // tests/artifacts/Arc4ABIMethod/contract.py:29 // assert op.Global.current_application_id != 0, "expected global to have app id" global CurrentApplicationID assert // expected global to have app id - // a/contract.py:31 + // tests/artifacts/Arc4ABIMethod/contract.py:31 // op.Global.current_application_address != op.Global.zero_address global CurrentApplicationAddress global ZeroAddress != - // a/contract.py:30-32 + // tests/artifacts/Arc4ABIMethod/contract.py:30-32 // assert ( // op.Global.current_application_address != op.Global.zero_address // ), "expected global to have app address" assert // expected global to have app address - // a/contract.py:28 + // tests/artifacts/Arc4ABIMethod/contract.py:28 // app_txn = gtxn.ApplicationCallTransaction(0) intc_1 // 0 - // a/contract.py:33 + // tests/artifacts/Arc4ABIMethod/contract.py:33 // assert app_txn.app_id == 0, "expected txn to have 0" gtxns ApplicationID ! assert // expected txn to have 0 - // a/contract.py:34 + // tests/artifacts/Arc4ABIMethod/contract.py:34 // assert Txn.application_id == 0, "expected txn to have 0" txn ApplicationID ! - assert // expected txn to have 0 - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:26 + // @arc4.abimethod(create="require") + return // on error: expected txn to have 0 -// test_cases.a.contract.SignaturesContract.sink(value: bytes, arr: bytes) -> void: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.sink[routing]() -> void: sink: - // a/contract.py:36-37 + // tests/artifacts/Arc4ABIMethod/contract.py:36 // @arc4.abimethod - // def sink(self, value: arc4.String, arr: UInt8Array) -> None: - proto 2 0 - // a/contract.py:38 + txna ApplicationArgs 2 + txna ApplicationArgs 1 + // tests/artifacts/Arc4ABIMethod/contract.py:38 // assert value - frame_dig -2 bytec_0 // 0x0000 != assert - // a/contract.py:39 + // tests/artifacts/Arc4ABIMethod/contract.py:39 // assert arr - frame_dig -1 bytec_0 // 0x0000 != - assert - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:36 + // @arc4.abimethod + return -// test_cases.a.contract.SignaturesContract.sink2(value: bytes, arr: bytes) -> void: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.sink2[routing]() -> void: sink2: - // a/contract.py:41-42 + // tests/artifacts/Arc4ABIMethod/contract.py:41 // @arc4.abimethod(name="alias") - // def sink2(self, value: arc4.String, arr: UInt8Array) -> None: - proto 2 0 - // a/contract.py:43 + txna ApplicationArgs 2 + txna ApplicationArgs 1 + // tests/artifacts/Arc4ABIMethod/contract.py:43 // assert value - frame_dig -2 bytec_0 // 0x0000 != assert - // a/contract.py:44 + // tests/artifacts/Arc4ABIMethod/contract.py:44 // assert arr - frame_dig -1 bytec_0 // 0x0000 != - assert - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:41 + // @arc4.abimethod(name="alias") + return -// test_cases.a.contract.SignaturesContract.with_txn(value: bytes, pay: uint64, arr: bytes) -> void: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_txn[routing]() -> void: with_txn: - // a/contract.py:46-47 + // tests/artifacts/Arc4ABIMethod/contract.py:46 // @arc4.abimethod - // def with_txn(self, value: arc4.String, pay: gtxn.PaymentTransaction, arr: UInt8Array) -> None: - proto 3 0 - // a/contract.py:48 + txna ApplicationArgs 1 + txn GroupIndex + intc_0 // 1 + - + dup + gtxns TypeEnum + intc_0 // pay + == + assert // transaction type is pay + txna ApplicationArgs 2 + // tests/artifacts/Arc4ABIMethod/contract.py:48 // assert value - frame_dig -3 + uncover 2 bytec_0 // 0x0000 != assert - // a/contract.py:49 + // tests/artifacts/Arc4ABIMethod/contract.py:49 // assert arr - frame_dig -1 bytec_0 // 0x0000 != assert - // a/contract.py:50 + // tests/artifacts/Arc4ABIMethod/contract.py:50 // assert pay.group_index == 0 - frame_dig -2 + dup gtxns GroupIndex ! assert - // a/contract.py:51 + // tests/artifacts/Arc4ABIMethod/contract.py:51 // assert Txn.group_index == 1 txn GroupIndex intc_0 // 1 == assert - // a/contract.py:52 + // tests/artifacts/Arc4ABIMethod/contract.py:52 // assert pay.amount == 123 - frame_dig -2 gtxns Amount - pushint 123 // 123 + intc_3 // 123 == - assert - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:46 + // @arc4.abimethod + return -// test_cases.a.contract.SignaturesContract.with_asset(value: bytes, asset: uint64, arr: bytes) -> void: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_asset[routing]() -> void: with_asset: - // a/contract.py:54-55 + // tests/artifacts/Arc4ABIMethod/contract.py:54 // @arc4.abimethod(resource_encoding="index") - // def with_asset(self, value: arc4.String, asset: Asset, arr: UInt8Array) -> None: - proto 3 0 - // a/contract.py:56 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + btoi + txnas Assets + txna ApplicationArgs 3 + // tests/artifacts/Arc4ABIMethod/contract.py:56 // assert value - frame_dig -3 + uncover 2 bytec_0 // 0x0000 != assert - // a/contract.py:57 + // tests/artifacts/Arc4ABIMethod/contract.py:57 // assert arr - frame_dig -1 bytec_0 // 0x0000 != assert - // a/contract.py:58 + // tests/artifacts/Arc4ABIMethod/contract.py:58 // assert asset.total == 123 - frame_dig -2 + dup asset_params_get AssetTotal assert // asset exists - pushint 123 // 123 + intc_3 // 123 == assert - // a/contract.py:59 + // tests/artifacts/Arc4ABIMethod/contract.py:59 // assert Txn.assets(0) == asset txna Assets 0 - frame_dig -2 == - assert - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:54 + // @arc4.abimethod(resource_encoding="index") + return -// test_cases.a.contract.SignaturesContract.with_app(value: bytes, app: uint64, app_id: bytes, arr: bytes) -> void: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_app[routing]() -> void: with_app: - // a/contract.py:61-64 + // tests/artifacts/Arc4ABIMethod/contract.py:61 // @arc4.abimethod(resource_encoding="index") - // def with_app( - // self, value: arc4.String, app: Application, app_id: arc4.UInt64, arr: UInt8Array - // ) -> None: - proto 4 0 - // a/contract.py:65 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + btoi + txnas Applications + txna ApplicationArgs 3 + txna ApplicationArgs 4 + // tests/artifacts/Arc4ABIMethod/contract.py:65 // assert value - frame_dig -4 + uncover 3 bytec_0 // 0x0000 != assert - // a/contract.py:66 + // tests/artifacts/Arc4ABIMethod/contract.py:66 // assert arr - frame_dig -1 bytec_0 // 0x0000 != assert - // a/contract.py:67 + // tests/artifacts/Arc4ABIMethod/contract.py:67 // assert app.id == app_id, "expected app id to match provided app id" - frame_dig -3 + dig 1 itob - frame_dig -2 b== assert // expected app id to match provided app id - // a/contract.py:68 + // tests/artifacts/Arc4ABIMethod/contract.py:68 // assert app.creator == op.Global.creator_address, "expected other app to have same creator" - frame_dig -3 + dup app_params_get AppCreator assert // application exists global CreatorAddress == assert // expected other app to have same creator - // a/contract.py:69 + // tests/artifacts/Arc4ABIMethod/contract.py:69 // app_txn = gtxn.ApplicationCallTransaction(0) intc_1 // 0 gtxns TypeEnum - intc_3 // appl + intc_2 // appl == assert // transaction type is appl intc_1 // 0 - // a/contract.py:70 + // tests/artifacts/Arc4ABIMethod/contract.py:70 // assert app_txn.apps(0) == op.Global.current_application_id dup gtxnsas Applications global CurrentApplicationID == assert - // a/contract.py:71 + // tests/artifacts/Arc4ABIMethod/contract.py:71 // assert Txn.applications(0) == op.Global.current_application_id txna Applications 0 global CurrentApplicationID == assert - // a/contract.py:69 + // tests/artifacts/Arc4ABIMethod/contract.py:69 // app_txn = gtxn.ApplicationCallTransaction(0) intc_1 // 0 - // a/contract.py:72 + // tests/artifacts/Arc4ABIMethod/contract.py:72 // assert app_txn.apps(1) == app intc_0 // 1 gtxnsas Applications - frame_dig -3 + dig 1 == assert - // a/contract.py:73 + // tests/artifacts/Arc4ABIMethod/contract.py:73 // assert Txn.applications(1) == app txna Applications 1 - frame_dig -3 == - assert - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:61 + // @arc4.abimethod(resource_encoding="index") + return -// test_cases.a.contract.SignaturesContract.with_acc(value: bytes, acc: bytes, arr: bytes) -> void: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_acc[routing]() -> void: with_acc: - // a/contract.py:75-76 + // tests/artifacts/Arc4ABIMethod/contract.py:75 // @arc4.abimethod(resource_encoding="index") - // def with_acc(self, value: arc4.String, acc: Account, arr: UInt8Array) -> None: - proto 3 0 - // a/contract.py:77 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + btoi + txnas Accounts + txna ApplicationArgs 3 + // tests/artifacts/Arc4ABIMethod/contract.py:77 // assert value - frame_dig -3 + uncover 2 bytec_0 // 0x0000 != assert - // a/contract.py:78 + // tests/artifacts/Arc4ABIMethod/contract.py:78 // assert arr - frame_dig -1 bytec_0 // 0x0000 != assert - // a/contract.py:79 + // tests/artifacts/Arc4ABIMethod/contract.py:79 // assert acc.balance == acc.min_balance + 1234 - frame_dig -2 + dup acct_params_get AcctBalance assert // account funded - frame_dig -2 + dig 1 acct_params_get AcctMinBalance assert // account funded pushint 1234 // 1234 + == assert - // a/contract.py:80 + // tests/artifacts/Arc4ABIMethod/contract.py:80 // assert Txn.accounts(0) == Txn.sender txna Accounts 0 txn Sender == assert - // a/contract.py:81 + // tests/artifacts/Arc4ABIMethod/contract.py:81 // assert Txn.accounts(1) == acc txna Accounts 1 - frame_dig -2 == - assert - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:75 + // @arc4.abimethod(resource_encoding="index") + return -// test_cases.a.contract.SignaturesContract.complex_sig(struct1: bytes, txn: uint64, acc: bytes, five: bytes) -> bytes, bytes: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.complex_sig[routing]() -> void: complex_sig: - // a/contract.py:83-86 + // tests/artifacts/Arc4ABIMethod/contract.py:83 // @arc4.abimethod(resource_encoding="index") - // def complex_sig( - // self, struct1: MyStruct, txn: algopy.gtxn.Transaction, acc: Account, five: UInt8Array - // ) -> tuple[MyStructAlias, MyStruct]: - proto 4 2 - // a/contract.py:87 + txna ApplicationArgs 1 + txn GroupIndex + intc_0 // 1 + - + txna ApplicationArgs 2 + btoi + txnas Accounts + txna ApplicationArgs 3 + // tests/artifacts/Arc4ABIMethod/contract.py:87 // assert Txn.num_app_args == 4 txn NumAppArgs - intc_2 // 4 + pushint 4 // 4 == assert - // a/contract.py:88-89 + // tests/artifacts/Arc4ABIMethod/contract.py:88-89 // # struct // assert struct1.another_struct.one == 1 - frame_dig -4 + dig 3 intc_1 // 0 extract_uint16 - frame_dig -4 + dig 4 pushint 2 // 2 extract_uint16 - frame_dig -4 + dig 5 uncover 2 dig 2 substring3 @@ -584,7 +348,7 @@ complex_sig: bytec_2 // 0x0000000000000001 b== assert - // a/contract.py:88-90 + // tests/artifacts/Arc4ABIMethod/contract.py:88-90 // # struct // assert struct1.another_struct.one == 1 // assert struct1.another_struct.two == "2" @@ -594,19 +358,20 @@ complex_sig: dig 1 len dig 2 - cover 2 + uncover 2 + dig 2 substring3 - // a/contract.py:90 + // tests/artifacts/Arc4ABIMethod/contract.py:90 // assert struct1.another_struct.two == "2" bytec_3 // 0x000132 == assert - // a/contract.py:91 + // tests/artifacts/Arc4ABIMethod/contract.py:91 // assert struct1.another_struct_alias.one == 1 - frame_dig -4 + dig 6 len - frame_dig -4 - uncover 3 + dig 7 + uncover 4 uncover 2 substring3 dup @@ -614,7 +379,7 @@ complex_sig: bytec_2 // 0x0000000000000001 b== assert - // a/contract.py:91-92 + // tests/artifacts/Arc4ABIMethod/contract.py:91-92 // assert struct1.another_struct_alias.one == 1 // assert struct1.another_struct_alias.two == "2" dup @@ -623,158 +388,201 @@ complex_sig: dig 1 len substring3 - // a/contract.py:90 + // tests/artifacts/Arc4ABIMethod/contract.py:90 // assert struct1.another_struct.two == "2" bytec_3 // 0x000132 - // a/contract.py:92 + // tests/artifacts/Arc4ABIMethod/contract.py:92 // assert struct1.another_struct_alias.two == "2" == assert - // a/contract.py:93 + // tests/artifacts/Arc4ABIMethod/contract.py:93 // assert struct1.three == 3 - frame_dig -4 + dig 5 extract 4 16 pushbytes 0x00000000000000000000000000000003 b== assert - // a/contract.py:94 + // tests/artifacts/Arc4ABIMethod/contract.py:94 // assert struct1.four == 4 - frame_dig -4 + dig 5 extract 20 16 pushbytes 0x00000000000000000000000000000004 b== assert - // a/contract.py:96-97 + // tests/artifacts/Arc4ABIMethod/contract.py:96-97 // # txn // assert txn.group_index == Txn.group_index - 1 - frame_dig -3 + uncover 4 gtxns GroupIndex txn GroupIndex intc_0 // 1 - == assert - // a/contract.py:99-100 + // tests/artifacts/Arc4ABIMethod/contract.py:99-100 // # acc // assert Txn.application_args(2) == arc4.UInt8(1).bytes # acc array ref txna ApplicationArgs 2 pushbytes 0x01 == assert - // a/contract.py:101 + // tests/artifacts/Arc4ABIMethod/contract.py:101 // assert acc.balance == acc.min_balance + 1234 - frame_dig -2 + dig 3 acct_params_get AcctBalance assert // account funded - frame_dig -2 + uncover 4 acct_params_get AcctMinBalance assert // account funded pushint 1234 // 1234 + == assert - // a/contract.py:102 + // tests/artifacts/Arc4ABIMethod/contract.py:102 // assert five[0] == 5 - frame_dig -1 + uncover 2 extract 2 1 pushbytes 0x05 b== assert - // a/contract.py:104 - // return struct1.another_struct.copy(), struct1.copy() - frame_dig -4 - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:83 + // @arc4.abimethod(resource_encoding="index") + pushint 4 // 4 + + + itob + extract 6 2 + pushbytes 0x0004 + swap + concat + swap + concat + swap + concat + bytec_1 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// test_cases.a.contract.SignaturesContract.echo_resource_by_index(asset: uint64, app: uint64, acc: bytes) -> uint64, uint64, bytes: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.echo_resource_by_index[routing]() -> void: echo_resource_by_index: - // a/contract.py:106-111 + // tests/artifacts/Arc4ABIMethod/contract.py:106-108 // @arc4.abimethod( // resource_encoding="index", // ) - // def echo_resource_by_index( - // self, asset: Asset, app: Application, acc: Account - // ) -> tuple[Asset, Application, Account]: - proto 3 3 - // a/contract.py:112 + txna ApplicationArgs 1 + btoi + txnas Assets + txna ApplicationArgs 2 + btoi + txnas Applications + txna ApplicationArgs 3 + btoi + txnas Accounts + // tests/artifacts/Arc4ABIMethod/contract.py:112 // asset_idx = op.btoi(Txn.application_args(1)) txna ApplicationArgs 1 btoi - // a/contract.py:113 + // tests/artifacts/Arc4ABIMethod/contract.py:113 // assert asset == Txn.assets(asset_idx), "expected asset to be passed by index" txnas Assets - frame_dig -3 + dig 3 == assert // expected asset to be passed by index - // a/contract.py:114 + // tests/artifacts/Arc4ABIMethod/contract.py:114 // app_idx = op.btoi(Txn.application_args(2)) txna ApplicationArgs 2 btoi - // a/contract.py:115 + // tests/artifacts/Arc4ABIMethod/contract.py:115 // assert app == Txn.applications(app_idx), "expected application to be passed by index" txnas Applications - frame_dig -2 + dig 2 == assert // expected application to be passed by index - // a/contract.py:116 + // tests/artifacts/Arc4ABIMethod/contract.py:116 // acc_idx = op.btoi(Txn.application_args(3)) txna ApplicationArgs 3 btoi - // a/contract.py:117 + // tests/artifacts/Arc4ABIMethod/contract.py:117 // assert acc == Txn.accounts(acc_idx), "expected account to be passed by index" txnas Accounts - frame_dig -1 + dig 1 == assert // expected account to be passed by index - // a/contract.py:118 - // return asset, app, acc - frame_dig -3 - frame_dig -2 - frame_dig -1 - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:106-108 + // @arc4.abimethod( + // resource_encoding="index", + // ) + uncover 2 + itob + uncover 2 + itob + concat + swap + concat + bytec_1 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// test_cases.a.contract.SignaturesContract.echo_resource_by_value(asset: uint64, app: uint64, acc: bytes) -> uint64, uint64, bytes: +// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.echo_resource_by_value[routing]() -> void: echo_resource_by_value: - // a/contract.py:120-125 + // tests/artifacts/Arc4ABIMethod/contract.py:120-122 // @arc4.abimethod( // resource_encoding="value", // ) - // def echo_resource_by_value( - // self, asset: Asset, app: Application, acc: Account - // ) -> tuple[Asset, Application, Account]: - proto 3 3 - // a/contract.py:126 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + // tests/artifacts/Arc4ABIMethod/contract.py:126 // asset_id = op.btoi(Txn.application_args(1)) txna ApplicationArgs 1 btoi - // a/contract.py:127 + // tests/artifacts/Arc4ABIMethod/contract.py:127 // assert asset.id == asset_id, "expected asset to be passed by value" - frame_dig -3 + dig 3 == assert // expected asset to be passed by value - // a/contract.py:128 + // tests/artifacts/Arc4ABIMethod/contract.py:128 // app_id = op.btoi(Txn.application_args(2)) txna ApplicationArgs 2 btoi - // a/contract.py:129 + // tests/artifacts/Arc4ABIMethod/contract.py:129 // assert app.id == app_id, "expected application to be passed by value" - frame_dig -2 + dig 2 == assert // expected application to be passed by value - // a/contract.py:131 + // tests/artifacts/Arc4ABIMethod/contract.py:131 // assert acc.bytes == address, "expected account to be passed by value" - frame_dig -1 - // a/contract.py:130 + dup + // tests/artifacts/Arc4ABIMethod/contract.py:130 // address = Txn.application_args(3) txna ApplicationArgs 3 - // a/contract.py:131 + // tests/artifacts/Arc4ABIMethod/contract.py:131 // assert acc.bytes == address, "expected account to be passed by value" == assert // expected account to be passed by value - // a/contract.py:132 - // return asset, app, acc - frame_dig -3 - frame_dig -2 - frame_dig -1 - retsub + // tests/artifacts/Arc4ABIMethod/contract.py:120-122 + // @arc4.abimethod( + // resource_encoding="value", + // ) + uncover 2 + itob + uncover 2 + itob + concat + swap + concat + bytec_1 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return diff --git a/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc32.json b/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc32.json index fb20548..093e2ce 100644 --- a/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc32.json +++ b/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc32.json @@ -75,7 +75,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0 4 6
    bytecblock 0x0000 0x151f7c75 0x0000000000000001 0x000132
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txn NumAppArgs
    bz main_after_if_else@16
    pushbytess 0x4c5c61ba 0xe18922d8 0x3b05cf17 0x0658dcc3 0x5b6447de 0x061f4e77 0xeaa89139 0x510e72a4 0xd6c2ac7f 0x48142d5e // method "create()void", method "sink(string,uint8[])void", method "alias(string,uint8[])void", method "with_txn(string,pay,uint8[])void", method "with_asset(string,asset,uint8[])void", method "with_app(string,application,uint64,uint8[])void", method "with_acc(string,account,uint8[])void", method "complex_sig(((uint64,string),(uint64,string),uint128,uint128),txn,account,uint8[])((uint64,string),((uint64,string),(uint64,string),uint128,uint128))", method "echo_resource_by_index(asset,application,account)(uint64,uint64,address)", method "echo_resource_by_value(uint64,uint64,address)(uint64,uint64,address)"
    txna ApplicationArgs 0
    match main_create_route@3 main_sink_route@4 main_alias_route@5 main_with_txn_route@6 main_with_asset_route@7 main_with_app_route@8 main_with_acc_route@9 main_complex_sig_route@10 main_echo_resource_by_index_route@11 main_echo_resource_by_value_route@12

main_after_if_else@16:
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    intc_1 // 0
    return

main_echo_resource_by_value_route@12:
    // a/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    // a/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    callsub echo_resource_by_value
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_echo_resource_by_index_route@11:
    // a/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    btoi
    txnas Accounts
    // a/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    callsub echo_resource_by_index
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_complex_sig_route@10:
    // a/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // a/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    callsub complex_sig
    dig 1
    len
    intc_2 // 4
    +
    itob
    extract 6 2
    pushbytes 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_with_acc_route@9:
    // a/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // a/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    callsub with_acc
    intc_0 // 1
    return

main_with_app_route@8:
    // a/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // a/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    callsub with_app
    intc_0 // 1
    return

main_with_asset_route@7:
    // a/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Assets
    txna ApplicationArgs 3
    // a/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    callsub with_asset
    intc_0 // 1
    return

main_with_txn_route@6:
    // a/contract.py:46
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_0 // pay
    ==
    assert // transaction type is pay
    txna ApplicationArgs 2
    // a/contract.py:46
    // @arc4.abimethod
    callsub with_txn
    intc_0 // 1
    return

main_alias_route@5:
    // a/contract.py:41
    // @arc4.abimethod(name="alias")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // a/contract.py:41
    // @arc4.abimethod(name="alias")
    callsub sink2
    intc_0 // 1
    return

main_sink_route@4:
    // a/contract.py:36
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // a/contract.py:36
    // @arc4.abimethod
    callsub sink
    intc_0 // 1
    return

main_create_route@3:
    // a/contract.py:26
    // @arc4.abimethod(create="require")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    !
    assert // can only call when creating
    callsub create
    intc_0 // 1
    return


// test_cases.a.contract.SignaturesContract.create() -> void:
create:
    // a/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_3 // appl
    ==
    assert // transaction type is appl
    // a/contract.py:29
    // assert op.Global.current_application_id != 0, "expected global to have app id"
    global CurrentApplicationID
    assert // expected global to have app id
    // a/contract.py:31
    // op.Global.current_application_address != op.Global.zero_address
    global CurrentApplicationAddress
    global ZeroAddress
    !=
    // a/contract.py:30-32
    // assert (
    //     op.Global.current_application_address != op.Global.zero_address
    // ), "expected global to have app address"
    assert // expected global to have app address
    // a/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // a/contract.py:33
    // assert app_txn.app_id == 0, "expected txn to have 0"
    gtxns ApplicationID
    !
    assert // expected txn to have 0
    // a/contract.py:34
    // assert Txn.application_id == 0, "expected txn to have 0"
    txn ApplicationID
    !
    assert // expected txn to have 0
    retsub


// test_cases.a.contract.SignaturesContract.sink(value: bytes, arr: bytes) -> void:
sink:
    // a/contract.py:36-37
    // @arc4.abimethod
    // def sink(self, value: arc4.String, arr: UInt8Array) -> None:
    proto 2 0
    // a/contract.py:38
    // assert value
    frame_dig -2
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:39
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    retsub


// test_cases.a.contract.SignaturesContract.sink2(value: bytes, arr: bytes) -> void:
sink2:
    // a/contract.py:41-42
    // @arc4.abimethod(name="alias")
    // def sink2(self, value: arc4.String, arr: UInt8Array) -> None:
    proto 2 0
    // a/contract.py:43
    // assert value
    frame_dig -2
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:44
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_txn(value: bytes, pay: uint64, arr: bytes) -> void:
with_txn:
    // a/contract.py:46-47
    // @arc4.abimethod
    // def with_txn(self, value: arc4.String, pay: gtxn.PaymentTransaction, arr: UInt8Array) -> None:
    proto 3 0
    // a/contract.py:48
    // assert value
    frame_dig -3
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:49
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:50
    // assert pay.group_index == 0
    frame_dig -2
    gtxns GroupIndex
    !
    assert
    // a/contract.py:51
    // assert Txn.group_index == 1
    txn GroupIndex
    intc_0 // 1
    ==
    assert
    // a/contract.py:52
    // assert pay.amount == 123
    frame_dig -2
    gtxns Amount
    pushint 123 // 123
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_asset(value: bytes, asset: uint64, arr: bytes) -> void:
with_asset:
    // a/contract.py:54-55
    // @arc4.abimethod(resource_encoding="index")
    // def with_asset(self, value: arc4.String, asset: Asset, arr: UInt8Array) -> None:
    proto 3 0
    // a/contract.py:56
    // assert value
    frame_dig -3
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:57
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:58
    // assert asset.total == 123
    frame_dig -2
    asset_params_get AssetTotal
    assert // asset exists
    pushint 123 // 123
    ==
    assert
    // a/contract.py:59
    // assert Txn.assets(0) == asset
    txna Assets 0
    frame_dig -2
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_app(value: bytes, app: uint64, app_id: bytes, arr: bytes) -> void:
with_app:
    // a/contract.py:61-64
    // @arc4.abimethod(resource_encoding="index")
    // def with_app(
    //     self, value: arc4.String, app: Application, app_id: arc4.UInt64, arr: UInt8Array
    // ) -> None:
    proto 4 0
    // a/contract.py:65
    // assert value
    frame_dig -4
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:66
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:67
    // assert app.id == app_id, "expected app id to match provided app id"
    frame_dig -3
    itob
    frame_dig -2
    b==
    assert // expected app id to match provided app id
    // a/contract.py:68
    // assert app.creator == op.Global.creator_address, "expected other app to have same creator"
    frame_dig -3
    app_params_get AppCreator
    assert // application exists
    global CreatorAddress
    ==
    assert // expected other app to have same creator
    // a/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_3 // appl
    ==
    assert // transaction type is appl
    intc_1 // 0
    // a/contract.py:70
    // assert app_txn.apps(0) == op.Global.current_application_id
    dup
    gtxnsas Applications
    global CurrentApplicationID
    ==
    assert
    // a/contract.py:71
    // assert Txn.applications(0) == op.Global.current_application_id
    txna Applications 0
    global CurrentApplicationID
    ==
    assert
    // a/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // a/contract.py:72
    // assert app_txn.apps(1) == app
    intc_0 // 1
    gtxnsas Applications
    frame_dig -3
    ==
    assert
    // a/contract.py:73
    // assert Txn.applications(1) == app
    txna Applications 1
    frame_dig -3
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_acc(value: bytes, acc: bytes, arr: bytes) -> void:
with_acc:
    // a/contract.py:75-76
    // @arc4.abimethod(resource_encoding="index")
    // def with_acc(self, value: arc4.String, acc: Account, arr: UInt8Array) -> None:
    proto 3 0
    // a/contract.py:77
    // assert value
    frame_dig -3
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:78
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:79
    // assert acc.balance == acc.min_balance + 1234
    frame_dig -2
    acct_params_get AcctBalance
    assert // account funded
    frame_dig -2
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // a/contract.py:80
    // assert Txn.accounts(0) == Txn.sender
    txna Accounts 0
    txn Sender
    ==
    assert
    // a/contract.py:81
    // assert Txn.accounts(1) == acc
    txna Accounts 1
    frame_dig -2
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.complex_sig(struct1: bytes, txn: uint64, acc: bytes, five: bytes) -> bytes, bytes:
complex_sig:
    // a/contract.py:83-86
    // @arc4.abimethod(resource_encoding="index")
    // def complex_sig(
    //     self, struct1: MyStruct, txn: algopy.gtxn.Transaction, acc: Account, five: UInt8Array
    // ) -> tuple[MyStructAlias, MyStruct]:
    proto 4 2
    // a/contract.py:87
    // assert Txn.num_app_args == 4
    txn NumAppArgs
    intc_2 // 4
    ==
    assert
    // a/contract.py:88-89
    // # struct
    // assert struct1.another_struct.one == 1
    frame_dig -4
    intc_1 // 0
    extract_uint16
    frame_dig -4
    pushint 2 // 2
    extract_uint16
    frame_dig -4
    uncover 2
    dig 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // a/contract.py:88-90
    // # struct
    // assert struct1.another_struct.one == 1
    // assert struct1.another_struct.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    dig 2
    cover 2
    substring3
    // a/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    ==
    assert
    // a/contract.py:91
    // assert struct1.another_struct_alias.one == 1
    frame_dig -4
    len
    frame_dig -4
    uncover 3
    uncover 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // a/contract.py:91-92
    // assert struct1.another_struct_alias.one == 1
    // assert struct1.another_struct_alias.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    substring3
    // a/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    // a/contract.py:92
    // assert struct1.another_struct_alias.two == "2"
    ==
    assert
    // a/contract.py:93
    // assert struct1.three == 3
    frame_dig -4
    extract 4 16
    pushbytes 0x00000000000000000000000000000003
    b==
    assert
    // a/contract.py:94
    // assert struct1.four == 4
    frame_dig -4
    extract 20 16
    pushbytes 0x00000000000000000000000000000004
    b==
    assert
    // a/contract.py:96-97
    // # txn
    // assert txn.group_index == Txn.group_index - 1
    frame_dig -3
    gtxns GroupIndex
    txn GroupIndex
    intc_0 // 1
    -
    ==
    assert
    // a/contract.py:99-100
    // # acc
    // assert Txn.application_args(2) == arc4.UInt8(1).bytes  # acc array ref
    txna ApplicationArgs 2
    pushbytes 0x01
    ==
    assert
    // a/contract.py:101
    // assert acc.balance == acc.min_balance + 1234
    frame_dig -2
    acct_params_get AcctBalance
    assert // account funded
    frame_dig -2
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // a/contract.py:102
    // assert five[0] == 5
    frame_dig -1
    extract 2 1
    pushbytes 0x05
    b==
    assert
    // a/contract.py:104
    // return struct1.another_struct.copy(), struct1.copy()
    frame_dig -4
    retsub


// test_cases.a.contract.SignaturesContract.echo_resource_by_index(asset: uint64, app: uint64, acc: bytes) -> uint64, uint64, bytes:
echo_resource_by_index:
    // a/contract.py:106-111
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    // def echo_resource_by_index(
    //     self, asset: Asset, app: Application, acc: Account
    // ) -> tuple[Asset, Application, Account]:
    proto 3 3
    // a/contract.py:112
    // asset_idx = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // a/contract.py:113
    // assert asset == Txn.assets(asset_idx), "expected asset to be passed by index"
    txnas Assets
    frame_dig -3
    ==
    assert // expected asset to be passed by index
    // a/contract.py:114
    // app_idx = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // a/contract.py:115
    // assert app == Txn.applications(app_idx), "expected application to be passed by index"
    txnas Applications
    frame_dig -2
    ==
    assert // expected application to be passed by index
    // a/contract.py:116
    // acc_idx = op.btoi(Txn.application_args(3))
    txna ApplicationArgs 3
    btoi
    // a/contract.py:117
    // assert acc == Txn.accounts(acc_idx), "expected account to be passed by index"
    txnas Accounts
    frame_dig -1
    ==
    assert // expected account to be passed by index
    // a/contract.py:118
    // return asset, app, acc
    frame_dig -3
    frame_dig -2
    frame_dig -1
    retsub


// test_cases.a.contract.SignaturesContract.echo_resource_by_value(asset: uint64, app: uint64, acc: bytes) -> uint64, uint64, bytes:
echo_resource_by_value:
    // a/contract.py:120-125
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    // def echo_resource_by_value(
    //     self, asset: Asset, app: Application, acc: Account
    // ) -> tuple[Asset, Application, Account]:
    proto 3 3
    // a/contract.py:126
    // asset_id = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // a/contract.py:127
    // assert asset.id == asset_id, "expected asset to be passed by value"
    frame_dig -3
    ==
    assert // expected asset to be passed by value
    // a/contract.py:128
    // app_id = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // a/contract.py:129
    // assert app.id == app_id, "expected application to be passed by value"
    frame_dig -2
    ==
    assert // expected application to be passed by value
    // a/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    frame_dig -1
    // a/contract.py:130
    // address = Txn.application_args(3)
    txna ApplicationArgs 3
    // a/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    ==
    assert // expected account to be passed by value
    // a/contract.py:132
    // return asset, app, acc
    frame_dig -3
    frame_dig -2
    frame_dig -1
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0 6 123
    bytecblock 0x0000 0x151f7c75 0x0000000000000001 0x000132
    // tests/artifacts/Arc4ABIMethod/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    bz main_create_NoOp@13
    pushbytess 0xe18922d8 0x3b05cf17 0x0658dcc3 0x5b6447de 0x061f4e77 0xeaa89139 0x510e72a4 0xd6c2ac7f 0x48142d5e // method "sink(string,uint8[])void", method "alias(string,uint8[])void", method "with_txn(string,pay,uint8[])void", method "with_asset(string,asset,uint8[])void", method "with_app(string,application,uint64,uint8[])void", method "with_acc(string,account,uint8[])void", method "complex_sig(((uint64,string),(uint64,string),uint128,uint128),txn,account,uint8[])((uint64,string),((uint64,string),(uint64,string),uint128,uint128))", method "echo_resource_by_index(asset,application,account)(uint64,uint64,address)", method "echo_resource_by_value(uint64,uint64,address)(uint64,uint64,address)"
    txna ApplicationArgs 0
    match sink sink2 with_txn with_asset with_app with_acc complex_sig echo_resource_by_index echo_resource_by_value
    err

main_create_NoOp@13:
    // tests/artifacts/Arc4ABIMethod/contract.py:25
    // class SignaturesContract(ARC4Contract):
    pushbytes 0x4c5c61ba // method "create()void"
    txna ApplicationArgs 0
    match create
    err


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.create[routing]() -> void:
create:
    // tests/artifacts/Arc4ABIMethod/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    // tests/artifacts/Arc4ABIMethod/contract.py:29
    // assert op.Global.current_application_id != 0, "expected global to have app id"
    global CurrentApplicationID
    assert // expected global to have app id
    // tests/artifacts/Arc4ABIMethod/contract.py:31
    // op.Global.current_application_address != op.Global.zero_address
    global CurrentApplicationAddress
    global ZeroAddress
    !=
    // tests/artifacts/Arc4ABIMethod/contract.py:30-32
    // assert (
    //     op.Global.current_application_address != op.Global.zero_address
    // ), "expected global to have app address"
    assert // expected global to have app address
    // tests/artifacts/Arc4ABIMethod/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // tests/artifacts/Arc4ABIMethod/contract.py:33
    // assert app_txn.app_id == 0, "expected txn to have 0"
    gtxns ApplicationID
    !
    assert // expected txn to have 0
    // tests/artifacts/Arc4ABIMethod/contract.py:34
    // assert Txn.application_id == 0, "expected txn to have 0"
    txn ApplicationID
    !
    // tests/artifacts/Arc4ABIMethod/contract.py:26
    // @arc4.abimethod(create="require")
    return // on error: expected txn to have 0


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.sink[routing]() -> void:
sink:
    // tests/artifacts/Arc4ABIMethod/contract.py:36
    // @arc4.abimethod
    txna ApplicationArgs 2
    txna ApplicationArgs 1
    // tests/artifacts/Arc4ABIMethod/contract.py:38
    // assert value
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:39
    // assert arr
    bytec_0 // 0x0000
    !=
    // tests/artifacts/Arc4ABIMethod/contract.py:36
    // @arc4.abimethod
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.sink2[routing]() -> void:
sink2:
    // tests/artifacts/Arc4ABIMethod/contract.py:41
    // @arc4.abimethod(name="alias")
    txna ApplicationArgs 2
    txna ApplicationArgs 1
    // tests/artifacts/Arc4ABIMethod/contract.py:43
    // assert value
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:44
    // assert arr
    bytec_0 // 0x0000
    !=
    // tests/artifacts/Arc4ABIMethod/contract.py:41
    // @arc4.abimethod(name="alias")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_txn[routing]() -> void:
with_txn:
    // tests/artifacts/Arc4ABIMethod/contract.py:46
    // @arc4.abimethod
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_0 // pay
    ==
    assert // transaction type is pay
    txna ApplicationArgs 2
    // tests/artifacts/Arc4ABIMethod/contract.py:48
    // assert value
    uncover 2
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:49
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:50
    // assert pay.group_index == 0
    dup
    gtxns GroupIndex
    !
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:51
    // assert Txn.group_index == 1
    txn GroupIndex
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:52
    // assert pay.amount == 123
    gtxns Amount
    intc_3 // 123
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:46
    // @arc4.abimethod
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_asset[routing]() -> void:
with_asset:
    // tests/artifacts/Arc4ABIMethod/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Assets
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:56
    // assert value
    uncover 2
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:57
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:58
    // assert asset.total == 123
    dup
    asset_params_get AssetTotal
    assert // asset exists
    intc_3 // 123
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:59
    // assert Txn.assets(0) == asset
    txna Assets 0
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_app[routing]() -> void:
with_app:
    // tests/artifacts/Arc4ABIMethod/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // tests/artifacts/Arc4ABIMethod/contract.py:65
    // assert value
    uncover 3
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:66
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:67
    // assert app.id == app_id, "expected app id to match provided app id"
    dig 1
    itob
    b==
    assert // expected app id to match provided app id
    // tests/artifacts/Arc4ABIMethod/contract.py:68
    // assert app.creator == op.Global.creator_address, "expected other app to have same creator"
    dup
    app_params_get AppCreator
    assert // application exists
    global CreatorAddress
    ==
    assert // expected other app to have same creator
    // tests/artifacts/Arc4ABIMethod/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    intc_1 // 0
    // tests/artifacts/Arc4ABIMethod/contract.py:70
    // assert app_txn.apps(0) == op.Global.current_application_id
    dup
    gtxnsas Applications
    global CurrentApplicationID
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:71
    // assert Txn.applications(0) == op.Global.current_application_id
    txna Applications 0
    global CurrentApplicationID
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // tests/artifacts/Arc4ABIMethod/contract.py:72
    // assert app_txn.apps(1) == app
    intc_0 // 1
    gtxnsas Applications
    dig 1
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:73
    // assert Txn.applications(1) == app
    txna Applications 1
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_acc[routing]() -> void:
with_acc:
    // tests/artifacts/Arc4ABIMethod/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:77
    // assert value
    uncover 2
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:78
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:79
    // assert acc.balance == acc.min_balance + 1234
    dup
    acct_params_get AcctBalance
    assert // account funded
    dig 1
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:80
    // assert Txn.accounts(0) == Txn.sender
    txna Accounts 0
    txn Sender
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:81
    // assert Txn.accounts(1) == acc
    txna Accounts 1
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.complex_sig[routing]() -> void:
complex_sig:
    // tests/artifacts/Arc4ABIMethod/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:87
    // assert Txn.num_app_args == 4
    txn NumAppArgs
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:88-89
    // # struct
    // assert struct1.another_struct.one == 1
    dig 3
    intc_1 // 0
    extract_uint16
    dig 4
    pushint 2 // 2
    extract_uint16
    dig 5
    uncover 2
    dig 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:88-90
    // # struct
    // assert struct1.another_struct.one == 1
    // assert struct1.another_struct.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    dig 2
    uncover 2
    dig 2
    substring3
    // tests/artifacts/Arc4ABIMethod/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:91
    // assert struct1.another_struct_alias.one == 1
    dig 6
    len
    dig 7
    uncover 4
    uncover 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:91-92
    // assert struct1.another_struct_alias.one == 1
    // assert struct1.another_struct_alias.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    substring3
    // tests/artifacts/Arc4ABIMethod/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    // tests/artifacts/Arc4ABIMethod/contract.py:92
    // assert struct1.another_struct_alias.two == "2"
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:93
    // assert struct1.three == 3
    dig 5
    extract 4 16
    pushbytes 0x00000000000000000000000000000003
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:94
    // assert struct1.four == 4
    dig 5
    extract 20 16
    pushbytes 0x00000000000000000000000000000004
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:96-97
    // # txn
    // assert txn.group_index == Txn.group_index - 1
    uncover 4
    gtxns GroupIndex
    txn GroupIndex
    intc_0 // 1
    -
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:99-100
    // # acc
    // assert Txn.application_args(2) == arc4.UInt8(1).bytes  # acc array ref
    txna ApplicationArgs 2
    pushbytes 0x01
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:101
    // assert acc.balance == acc.min_balance + 1234
    dig 3
    acct_params_get AcctBalance
    assert // account funded
    uncover 4
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:102
    // assert five[0] == 5
    uncover 2
    extract 2 1
    pushbytes 0x05
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    pushint 4 // 4
    +
    itob
    extract 6 2
    pushbytes 0x0004
    swap
    concat
    swap
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.echo_resource_by_index[routing]() -> void:
echo_resource_by_index:
    // tests/artifacts/Arc4ABIMethod/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    txna ApplicationArgs 1
    btoi
    txnas Assets
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    btoi
    txnas Accounts
    // tests/artifacts/Arc4ABIMethod/contract.py:112
    // asset_idx = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:113
    // assert asset == Txn.assets(asset_idx), "expected asset to be passed by index"
    txnas Assets
    dig 3
    ==
    assert // expected asset to be passed by index
    // tests/artifacts/Arc4ABIMethod/contract.py:114
    // app_idx = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:115
    // assert app == Txn.applications(app_idx), "expected application to be passed by index"
    txnas Applications
    dig 2
    ==
    assert // expected application to be passed by index
    // tests/artifacts/Arc4ABIMethod/contract.py:116
    // acc_idx = op.btoi(Txn.application_args(3))
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:117
    // assert acc == Txn.accounts(acc_idx), "expected account to be passed by index"
    txnas Accounts
    dig 1
    ==
    assert // expected account to be passed by index
    // tests/artifacts/Arc4ABIMethod/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.echo_resource_by_value[routing]() -> void:
echo_resource_by_value:
    // tests/artifacts/Arc4ABIMethod/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:126
    // asset_id = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:127
    // assert asset.id == asset_id, "expected asset to be passed by value"
    dig 3
    ==
    assert // expected asset to be passed by value
    // tests/artifacts/Arc4ABIMethod/contract.py:128
    // app_id = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:129
    // assert app.id == app_id, "expected application to be passed by value"
    dig 2
    ==
    assert // expected application to be passed by value
    // tests/artifacts/Arc4ABIMethod/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    dup
    // tests/artifacts/Arc4ABIMethod/contract.py:130
    // address = Txn.application_args(3)
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    ==
    assert // expected account to be passed by value
    // tests/artifacts/Arc4ABIMethod/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc56.json b/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc56.json index 19f4f1d..c343fe8 100644 --- a/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc56.json +++ b/tests/artifacts/Arc4ABIMethod/data/SignaturesContract.arc56.json @@ -346,137 +346,108 @@ "sourceInfo": [ { "pc": [ - 117, - 153, - 196, - 248, - 272, - 299, - 323, - 351, - 369, - 387 + 33 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 596, - 601, - 769, - 774 + 336, + 341, + 522, + 527 ], "errorMessage": "account funded" }, { "pc": [ - 537 + 274 ], "errorMessage": "application exists" }, { "pc": [ - 500 + 234 ], "errorMessage": "asset exists" }, { "pc": [ - 391 - ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 120, - 156, - 199, - 251, - 275, - 302, - 326, - 354, - 372 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 826 + 614 ], "errorMessage": "expected account to be passed by index" }, { "pc": [ - 859 + 662 ], "errorMessage": "expected account to be passed by value" }, { "pc": [ - 532 + 270 ], "errorMessage": "expected app id to match provided app id" }, { "pc": [ - 816 + 604 ], "errorMessage": "expected application to be passed by index" }, { "pc": [ - 852 + 656 ], "errorMessage": "expected application to be passed by value" }, { "pc": [ - 806 + 594 ], "errorMessage": "expected asset to be passed by index" }, { "pc": [ - 844 + 648 ], "errorMessage": "expected asset to be passed by value" }, { "pc": [ - 411 + 138 ], "errorMessage": "expected global to have app address" }, { "pc": [ - 405 + 132 ], "errorMessage": "expected global to have app id" }, { "pc": [ - 541 + 278 ], "errorMessage": "expected other app to have same creator" }, { "pc": [ - 416, - 420 + 143, + 147 ], "errorMessage": "expected txn to have 0" }, { "pc": [ - 402, - 547 + 129, + 284 ], "errorMessage": "transaction type is appl" }, { "pc": [ - 339 + 184 ], "errorMessage": "transaction type is pay" } @@ -489,19 +460,19 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0 4 6
    bytecblock 0x0000 0x151f7c75 0x0000000000000001 0x000132
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txn NumAppArgs
    bz main_after_if_else@16
    pushbytess 0x4c5c61ba 0xe18922d8 0x3b05cf17 0x0658dcc3 0x5b6447de 0x061f4e77 0xeaa89139 0x510e72a4 0xd6c2ac7f 0x48142d5e // method "create()void", method "sink(string,uint8[])void", method "alias(string,uint8[])void", method "with_txn(string,pay,uint8[])void", method "with_asset(string,asset,uint8[])void", method "with_app(string,application,uint64,uint8[])void", method "with_acc(string,account,uint8[])void", method "complex_sig(((uint64,string),(uint64,string),uint128,uint128),txn,account,uint8[])((uint64,string),((uint64,string),(uint64,string),uint128,uint128))", method "echo_resource_by_index(asset,application,account)(uint64,uint64,address)", method "echo_resource_by_value(uint64,uint64,address)(uint64,uint64,address)"
    txna ApplicationArgs 0
    match main_create_route@3 main_sink_route@4 main_alias_route@5 main_with_txn_route@6 main_with_asset_route@7 main_with_app_route@8 main_with_acc_route@9 main_complex_sig_route@10 main_echo_resource_by_index_route@11 main_echo_resource_by_value_route@12

main_after_if_else@16:
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    intc_1 // 0
    return

main_echo_resource_by_value_route@12:
    // a/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    // a/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    callsub echo_resource_by_value
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_echo_resource_by_index_route@11:
    // a/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    btoi
    txnas Accounts
    // a/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    callsub echo_resource_by_index
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_complex_sig_route@10:
    // a/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // a/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    callsub complex_sig
    dig 1
    len
    intc_2 // 4
    +
    itob
    extract 6 2
    pushbytes 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_with_acc_route@9:
    // a/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // a/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    callsub with_acc
    intc_0 // 1
    return

main_with_app_route@8:
    // a/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // a/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    callsub with_app
    intc_0 // 1
    return

main_with_asset_route@7:
    // a/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Assets
    txna ApplicationArgs 3
    // a/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    callsub with_asset
    intc_0 // 1
    return

main_with_txn_route@6:
    // a/contract.py:46
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_0 // pay
    ==
    assert // transaction type is pay
    txna ApplicationArgs 2
    // a/contract.py:46
    // @arc4.abimethod
    callsub with_txn
    intc_0 // 1
    return

main_alias_route@5:
    // a/contract.py:41
    // @arc4.abimethod(name="alias")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // a/contract.py:41
    // @arc4.abimethod(name="alias")
    callsub sink2
    intc_0 // 1
    return

main_sink_route@4:
    // a/contract.py:36
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // a/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // a/contract.py:36
    // @arc4.abimethod
    callsub sink
    intc_0 // 1
    return

main_create_route@3:
    // a/contract.py:26
    // @arc4.abimethod(create="require")
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    !
    assert // can only call when creating
    callsub create
    intc_0 // 1
    return


// test_cases.a.contract.SignaturesContract.create() -> void:
create:
    // a/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_3 // appl
    ==
    assert // transaction type is appl
    // a/contract.py:29
    // assert op.Global.current_application_id != 0, "expected global to have app id"
    global CurrentApplicationID
    assert // expected global to have app id
    // a/contract.py:31
    // op.Global.current_application_address != op.Global.zero_address
    global CurrentApplicationAddress
    global ZeroAddress
    !=
    // a/contract.py:30-32
    // assert (
    //     op.Global.current_application_address != op.Global.zero_address
    // ), "expected global to have app address"
    assert // expected global to have app address
    // a/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // a/contract.py:33
    // assert app_txn.app_id == 0, "expected txn to have 0"
    gtxns ApplicationID
    !
    assert // expected txn to have 0
    // a/contract.py:34
    // assert Txn.application_id == 0, "expected txn to have 0"
    txn ApplicationID
    !
    assert // expected txn to have 0
    retsub


// test_cases.a.contract.SignaturesContract.sink(value: bytes, arr: bytes) -> void:
sink:
    // a/contract.py:36-37
    // @arc4.abimethod
    // def sink(self, value: arc4.String, arr: UInt8Array) -> None:
    proto 2 0
    // a/contract.py:38
    // assert value
    frame_dig -2
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:39
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    retsub


// test_cases.a.contract.SignaturesContract.sink2(value: bytes, arr: bytes) -> void:
sink2:
    // a/contract.py:41-42
    // @arc4.abimethod(name="alias")
    // def sink2(self, value: arc4.String, arr: UInt8Array) -> None:
    proto 2 0
    // a/contract.py:43
    // assert value
    frame_dig -2
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:44
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_txn(value: bytes, pay: uint64, arr: bytes) -> void:
with_txn:
    // a/contract.py:46-47
    // @arc4.abimethod
    // def with_txn(self, value: arc4.String, pay: gtxn.PaymentTransaction, arr: UInt8Array) -> None:
    proto 3 0
    // a/contract.py:48
    // assert value
    frame_dig -3
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:49
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:50
    // assert pay.group_index == 0
    frame_dig -2
    gtxns GroupIndex
    !
    assert
    // a/contract.py:51
    // assert Txn.group_index == 1
    txn GroupIndex
    intc_0 // 1
    ==
    assert
    // a/contract.py:52
    // assert pay.amount == 123
    frame_dig -2
    gtxns Amount
    pushint 123 // 123
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_asset(value: bytes, asset: uint64, arr: bytes) -> void:
with_asset:
    // a/contract.py:54-55
    // @arc4.abimethod(resource_encoding="index")
    // def with_asset(self, value: arc4.String, asset: Asset, arr: UInt8Array) -> None:
    proto 3 0
    // a/contract.py:56
    // assert value
    frame_dig -3
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:57
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:58
    // assert asset.total == 123
    frame_dig -2
    asset_params_get AssetTotal
    assert // asset exists
    pushint 123 // 123
    ==
    assert
    // a/contract.py:59
    // assert Txn.assets(0) == asset
    txna Assets 0
    frame_dig -2
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_app(value: bytes, app: uint64, app_id: bytes, arr: bytes) -> void:
with_app:
    // a/contract.py:61-64
    // @arc4.abimethod(resource_encoding="index")
    // def with_app(
    //     self, value: arc4.String, app: Application, app_id: arc4.UInt64, arr: UInt8Array
    // ) -> None:
    proto 4 0
    // a/contract.py:65
    // assert value
    frame_dig -4
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:66
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:67
    // assert app.id == app_id, "expected app id to match provided app id"
    frame_dig -3
    itob
    frame_dig -2
    b==
    assert // expected app id to match provided app id
    // a/contract.py:68
    // assert app.creator == op.Global.creator_address, "expected other app to have same creator"
    frame_dig -3
    app_params_get AppCreator
    assert // application exists
    global CreatorAddress
    ==
    assert // expected other app to have same creator
    // a/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_3 // appl
    ==
    assert // transaction type is appl
    intc_1 // 0
    // a/contract.py:70
    // assert app_txn.apps(0) == op.Global.current_application_id
    dup
    gtxnsas Applications
    global CurrentApplicationID
    ==
    assert
    // a/contract.py:71
    // assert Txn.applications(0) == op.Global.current_application_id
    txna Applications 0
    global CurrentApplicationID
    ==
    assert
    // a/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // a/contract.py:72
    // assert app_txn.apps(1) == app
    intc_0 // 1
    gtxnsas Applications
    frame_dig -3
    ==
    assert
    // a/contract.py:73
    // assert Txn.applications(1) == app
    txna Applications 1
    frame_dig -3
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.with_acc(value: bytes, acc: bytes, arr: bytes) -> void:
with_acc:
    // a/contract.py:75-76
    // @arc4.abimethod(resource_encoding="index")
    // def with_acc(self, value: arc4.String, acc: Account, arr: UInt8Array) -> None:
    proto 3 0
    // a/contract.py:77
    // assert value
    frame_dig -3
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:78
    // assert arr
    frame_dig -1
    bytec_0 // 0x0000
    !=
    assert
    // a/contract.py:79
    // assert acc.balance == acc.min_balance + 1234
    frame_dig -2
    acct_params_get AcctBalance
    assert // account funded
    frame_dig -2
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // a/contract.py:80
    // assert Txn.accounts(0) == Txn.sender
    txna Accounts 0
    txn Sender
    ==
    assert
    // a/contract.py:81
    // assert Txn.accounts(1) == acc
    txna Accounts 1
    frame_dig -2
    ==
    assert
    retsub


// test_cases.a.contract.SignaturesContract.complex_sig(struct1: bytes, txn: uint64, acc: bytes, five: bytes) -> bytes, bytes:
complex_sig:
    // a/contract.py:83-86
    // @arc4.abimethod(resource_encoding="index")
    // def complex_sig(
    //     self, struct1: MyStruct, txn: algopy.gtxn.Transaction, acc: Account, five: UInt8Array
    // ) -> tuple[MyStructAlias, MyStruct]:
    proto 4 2
    // a/contract.py:87
    // assert Txn.num_app_args == 4
    txn NumAppArgs
    intc_2 // 4
    ==
    assert
    // a/contract.py:88-89
    // # struct
    // assert struct1.another_struct.one == 1
    frame_dig -4
    intc_1 // 0
    extract_uint16
    frame_dig -4
    pushint 2 // 2
    extract_uint16
    frame_dig -4
    uncover 2
    dig 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // a/contract.py:88-90
    // # struct
    // assert struct1.another_struct.one == 1
    // assert struct1.another_struct.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    dig 2
    cover 2
    substring3
    // a/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    ==
    assert
    // a/contract.py:91
    // assert struct1.another_struct_alias.one == 1
    frame_dig -4
    len
    frame_dig -4
    uncover 3
    uncover 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // a/contract.py:91-92
    // assert struct1.another_struct_alias.one == 1
    // assert struct1.another_struct_alias.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    substring3
    // a/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    // a/contract.py:92
    // assert struct1.another_struct_alias.two == "2"
    ==
    assert
    // a/contract.py:93
    // assert struct1.three == 3
    frame_dig -4
    extract 4 16
    pushbytes 0x00000000000000000000000000000003
    b==
    assert
    // a/contract.py:94
    // assert struct1.four == 4
    frame_dig -4
    extract 20 16
    pushbytes 0x00000000000000000000000000000004
    b==
    assert
    // a/contract.py:96-97
    // # txn
    // assert txn.group_index == Txn.group_index - 1
    frame_dig -3
    gtxns GroupIndex
    txn GroupIndex
    intc_0 // 1
    -
    ==
    assert
    // a/contract.py:99-100
    // # acc
    // assert Txn.application_args(2) == arc4.UInt8(1).bytes  # acc array ref
    txna ApplicationArgs 2
    pushbytes 0x01
    ==
    assert
    // a/contract.py:101
    // assert acc.balance == acc.min_balance + 1234
    frame_dig -2
    acct_params_get AcctBalance
    assert // account funded
    frame_dig -2
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // a/contract.py:102
    // assert five[0] == 5
    frame_dig -1
    extract 2 1
    pushbytes 0x05
    b==
    assert
    // a/contract.py:104
    // return struct1.another_struct.copy(), struct1.copy()
    frame_dig -4
    retsub


// test_cases.a.contract.SignaturesContract.echo_resource_by_index(asset: uint64, app: uint64, acc: bytes) -> uint64, uint64, bytes:
echo_resource_by_index:
    // a/contract.py:106-111
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    // def echo_resource_by_index(
    //     self, asset: Asset, app: Application, acc: Account
    // ) -> tuple[Asset, Application, Account]:
    proto 3 3
    // a/contract.py:112
    // asset_idx = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // a/contract.py:113
    // assert asset == Txn.assets(asset_idx), "expected asset to be passed by index"
    txnas Assets
    frame_dig -3
    ==
    assert // expected asset to be passed by index
    // a/contract.py:114
    // app_idx = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // a/contract.py:115
    // assert app == Txn.applications(app_idx), "expected application to be passed by index"
    txnas Applications
    frame_dig -2
    ==
    assert // expected application to be passed by index
    // a/contract.py:116
    // acc_idx = op.btoi(Txn.application_args(3))
    txna ApplicationArgs 3
    btoi
    // a/contract.py:117
    // assert acc == Txn.accounts(acc_idx), "expected account to be passed by index"
    txnas Accounts
    frame_dig -1
    ==
    assert // expected account to be passed by index
    // a/contract.py:118
    // return asset, app, acc
    frame_dig -3
    frame_dig -2
    frame_dig -1
    retsub


// test_cases.a.contract.SignaturesContract.echo_resource_by_value(asset: uint64, app: uint64, acc: bytes) -> uint64, uint64, bytes:
echo_resource_by_value:
    // a/contract.py:120-125
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    // def echo_resource_by_value(
    //     self, asset: Asset, app: Application, acc: Account
    // ) -> tuple[Asset, Application, Account]:
    proto 3 3
    // a/contract.py:126
    // asset_id = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // a/contract.py:127
    // assert asset.id == asset_id, "expected asset to be passed by value"
    frame_dig -3
    ==
    assert // expected asset to be passed by value
    // a/contract.py:128
    // app_id = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // a/contract.py:129
    // assert app.id == app_id, "expected application to be passed by value"
    frame_dig -2
    ==
    assert // expected application to be passed by value
    // a/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    frame_dig -1
    // a/contract.py:130
    // address = Txn.application_args(3)
    txna ApplicationArgs 3
    // a/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    ==
    assert // expected account to be passed by value
    // a/contract.py:132
    // return asset, app, acc
    frame_dig -3
    frame_dig -2
    frame_dig -1
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0 6 123
    bytecblock 0x0000 0x151f7c75 0x0000000000000001 0x000132
    // tests/artifacts/Arc4ABIMethod/contract.py:25
    // class SignaturesContract(ARC4Contract):
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    bz main_create_NoOp@13
    pushbytess 0xe18922d8 0x3b05cf17 0x0658dcc3 0x5b6447de 0x061f4e77 0xeaa89139 0x510e72a4 0xd6c2ac7f 0x48142d5e // method "sink(string,uint8[])void", method "alias(string,uint8[])void", method "with_txn(string,pay,uint8[])void", method "with_asset(string,asset,uint8[])void", method "with_app(string,application,uint64,uint8[])void", method "with_acc(string,account,uint8[])void", method "complex_sig(((uint64,string),(uint64,string),uint128,uint128),txn,account,uint8[])((uint64,string),((uint64,string),(uint64,string),uint128,uint128))", method "echo_resource_by_index(asset,application,account)(uint64,uint64,address)", method "echo_resource_by_value(uint64,uint64,address)(uint64,uint64,address)"
    txna ApplicationArgs 0
    match sink sink2 with_txn with_asset with_app with_acc complex_sig echo_resource_by_index echo_resource_by_value
    err

main_create_NoOp@13:
    // tests/artifacts/Arc4ABIMethod/contract.py:25
    // class SignaturesContract(ARC4Contract):
    pushbytes 0x4c5c61ba // method "create()void"
    txna ApplicationArgs 0
    match create
    err


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.create[routing]() -> void:
create:
    // tests/artifacts/Arc4ABIMethod/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    // tests/artifacts/Arc4ABIMethod/contract.py:29
    // assert op.Global.current_application_id != 0, "expected global to have app id"
    global CurrentApplicationID
    assert // expected global to have app id
    // tests/artifacts/Arc4ABIMethod/contract.py:31
    // op.Global.current_application_address != op.Global.zero_address
    global CurrentApplicationAddress
    global ZeroAddress
    !=
    // tests/artifacts/Arc4ABIMethod/contract.py:30-32
    // assert (
    //     op.Global.current_application_address != op.Global.zero_address
    // ), "expected global to have app address"
    assert // expected global to have app address
    // tests/artifacts/Arc4ABIMethod/contract.py:28
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // tests/artifacts/Arc4ABIMethod/contract.py:33
    // assert app_txn.app_id == 0, "expected txn to have 0"
    gtxns ApplicationID
    !
    assert // expected txn to have 0
    // tests/artifacts/Arc4ABIMethod/contract.py:34
    // assert Txn.application_id == 0, "expected txn to have 0"
    txn ApplicationID
    !
    // tests/artifacts/Arc4ABIMethod/contract.py:26
    // @arc4.abimethod(create="require")
    return // on error: expected txn to have 0


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.sink[routing]() -> void:
sink:
    // tests/artifacts/Arc4ABIMethod/contract.py:36
    // @arc4.abimethod
    txna ApplicationArgs 2
    txna ApplicationArgs 1
    // tests/artifacts/Arc4ABIMethod/contract.py:38
    // assert value
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:39
    // assert arr
    bytec_0 // 0x0000
    !=
    // tests/artifacts/Arc4ABIMethod/contract.py:36
    // @arc4.abimethod
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.sink2[routing]() -> void:
sink2:
    // tests/artifacts/Arc4ABIMethod/contract.py:41
    // @arc4.abimethod(name="alias")
    txna ApplicationArgs 2
    txna ApplicationArgs 1
    // tests/artifacts/Arc4ABIMethod/contract.py:43
    // assert value
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:44
    // assert arr
    bytec_0 // 0x0000
    !=
    // tests/artifacts/Arc4ABIMethod/contract.py:41
    // @arc4.abimethod(name="alias")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_txn[routing]() -> void:
with_txn:
    // tests/artifacts/Arc4ABIMethod/contract.py:46
    // @arc4.abimethod
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_0 // pay
    ==
    assert // transaction type is pay
    txna ApplicationArgs 2
    // tests/artifacts/Arc4ABIMethod/contract.py:48
    // assert value
    uncover 2
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:49
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:50
    // assert pay.group_index == 0
    dup
    gtxns GroupIndex
    !
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:51
    // assert Txn.group_index == 1
    txn GroupIndex
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:52
    // assert pay.amount == 123
    gtxns Amount
    intc_3 // 123
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:46
    // @arc4.abimethod
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_asset[routing]() -> void:
with_asset:
    // tests/artifacts/Arc4ABIMethod/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Assets
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:56
    // assert value
    uncover 2
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:57
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:58
    // assert asset.total == 123
    dup
    asset_params_get AssetTotal
    assert // asset exists
    intc_3 // 123
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:59
    // assert Txn.assets(0) == asset
    txna Assets 0
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:54
    // @arc4.abimethod(resource_encoding="index")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_app[routing]() -> void:
with_app:
    // tests/artifacts/Arc4ABIMethod/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // tests/artifacts/Arc4ABIMethod/contract.py:65
    // assert value
    uncover 3
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:66
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:67
    // assert app.id == app_id, "expected app id to match provided app id"
    dig 1
    itob
    b==
    assert // expected app id to match provided app id
    // tests/artifacts/Arc4ABIMethod/contract.py:68
    // assert app.creator == op.Global.creator_address, "expected other app to have same creator"
    dup
    app_params_get AppCreator
    assert // application exists
    global CreatorAddress
    ==
    assert // expected other app to have same creator
    // tests/artifacts/Arc4ABIMethod/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    intc_1 // 0
    // tests/artifacts/Arc4ABIMethod/contract.py:70
    // assert app_txn.apps(0) == op.Global.current_application_id
    dup
    gtxnsas Applications
    global CurrentApplicationID
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:71
    // assert Txn.applications(0) == op.Global.current_application_id
    txna Applications 0
    global CurrentApplicationID
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:69
    // app_txn = gtxn.ApplicationCallTransaction(0)
    intc_1 // 0
    // tests/artifacts/Arc4ABIMethod/contract.py:72
    // assert app_txn.apps(1) == app
    intc_0 // 1
    gtxnsas Applications
    dig 1
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:73
    // assert Txn.applications(1) == app
    txna Applications 1
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:61
    // @arc4.abimethod(resource_encoding="index")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.with_acc[routing]() -> void:
with_acc:
    // tests/artifacts/Arc4ABIMethod/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:77
    // assert value
    uncover 2
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:78
    // assert arr
    bytec_0 // 0x0000
    !=
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:79
    // assert acc.balance == acc.min_balance + 1234
    dup
    acct_params_get AcctBalance
    assert // account funded
    dig 1
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:80
    // assert Txn.accounts(0) == Txn.sender
    txna Accounts 0
    txn Sender
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:81
    // assert Txn.accounts(1) == acc
    txna Accounts 1
    ==
    // tests/artifacts/Arc4ABIMethod/contract.py:75
    // @arc4.abimethod(resource_encoding="index")
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.complex_sig[routing]() -> void:
complex_sig:
    // tests/artifacts/Arc4ABIMethod/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    txn GroupIndex
    intc_0 // 1
    -
    txna ApplicationArgs 2
    btoi
    txnas Accounts
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:87
    // assert Txn.num_app_args == 4
    txn NumAppArgs
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:88-89
    // # struct
    // assert struct1.another_struct.one == 1
    dig 3
    intc_1 // 0
    extract_uint16
    dig 4
    pushint 2 // 2
    extract_uint16
    dig 5
    uncover 2
    dig 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:88-90
    // # struct
    // assert struct1.another_struct.one == 1
    // assert struct1.another_struct.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    dig 2
    uncover 2
    dig 2
    substring3
    // tests/artifacts/Arc4ABIMethod/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:91
    // assert struct1.another_struct_alias.one == 1
    dig 6
    len
    dig 7
    uncover 4
    uncover 2
    substring3
    dup
    extract 0 8
    bytec_2 // 0x0000000000000001
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:91-92
    // assert struct1.another_struct_alias.one == 1
    // assert struct1.another_struct_alias.two == "2"
    dup
    pushint 8 // 8
    extract_uint16
    dig 1
    len
    substring3
    // tests/artifacts/Arc4ABIMethod/contract.py:90
    // assert struct1.another_struct.two == "2"
    bytec_3 // 0x000132
    // tests/artifacts/Arc4ABIMethod/contract.py:92
    // assert struct1.another_struct_alias.two == "2"
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:93
    // assert struct1.three == 3
    dig 5
    extract 4 16
    pushbytes 0x00000000000000000000000000000003
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:94
    // assert struct1.four == 4
    dig 5
    extract 20 16
    pushbytes 0x00000000000000000000000000000004
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:96-97
    // # txn
    // assert txn.group_index == Txn.group_index - 1
    uncover 4
    gtxns GroupIndex
    txn GroupIndex
    intc_0 // 1
    -
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:99-100
    // # acc
    // assert Txn.application_args(2) == arc4.UInt8(1).bytes  # acc array ref
    txna ApplicationArgs 2
    pushbytes 0x01
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:101
    // assert acc.balance == acc.min_balance + 1234
    dig 3
    acct_params_get AcctBalance
    assert // account funded
    uncover 4
    acct_params_get AcctMinBalance
    assert // account funded
    pushint 1234 // 1234
    +
    ==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:102
    // assert five[0] == 5
    uncover 2
    extract 2 1
    pushbytes 0x05
    b==
    assert
    // tests/artifacts/Arc4ABIMethod/contract.py:83
    // @arc4.abimethod(resource_encoding="index")
    pushint 4 // 4
    +
    itob
    extract 6 2
    pushbytes 0x0004
    swap
    concat
    swap
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.echo_resource_by_index[routing]() -> void:
echo_resource_by_index:
    // tests/artifacts/Arc4ABIMethod/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    txna ApplicationArgs 1
    btoi
    txnas Assets
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    btoi
    txnas Accounts
    // tests/artifacts/Arc4ABIMethod/contract.py:112
    // asset_idx = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:113
    // assert asset == Txn.assets(asset_idx), "expected asset to be passed by index"
    txnas Assets
    dig 3
    ==
    assert // expected asset to be passed by index
    // tests/artifacts/Arc4ABIMethod/contract.py:114
    // app_idx = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:115
    // assert app == Txn.applications(app_idx), "expected application to be passed by index"
    txnas Applications
    dig 2
    ==
    assert // expected application to be passed by index
    // tests/artifacts/Arc4ABIMethod/contract.py:116
    // acc_idx = op.btoi(Txn.application_args(3))
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:117
    // assert acc == Txn.accounts(acc_idx), "expected account to be passed by index"
    txnas Accounts
    dig 1
    ==
    assert // expected account to be passed by index
    // tests/artifacts/Arc4ABIMethod/contract.py:106-108
    // @arc4.abimethod(
    //     resource_encoding="index",
    // )
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4ABIMethod.contract.SignaturesContract.echo_resource_by_value[routing]() -> void:
echo_resource_by_value:
    // tests/artifacts/Arc4ABIMethod/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:126
    // asset_id = op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:127
    // assert asset.id == asset_id, "expected asset to be passed by value"
    dig 3
    ==
    assert // expected asset to be passed by value
    // tests/artifacts/Arc4ABIMethod/contract.py:128
    // app_id = op.btoi(Txn.application_args(2))
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/Arc4ABIMethod/contract.py:129
    // assert app.id == app_id, "expected application to be passed by value"
    dig 2
    ==
    assert // expected application to be passed by value
    // tests/artifacts/Arc4ABIMethod/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    dup
    // tests/artifacts/Arc4ABIMethod/contract.py:130
    // address = Txn.application_args(3)
    txna ApplicationArgs 3
    // tests/artifacts/Arc4ABIMethod/contract.py:131
    // assert acc.bytes == address, "expected account to be passed by value"
    ==
    assert // expected account to be passed by value
    // tests/artifacts/Arc4ABIMethod/contract.py:120-122
    // @arc4.abimethod(
    //     resource_encoding="value",
    // )
    uncover 2
    itob
    uncover 2
    itob
    concat
    swap
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAEAQAEBiYEAgAABBUffHUIAAAAAAAAAAEDAAEyMRtBAE2CCgRMXGG6BOGJItgEOwXPFwQGWNzDBFtkR94EBh9OdwTqqJE5BFEOcqQE1sKsfwRIFC1eNhoAjgoBEAD+AOwA0AC4AJ0AhQBRACYAAiNDMRkURDEYRDYaARc2GgIXNhoDiAK7TwIWTwIWUExQKUxQsCJDMRkURDEYRDYaARfAMDYaAhfAMjYaAxfAHIgCaE8CFk8CFlBMUClMULAiQzEZFEQxGEQ2GgExFiIJNhoCF8AcNhoDiAGUSwEVJAgWVwYCgAIABExQTwJQTFApTFCwIkMxGRREMRhENhoBNhoCF8AcNhoDiAE4IkMxGRREMRhENhoBNhoCF8AyNhoDNhoEiADbIkMxGRREMRhENhoBNhoCF8AwNhoDiAClIkMxGRREMRhENhoBMRYiCUk4ECISRDYaAogAaCJDMRkURDEYRDYaATYaAogASCJDMRkURDEYRDYaATYaAogAKCJDMRkURDEYFESIAAIiQyM4ECUSRDIIRDIKMgMTRCM4GBREMRgURImKAgCL/igTRIv/KBNEiYoCAIv+KBNEi/8oE0SJigMAi/0oE0SL/ygTRIv+OBYURDEWIhJEi/44CIF7EkSJigMAi/0oE0SL/ygTRIv+cQBEgXsSRDYwAIv+EkSJigQAi/woE0SL/ygTRIv9Fov+qESL/XIHRDIJEkQjOBAlEkQjScIyMggSRDYyADIIEkQjIsIyi/0SRDYyAYv9EkSJigMAi/0oE0SL/ygTRIv+cwBEi/5zAUSB0gkIEkQ2HAAxABJENhwBi/4SRImKBAIxGyQSRIv8I1mL/IECWYv8TwJLAlJJVwAIKqhESYEIWUsBFUsCTgJSKxJEi/wVi/xPA08CUklXAAgqqERJgQhZSwEVUisSRIv8VwQQgBAAAAAAAAAAAAAAAAAAAAADqESL/FcUEIAQAAAAAAAAAAAAAAAAAAAABKhEi/04FjEWIgkSRDYaAoABARJEi/5zAESL/nMBRIHSCQgSRIv/VwIBgAEFqESL/ImKAwM2GgEXwDCL/RJENhoCF8Ayi/4SRDYaAxfAHIv/EkSL/Yv+i/+JigMDNhoBF4v9EkQ2GgIXi/4SRIv/NhoDEkSL/Yv+i/+J", + "approval": "CiAEAQAGeyYEAgAABBUffHUIAAAAAAAAAAEDAAEyMRkURDEYQQBHggkE4Yki2AQ7Bc8XBAZY3MMEW2RH3gQGH053BOqokTkEUQ5ypATWwqx/BEgULV42GgCOCQAnADMAPwBmAIYAzAD7AcoCCQCABExcYbo2GgCOAQABACM4ECQSRDIIRDIKMgMTRCM4GBREMRgUQzYaAjYaASgTRCgTQzYaAjYaASgTRCgTQzYaATEWIglJOBAiEkQ2GgJPAigTRCgTREk4FhREMRYiEkQ4CCUSQzYaATYaAhfAMDYaA08CKBNEKBNESXEARCUSRDYwABJDNhoBNhoCF8AyNhoDNhoETwMoE0QoE0RLARaoRElyB0QyCRJEIzgQJBJEI0nCMjIIEkQ2MgAyCBJEIyLCMksBEkQ2MgESQzYaATYaAhfAHDYaA08CKBNEKBNESXMAREsBcwFEgdIJCBJENhwAMQASRDYcARJDNhoBMRYiCTYaAhfAHDYaAzEbgQQSREsDI1lLBIECWUsFTwJLAlJJVwAIKqhESYEIWUsBFUsCTwJLAlIrEkRLBhVLB08ETwJSSVcACCqoREmBCFlLARVSKxJESwVXBBCAEAAAAAAAAAAAAAAAAAAAAAOoREsFVxQQgBAAAAAAAAAAAAAAAAAAAAAEqERPBDgWMRYiCRJENhoCgAEBEkRLA3MARE8EcwFEgdIJCBJETwJXAgGAAQWoRIEECBZXBgKAAgAETFBMUExQKUxQsCJDNhoBF8AwNhoCF8AyNhoDF8AcNhoBF8AwSwMSRDYaAhfAMksCEkQ2GgMXwBxLARJETwIWTwIWUExQKUxQsCJDNhoBFzYaAhc2GgM2GgEXSwMSRDYaAhdLAhJESTYaAxJETwIWTwIWUExQKUxQsCJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 99, - "minor": 99, - "patch": 99 + "major": 5, + "minor": 0, + "patch": 0 } }, "events": [], diff --git a/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.approval.teal b/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.approval.teal index a68ffac..1436fb7 100644 --- a/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.approval.teal +++ b/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.approval.teal @@ -3,58 +3,40 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 0 1 // tests/artifacts/Arc4InnerTxns/contract.py:4 // class Arc4InnerTxnsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@6 - pushbytes 0xe2353124 // method "opt_in_dummy_asset(asset)void" + bz main___algopy_default_create@5 + pushbytes 0xab39c55a // method "opt_in_dummy_asset(uint64)void" txna ApplicationArgs 0 match main_opt_in_dummy_asset_route@3 - -main_after_if_else@10: - // tests/artifacts/Arc4InnerTxns/contract.py:4 - // class Arc4InnerTxnsContract(ARC4Contract): - intc_0 // 0 - return + err main_opt_in_dummy_asset_route@3: // tests/artifacts/Arc4InnerTxns/contract.py:5 // @arc4.abimethod txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4InnerTxns/contract.py:4 - // class Arc4InnerTxnsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/Arc4InnerTxns/contract.py:5 - // @arc4.abimethod - callsub opt_in_dummy_asset - intc_1 // 1 - return + && + assert // OnCompletion must be NoOp && can only call when not creating + b opt_in_dummy_asset -main_bare_routing@6: - // tests/artifacts/Arc4InnerTxns/contract.py:4 - // class Arc4InnerTxnsContract(ARC4Contract): +main___algopy_default_create@5: txn OnCompletion - bnz main_after_if_else@10 + ! txn ApplicationID ! - assert // can only call when creating - intc_1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.Arc4InnerTxns.contract.Arc4InnerTxnsContract.opt_in_dummy_asset(asset: uint64) -> void: +// tests.artifacts.Arc4InnerTxns.contract.Arc4InnerTxnsContract.opt_in_dummy_asset[routing]() -> void: opt_in_dummy_asset: - // tests/artifacts/Arc4InnerTxns/contract.py:5-6 + // tests/artifacts/Arc4InnerTxns/contract.py:5 // @arc4.abimethod - // def opt_in_dummy_asset(self, asset: Asset) -> None: - proto 1 0 + txna ApplicationArgs 1 + btoi // tests/artifacts/Arc4InnerTxns/contract.py:7-11 // # Submit opt-in transaction: 0 asset transfer to self // itxn.AssetTransfer( @@ -65,15 +47,14 @@ opt_in_dummy_asset: // tests/artifacts/Arc4InnerTxns/contract.py:9 // asset_receiver=Global.current_application_address, global CurrentApplicationAddress - frame_dig -1 - itxn_field XferAsset itxn_field AssetReceiver + itxn_field XferAsset // tests/artifacts/Arc4InnerTxns/contract.py:7-8 // # Submit opt-in transaction: 0 asset transfer to self // itxn.AssetTransfer( pushint 4 // axfer itxn_field TypeEnum - intc_0 // 0 + pushint 0 // 0 itxn_field Fee // tests/artifacts/Arc4InnerTxns/contract.py:7-11 // # Submit opt-in transaction: 0 asset transfer to self @@ -82,4 +63,7 @@ opt_in_dummy_asset: // xfer_asset=asset, // ).submit() itxn_submit - retsub + // tests/artifacts/Arc4InnerTxns/contract.py:5 + // @arc4.abimethod + pushint 1 // 1 + return diff --git a/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc32.json b/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc32.json index 5344fe8..3034e9a 100644 --- a/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc32.json +++ b/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc32.json @@ -1,13 +1,13 @@ { "hints": { - "opt_in_dummy_asset(asset)void": { + "opt_in_dummy_asset(uint64)void": { "call_config": { "no_op": "CALL" } } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAwIDEKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEFyYzRJbm5lclR4bnNDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIHB1c2hieXRlcyAweGUyMzUzMTI0IC8vIG1ldGhvZCAib3B0X2luX2R1bW15X2Fzc2V0KGFzc2V0KXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX29wdF9pbl9kdW1teV9hc3NldF9yb3V0ZUAzCgptYWluX2FmdGVyX2lmX2Vsc2VAMTA6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBBcmM0SW5uZXJUeG5zQ29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIGludGNfMCAvLyAwCiAgICByZXR1cm4KCm1haW5fb3B0X2luX2R1bW15X2Fzc2V0X3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6NAogICAgLy8gY2xhc3MgQXJjNElubmVyVHhuc0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBidG9pCiAgICB0eG5hcyBBc3NldHMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgY2FsbHN1YiBvcHRfaW5fZHVtbXlfYXNzZXQKICAgIGludGNfMSAvLyAxCiAgICByZXR1cm4KCm1haW5fYmFyZV9yb3V0aW5nQDY6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBBcmM0SW5uZXJUeG5zQ29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgIGJueiBtYWluX2FmdGVyX2lmX2Vsc2VAMTAKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCiAgICBpbnRjXzEgLy8gMQogICAgcmV0dXJuCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLkFyYzRJbm5lclR4bnMuY29udHJhY3QuQXJjNElubmVyVHhuc0NvbnRyYWN0Lm9wdF9pbl9kdW1teV9hc3NldChhc3NldDogdWludDY0KSAtPiB2b2lkOgpvcHRfaW5fZHVtbXlfYXNzZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1LTYKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgLy8gZGVmIG9wdF9pbl9kdW1teV9hc3NldChzZWxmLCBhc3NldDogQXNzZXQpIC0+IE5vbmU6CiAgICBwcm90byAxIDAKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjctMTEKICAgIC8vICMgU3VibWl0IG9wdC1pbiB0cmFuc2FjdGlvbjogMCBhc3NldCB0cmFuc2ZlciB0byBzZWxmCiAgICAvLyBpdHhuLkFzc2V0VHJhbnNmZXIoCiAgICAvLyAgICAgYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIC8vICAgICB4ZmVyX2Fzc2V0PWFzc2V0LAogICAgLy8gKS5zdWJtaXQoKQogICAgaXR4bl9iZWdpbgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6OQogICAgLy8gYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIGdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCiAgICBmcmFtZV9kaWcgLTEKICAgIGl0eG5fZmllbGQgWGZlckFzc2V0CiAgICBpdHhuX2ZpZWxkIEFzc2V0UmVjZWl2ZXIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjctOAogICAgLy8gIyBTdWJtaXQgb3B0LWluIHRyYW5zYWN0aW9uOiAwIGFzc2V0IHRyYW5zZmVyIHRvIHNlbGYKICAgIC8vIGl0eG4uQXNzZXRUcmFuc2ZlcigKICAgIHB1c2hpbnQgNCAvLyBheGZlcgogICAgaXR4bl9maWVsZCBUeXBlRW51bQogICAgaW50Y18wIC8vIDAKICAgIGl0eG5fZmllbGQgRmVlCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo3LTExCiAgICAvLyAjIFN1Ym1pdCBvcHQtaW4gdHJhbnNhY3Rpb246IDAgYXNzZXQgdHJhbnNmZXIgdG8gc2VsZgogICAgLy8gaXR4bi5Bc3NldFRyYW5zZmVyKAogICAgLy8gICAgIGFzc2V0X3JlY2VpdmVyPUdsb2JhbC5jdXJyZW50X2FwcGxpY2F0aW9uX2FkZHJlc3MsCiAgICAvLyAgICAgeGZlcl9hc3NldD1hc3NldCwKICAgIC8vICkuc3VibWl0KCkKICAgIGl0eG5fc3VibWl0CiAgICByZXRzdWIK", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEFyYzRJbm5lclR4bnNDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANQogICAgcHVzaGJ5dGVzIDB4YWIzOWM1NWEgLy8gbWV0aG9kICJvcHRfaW5fZHVtbXlfYXNzZXQodWludDY0KXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX29wdF9pbl9kdW1teV9hc3NldF9yb3V0ZUAzCiAgICBlcnIKCm1haW5fb3B0X2luX2R1bW15X2Fzc2V0X3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgYiBvcHRfaW5fZHVtbXlfYXNzZXQKCm1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5BcmM0SW5uZXJUeG5zLmNvbnRyYWN0LkFyYzRJbm5lclR4bnNDb250cmFjdC5vcHRfaW5fZHVtbXlfYXNzZXRbcm91dGluZ10oKSAtPiB2b2lkOgpvcHRfaW5fZHVtbXlfYXNzZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGJ0b2kKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjctMTEKICAgIC8vICMgU3VibWl0IG9wdC1pbiB0cmFuc2FjdGlvbjogMCBhc3NldCB0cmFuc2ZlciB0byBzZWxmCiAgICAvLyBpdHhuLkFzc2V0VHJhbnNmZXIoCiAgICAvLyAgICAgYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIC8vICAgICB4ZmVyX2Fzc2V0PWFzc2V0LAogICAgLy8gKS5zdWJtaXQoKQogICAgaXR4bl9iZWdpbgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6OQogICAgLy8gYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIGdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCiAgICBpdHhuX2ZpZWxkIEFzc2V0UmVjZWl2ZXIKICAgIGl0eG5fZmllbGQgWGZlckFzc2V0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo3LTgKICAgIC8vICMgU3VibWl0IG9wdC1pbiB0cmFuc2FjdGlvbjogMCBhc3NldCB0cmFuc2ZlciB0byBzZWxmCiAgICAvLyBpdHhuLkFzc2V0VHJhbnNmZXIoCiAgICBwdXNoaW50IDQgLy8gYXhmZXIKICAgIGl0eG5fZmllbGQgVHlwZUVudW0KICAgIHB1c2hpbnQgMCAvLyAwCiAgICBpdHhuX2ZpZWxkIEZlZQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6Ny0xMQogICAgLy8gIyBTdWJtaXQgb3B0LWluIHRyYW5zYWN0aW9uOiAwIGFzc2V0IHRyYW5zZmVyIHRvIHNlbGYKICAgIC8vIGl0eG4uQXNzZXRUcmFuc2ZlcigKICAgIC8vICAgICBhc3NldF9yZWNlaXZlcj1HbG9iYWwuY3VycmVudF9hcHBsaWNhdGlvbl9hZGRyZXNzLAogICAgLy8gICAgIHhmZXJfYXNzZXQ9YXNzZXQsCiAgICAvLyApLnN1Ym1pdCgpCiAgICBpdHhuX3N1Ym1pdAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -37,7 +37,7 @@ "name": "opt_in_dummy_asset", "args": [ { - "type": "asset", + "type": "uint64", "name": "asset" } ], diff --git a/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc56.json b/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc56.json index e992385..1e2c9fd 100644 --- a/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc56.json +++ b/tests/artifacts/Arc4InnerTxns/data/Arc4InnerTxnsContract.arc56.json @@ -6,7 +6,7 @@ "name": "opt_in_dummy_asset", "args": [ { - "type": "asset", + "type": "uint64", "name": "asset" } ], @@ -62,21 +62,15 @@ "sourceInfo": [ { "pc": [ - 28 + 37 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 51 + 26 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 31 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when not creating" } ], "pcOffsetMethod": "none" @@ -87,18 +81,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAwIDEKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEFyYzRJbm5lclR4bnNDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIHB1c2hieXRlcyAweGUyMzUzMTI0IC8vIG1ldGhvZCAib3B0X2luX2R1bW15X2Fzc2V0KGFzc2V0KXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX29wdF9pbl9kdW1teV9hc3NldF9yb3V0ZUAzCgptYWluX2FmdGVyX2lmX2Vsc2VAMTA6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBBcmM0SW5uZXJUeG5zQ29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIGludGNfMCAvLyAwCiAgICByZXR1cm4KCm1haW5fb3B0X2luX2R1bW15X2Fzc2V0X3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6NAogICAgLy8gY2xhc3MgQXJjNElubmVyVHhuc0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBidG9pCiAgICB0eG5hcyBBc3NldHMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgY2FsbHN1YiBvcHRfaW5fZHVtbXlfYXNzZXQKICAgIGludGNfMSAvLyAxCiAgICByZXR1cm4KCm1haW5fYmFyZV9yb3V0aW5nQDY6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBBcmM0SW5uZXJUeG5zQ29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgIGJueiBtYWluX2FmdGVyX2lmX2Vsc2VAMTAKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCiAgICBpbnRjXzEgLy8gMQogICAgcmV0dXJuCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLkFyYzRJbm5lclR4bnMuY29udHJhY3QuQXJjNElubmVyVHhuc0NvbnRyYWN0Lm9wdF9pbl9kdW1teV9hc3NldChhc3NldDogdWludDY0KSAtPiB2b2lkOgpvcHRfaW5fZHVtbXlfYXNzZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1LTYKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgLy8gZGVmIG9wdF9pbl9kdW1teV9hc3NldChzZWxmLCBhc3NldDogQXNzZXQpIC0+IE5vbmU6CiAgICBwcm90byAxIDAKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjctMTEKICAgIC8vICMgU3VibWl0IG9wdC1pbiB0cmFuc2FjdGlvbjogMCBhc3NldCB0cmFuc2ZlciB0byBzZWxmCiAgICAvLyBpdHhuLkFzc2V0VHJhbnNmZXIoCiAgICAvLyAgICAgYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIC8vICAgICB4ZmVyX2Fzc2V0PWFzc2V0LAogICAgLy8gKS5zdWJtaXQoKQogICAgaXR4bl9iZWdpbgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6OQogICAgLy8gYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIGdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCiAgICBmcmFtZV9kaWcgLTEKICAgIGl0eG5fZmllbGQgWGZlckFzc2V0CiAgICBpdHhuX2ZpZWxkIEFzc2V0UmVjZWl2ZXIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjctOAogICAgLy8gIyBTdWJtaXQgb3B0LWluIHRyYW5zYWN0aW9uOiAwIGFzc2V0IHRyYW5zZmVyIHRvIHNlbGYKICAgIC8vIGl0eG4uQXNzZXRUcmFuc2ZlcigKICAgIHB1c2hpbnQgNCAvLyBheGZlcgogICAgaXR4bl9maWVsZCBUeXBlRW51bQogICAgaW50Y18wIC8vIDAKICAgIGl0eG5fZmllbGQgRmVlCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo3LTExCiAgICAvLyAjIFN1Ym1pdCBvcHQtaW4gdHJhbnNhY3Rpb246IDAgYXNzZXQgdHJhbnNmZXIgdG8gc2VsZgogICAgLy8gaXR4bi5Bc3NldFRyYW5zZmVyKAogICAgLy8gICAgIGFzc2V0X3JlY2VpdmVyPUdsb2JhbC5jdXJyZW50X2FwcGxpY2F0aW9uX2FkZHJlc3MsCiAgICAvLyAgICAgeGZlcl9hc3NldD1hc3NldCwKICAgIC8vICkuc3VibWl0KCkKICAgIGl0eG5fc3VibWl0CiAgICByZXRzdWIK", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEFyYzRJbm5lclR4bnNDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANQogICAgcHVzaGJ5dGVzIDB4YWIzOWM1NWEgLy8gbWV0aG9kICJvcHRfaW5fZHVtbXlfYXNzZXQodWludDY0KXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX29wdF9pbl9kdW1teV9hc3NldF9yb3V0ZUAzCiAgICBlcnIKCm1haW5fb3B0X2luX2R1bW15X2Fzc2V0X3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgYiBvcHRfaW5fZHVtbXlfYXNzZXQKCm1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5BcmM0SW5uZXJUeG5zLmNvbnRyYWN0LkFyYzRJbm5lclR4bnNDb250cmFjdC5vcHRfaW5fZHVtbXlfYXNzZXRbcm91dGluZ10oKSAtPiB2b2lkOgpvcHRfaW5fZHVtbXlfYXNzZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGJ0b2kKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9BcmM0SW5uZXJUeG5zL2NvbnRyYWN0LnB5OjctMTEKICAgIC8vICMgU3VibWl0IG9wdC1pbiB0cmFuc2FjdGlvbjogMCBhc3NldCB0cmFuc2ZlciB0byBzZWxmCiAgICAvLyBpdHhuLkFzc2V0VHJhbnNmZXIoCiAgICAvLyAgICAgYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIC8vICAgICB4ZmVyX2Fzc2V0PWFzc2V0LAogICAgLy8gKS5zdWJtaXQoKQogICAgaXR4bl9iZWdpbgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6OQogICAgLy8gYXNzZXRfcmVjZWl2ZXI9R2xvYmFsLmN1cnJlbnRfYXBwbGljYXRpb25fYWRkcmVzcywKICAgIGdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCiAgICBpdHhuX2ZpZWxkIEFzc2V0UmVjZWl2ZXIKICAgIGl0eG5fZmllbGQgWGZlckFzc2V0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQXJjNElubmVyVHhucy9jb250cmFjdC5weTo3LTgKICAgIC8vICMgU3VibWl0IG9wdC1pbiB0cmFuc2FjdGlvbjogMCBhc3NldCB0cmFuc2ZlciB0byBzZWxmCiAgICAvLyBpdHhuLkFzc2V0VHJhbnNmZXIoCiAgICBwdXNoaW50IDQgLy8gYXhmZXIKICAgIGl0eG5fZmllbGQgVHlwZUVudW0KICAgIHB1c2hpbnQgMCAvLyAwCiAgICBpdHhuX2ZpZWxkIEZlZQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6Ny0xMQogICAgLy8gIyBTdWJtaXQgb3B0LWluIHRyYW5zYWN0aW9uOiAwIGFzc2V0IHRyYW5zZmVyIHRvIHNlbGYKICAgIC8vIGl0eG4uQXNzZXRUcmFuc2ZlcigKICAgIC8vICAgICBhc3NldF9yZWNlaXZlcj1HbG9iYWwuY3VycmVudF9hcHBsaWNhdGlvbl9hZGRyZXNzLAogICAgLy8gICAgIHhmZXJfYXNzZXQ9YXNzZXQsCiAgICAvLyApLnN1Ym1pdCgpCiAgICBpdHhuX3N1Ym1pdAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0FyYzRJbm5lclR4bnMvY29udHJhY3QucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiACAAExG0EAIYAE4jUxJDYaAI4BAAIiQzEZFEQxGEQ2GgEXwDCIAA0jQzEZQP/nMRgURCNDigEAsTIKi/+yEbIUgQSyECKyAbOJ", + "approval": "CjEbQQAYgASrOcVaNhoAjgEAAQAxGRQxGBBEQgAIMRkUMRgUEEM2GgEXsTIKshSyEYEEshCBALIBs4EBQw==", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/Arc4PrimitiveOps/contract.py b/tests/artifacts/Arc4PrimitiveOps/contract.py index 5f80156..917deac 100644 --- a/tests/artifacts/Arc4PrimitiveOps/contract.py +++ b/tests/artifacts/Arc4PrimitiveOps/contract.py @@ -1,6 +1,6 @@ import typing -from algopy import ARC4Contract, BigUInt, Bytes, String, arc4 +from algopy import ARC4Contract, BigUInt, Bytes, String, UInt64, arc4 class Arc4PrimitiveOpsContract(ARC4Contract): @@ -174,6 +174,26 @@ def verify_uintn_from_log(self, a: Bytes) -> arc4.UInt32: def verify_biguintn_from_log(self, a: Bytes) -> arc4.UInt256: return arc4.UInt256.from_log(a) + @arc4.abimethod() + def verify_biguintn_as_uint64(self, a: Bytes) -> UInt64: + a_biguint = BigUInt.from_bytes(a) + return arc4.UInt256(a_biguint).as_uint64() + + @arc4.abimethod() + def verify_biguintn_as_biguint(self, a: Bytes) -> BigUInt: + a_biguint = BigUInt.from_bytes(a) + return arc4.UInt256(a_biguint).as_biguint() + + @arc4.abimethod() + def verify_uintn64_as_uint64(self, a: Bytes) -> UInt64: + a_biguint = BigUInt.from_bytes(a) + return arc4.UInt64(a_biguint).as_uint64() + + @arc4.abimethod() + def verify_uintn64_as_biguint(self, a: Bytes) -> BigUInt: + a_biguint = BigUInt.from_bytes(a) + return arc4.UInt64(a_biguint).as_biguint() + @arc4.abimethod() def verify_ufixednxm_bytes( self, a: arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]] diff --git a/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.approval.teal b/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.approval.teal index c628f30..f03186b 100644 --- a/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.approval.teal +++ b/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.approval.teal @@ -8,1092 +8,56 @@ main: // tests/artifacts/Arc4PrimitiveOps/contract.py:6 // class Arc4PrimitiveOpsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@51 - pushbytess 0x96f14116 0xed666096 0x2ca0352b 0x85907d40 0x2cbec45b 0x07666fd9 0x370babd3 0x2b6b3ef0 0x339da97c 0x7898ed97 0x1f130cec 0xc748664e 0x7a460cb1 0xdcab1f01 0x97d9064d 0xce06c2a0 0xdcdbcee0 0x77a4b68d 0x4f540626 0x095aed41 0xe3b7e918 0x55337008 0x9bb1cd66 0x81484d9d 0x9a03df10 0xd3f0e44b 0x982db233 0xaffbdf0e 0x288af76e 0x8bd84a04 0x0f1574fe 0xb2cb13be 0xd059eea7 0x4cc4c157 0x3d17ac6e 0xf7f3d5fc 0xf8c8f8d5 0x43f7162a 0x42e09075 0xd956f575 0x6c0160df 0xa890150b 0x0b2f4c3f 0x9db9d327 0xe4d950a1 0xb605e80c // method "verify_uintn_uintn_eq(byte[],byte[])bool", method "verify_biguintn_uintn_eq(byte[],byte[])bool", method "verify_uintn_biguintn_eq(byte[],byte[])bool", method "verify_biguintn_biguintn_eq(byte[],byte[])bool", method "verify_uintn_uintn_ne(byte[],byte[])bool", method "verify_biguintn_uintn_ne(byte[],byte[])bool", method "verify_uintn_biguintn_ne(byte[],byte[])bool", method "verify_biguintn_biguintn_ne(byte[],byte[])bool", method "verify_uintn_uintn_lt(byte[],byte[])bool", method "verify_biguintn_uintn_lt(byte[],byte[])bool", method "verify_uintn_biguintn_lt(byte[],byte[])bool", method "verify_biguintn_biguintn_lt(byte[],byte[])bool", method "verify_uintn_uintn_le(byte[],byte[])bool", method "verify_biguintn_uintn_le(byte[],byte[])bool", method "verify_uintn_biguintn_le(byte[],byte[])bool", method "verify_biguintn_biguintn_le(byte[],byte[])bool", method "verify_uintn_uintn_gt(byte[],byte[])bool", method "verify_biguintn_uintn_gt(byte[],byte[])bool", method "verify_uintn_biguintn_gt(byte[],byte[])bool", method "verify_biguintn_biguintn_gt(byte[],byte[])bool", method "verify_uintn_uintn_ge(byte[],byte[])bool", method "verify_biguintn_uintn_ge(byte[],byte[])bool", method "verify_uintn_biguintn_ge(byte[],byte[])bool", method "verify_biguintn_biguintn_ge(byte[],byte[])bool", method "verify_uintn_init(byte[])uint32", method "verify_biguintn_init(byte[])uint256", method "verify_uintn_from_bytes(byte[])uint32", method "verify_biguintn_from_bytes(byte[])uint256", method "verify_uintn_from_log(byte[])uint32", method "verify_biguintn_from_log(byte[])uint256", method "verify_ufixednxm_bytes(ufixed32x8)byte[]", method "verify_bigufixednxm_bytes(ufixed256x16)byte[]", method "verify_ufixednxm_from_bytes(byte[])ufixed32x8", method "verify_bigufixednxm_from_bytes(byte[])ufixed256x16", method "verify_ufixednxm_from_log(byte[])ufixed32x8", method "verify_bigufixednxm_from_log(byte[])ufixed256x16", method "verify_string_init(string)string", method "verify_string_add(string,string)string", method "verify_string_eq(string,string)bool", method "verify_string_bytes(string)byte[]", method "verify_string_from_bytes(byte[])string", method "verify_string_from_log(byte[])string", method "verify_bool_bytes(bool)byte[]", method "verify_bool_from_bytes(byte[])bool", method "verify_bool_from_log(byte[])bool", method "verify_emit(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,byte[],byte[],byte[])void" - txna ApplicationArgs 0 - match main_verify_uintn_uintn_eq_route@3 main_verify_biguintn_uintn_eq_route@4 main_verify_uintn_biguintn_eq_route@5 main_verify_biguintn_biguintn_eq_route@6 main_verify_uintn_uintn_ne_route@7 main_verify_biguintn_uintn_ne_route@8 main_verify_uintn_biguintn_ne_route@9 main_verify_biguintn_biguintn_ne_route@10 main_verify_uintn_uintn_lt_route@11 main_verify_biguintn_uintn_lt_route@12 main_verify_uintn_biguintn_lt_route@13 main_verify_biguintn_biguintn_lt_route@14 main_verify_uintn_uintn_le_route@15 main_verify_biguintn_uintn_le_route@16 main_verify_uintn_biguintn_le_route@17 main_verify_biguintn_biguintn_le_route@18 main_verify_uintn_uintn_gt_route@19 main_verify_biguintn_uintn_gt_route@20 main_verify_uintn_biguintn_gt_route@21 main_verify_biguintn_biguintn_gt_route@22 main_verify_uintn_uintn_ge_route@23 main_verify_biguintn_uintn_ge_route@24 main_verify_uintn_biguintn_ge_route@25 main_verify_biguintn_biguintn_ge_route@26 main_verify_uintn_init_route@27 main_verify_biguintn_init_route@28 main_verify_uintn_from_bytes_route@29 main_verify_biguintn_from_bytes_route@30 main_verify_uintn_from_log_route@31 main_verify_biguintn_from_log_route@32 main_verify_ufixednxm_bytes_route@33 main_verify_bigufixednxm_bytes_route@34 main_verify_ufixednxm_from_bytes_route@35 main_verify_bigufixednxm_from_bytes_route@36 main_verify_ufixednxm_from_log_route@37 main_verify_bigufixednxm_from_log_route@38 main_verify_string_init_route@39 main_verify_string_add_route@40 main_verify_string_eq_route@41 main_verify_string_bytes_route@42 main_verify_string_from_bytes_route@43 main_verify_string_from_log_route@44 main_verify_bool_bytes_route@45 main_verify_bool_from_bytes_route@46 main_verify_bool_from_log_route@47 main_verify_emit_route@48 - -main_after_if_else@55: - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - intc_3 // 0 - return - -main_verify_emit_route@48: - // tests/artifacts/Arc4PrimitiveOps/contract.py:252 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - txna ApplicationArgs 3 - txna ApplicationArgs 4 - txna ApplicationArgs 5 - txna ApplicationArgs 6 - txna ApplicationArgs 7 - txna ApplicationArgs 8 - txna ApplicationArgs 9 - txna ApplicationArgs 10 - txna ApplicationArgs 11 - txna ApplicationArgs 12 - txna ApplicationArgs 13 - txna ApplicationArgs 14 - extract 2 0 - txna ApplicationArgs 15 - dup - intc_3 // 0 - extract_uint16 - dig 1 - pushint 2 // 2 - extract_uint16 - substring3 - extract 2 0 - txna ApplicationArgs 15 - dup - pushint 2 // 2 - extract_uint16 - dig 1 - len - substring3 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:252 - // @arc4.abimethod() - callsub verify_emit - intc_0 // 1 - return - -main_verify_bool_from_log_route@47: - // tests/artifacts/Arc4PrimitiveOps/contract.py:248 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:248 - // @arc4.abimethod() - callsub verify_bool_from_log - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bool_from_bytes_route@46: - // tests/artifacts/Arc4PrimitiveOps/contract.py:244 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:244 - // @arc4.abimethod() - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bool_bytes_route@45: - // tests/artifacts/Arc4PrimitiveOps/contract.py:240 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:240 - // @arc4.abimethod() - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_from_log_route@44: - // tests/artifacts/Arc4PrimitiveOps/contract.py:236 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:236 - // @arc4.abimethod() - callsub verify_string_from_log - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_from_bytes_route@43: - // tests/artifacts/Arc4PrimitiveOps/contract.py:232 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:232 - // @arc4.abimethod() - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_bytes_route@42: - // tests/artifacts/Arc4PrimitiveOps/contract.py:227 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:227 - // @arc4.abimethod() - callsub verify_string_bytes - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_eq_route@41: - // tests/artifacts/Arc4PrimitiveOps/contract.py:223 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - // tests/artifacts/Arc4PrimitiveOps/contract.py:223 - // @arc4.abimethod() - callsub verify_string_eq - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_add_route@40: - // tests/artifacts/Arc4PrimitiveOps/contract.py:218 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - // tests/artifacts/Arc4PrimitiveOps/contract.py:218 - // @arc4.abimethod - callsub verify_string_add - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_init_route@39: - // tests/artifacts/Arc4PrimitiveOps/contract.py:213 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:213 - // @arc4.abimethod - callsub verify_string_init - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bigufixednxm_from_log_route@38: - // tests/artifacts/Arc4PrimitiveOps/contract.py:207 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:207 - // @arc4.abimethod() - callsub verify_bigufixednxm_from_log - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_ufixednxm_from_log_route@37: - // tests/artifacts/Arc4PrimitiveOps/contract.py:201 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:201 - // @arc4.abimethod() - callsub verify_ufixednxm_from_log - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bigufixednxm_from_bytes_route@36: - // tests/artifacts/Arc4PrimitiveOps/contract.py:195 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:195 - // @arc4.abimethod() - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_ufixednxm_from_bytes_route@35: - // tests/artifacts/Arc4PrimitiveOps/contract.py:189 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:189 - // @arc4.abimethod() - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bigufixednxm_bytes_route@34: - // tests/artifacts/Arc4PrimitiveOps/contract.py:183 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:183 - // @arc4.abimethod() - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_ufixednxm_bytes_route@33: - // tests/artifacts/Arc4PrimitiveOps/contract.py:177 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:177 - // @arc4.abimethod() - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_from_log_route@32: - // tests/artifacts/Arc4PrimitiveOps/contract.py:173 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:173 - // @arc4.abimethod() - callsub verify_biguintn_from_log - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_from_log_route@31: - // tests/artifacts/Arc4PrimitiveOps/contract.py:169 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:169 - // @arc4.abimethod() - callsub verify_uintn_from_log - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_from_bytes_route@30: - // tests/artifacts/Arc4PrimitiveOps/contract.py:165 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:165 - // @arc4.abimethod() - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_from_bytes_route@29: - // tests/artifacts/Arc4PrimitiveOps/contract.py:161 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:161 - // @arc4.abimethod() - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_init_route@28: - // tests/artifacts/Arc4PrimitiveOps/contract.py:156 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:156 - // @arc4.abimethod() - callsub verify_biguintn_init - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_init_route@27: - // tests/artifacts/Arc4PrimitiveOps/contract.py:151 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:151 - // @arc4.abimethod() - callsub verify_uintn_init - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_biguintn_ge_route@26: - // tests/artifacts/Arc4PrimitiveOps/contract.py:145 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:145 - // @arc4.abimethod() - callsub verify_biguintn_biguintn_ge - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_biguintn_ge_route@25: - // tests/artifacts/Arc4PrimitiveOps/contract.py:139 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:139 - // @arc4.abimethod() - callsub verify_uintn_biguintn_ge - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_uintn_ge_route@24: - // tests/artifacts/Arc4PrimitiveOps/contract.py:133 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:133 - // @arc4.abimethod() - callsub verify_biguintn_uintn_ge - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_uintn_ge_route@23: - // tests/artifacts/Arc4PrimitiveOps/contract.py:127 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:127 - // @arc4.abimethod() - callsub verify_uintn_uintn_ge - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_biguintn_gt_route@22: - // tests/artifacts/Arc4PrimitiveOps/contract.py:121 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:121 - // @arc4.abimethod() - callsub verify_biguintn_biguintn_gt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_biguintn_gt_route@21: - // tests/artifacts/Arc4PrimitiveOps/contract.py:115 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:115 - // @arc4.abimethod() - callsub verify_uintn_biguintn_gt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_uintn_gt_route@20: - // tests/artifacts/Arc4PrimitiveOps/contract.py:109 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:109 - // @arc4.abimethod() - callsub verify_biguintn_uintn_gt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_uintn_gt_route@19: - // tests/artifacts/Arc4PrimitiveOps/contract.py:103 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:103 - // @arc4.abimethod() - callsub verify_uintn_uintn_gt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_biguintn_le_route@18: - // tests/artifacts/Arc4PrimitiveOps/contract.py:97 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:97 - // @arc4.abimethod() - callsub verify_biguintn_biguintn_le - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_biguintn_le_route@17: - // tests/artifacts/Arc4PrimitiveOps/contract.py:91 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:91 - // @arc4.abimethod() - callsub verify_uintn_biguintn_le - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_uintn_le_route@16: - // tests/artifacts/Arc4PrimitiveOps/contract.py:85 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:85 - // @arc4.abimethod() - callsub verify_biguintn_uintn_le - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_uintn_le_route@15: - // tests/artifacts/Arc4PrimitiveOps/contract.py:79 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:79 - // @arc4.abimethod() - callsub verify_uintn_uintn_le - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_biguintn_lt_route@14: - // tests/artifacts/Arc4PrimitiveOps/contract.py:73 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:73 - // @arc4.abimethod() - callsub verify_biguintn_biguintn_lt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_biguintn_lt_route@13: - // tests/artifacts/Arc4PrimitiveOps/contract.py:67 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:67 - // @arc4.abimethod() - callsub verify_uintn_biguintn_lt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_uintn_lt_route@12: - // tests/artifacts/Arc4PrimitiveOps/contract.py:61 - // @arc4.abimethod() + bz main___algopy_default_create@57 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:61 - // @arc4.abimethod() - callsub verify_biguintn_uintn_lt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + assert + pushbytess 0x96f14116 0xed666096 0x2ca0352b 0x85907d40 0x2cbec45b 0x07666fd9 0x370babd3 0x2b6b3ef0 0x339da97c 0x7898ed97 0x1f130cec 0xc748664e 0x7a460cb1 0xdcab1f01 0x97d9064d 0xce06c2a0 0xdcdbcee0 0x77a4b68d 0x4f540626 0x095aed41 0xe3b7e918 0x55337008 0x9bb1cd66 0x81484d9d 0x9a03df10 0xd3f0e44b 0x982db233 0xaffbdf0e 0x288af76e 0x8bd84a04 0x302b8a0a 0x337ae20b 0x6e259270 0x79e35f77 0x0f1574fe 0xb2cb13be 0xd059eea7 0x4cc4c157 0x3d17ac6e 0xf7f3d5fc 0xf8c8f8d5 0x43f7162a 0x42e09075 0xd956f575 0x6c0160df 0xa890150b 0x0b2f4c3f 0x9db9d327 0xe4d950a1 0xb605e80c // method "verify_uintn_uintn_eq(byte[],byte[])bool", method "verify_biguintn_uintn_eq(byte[],byte[])bool", method "verify_uintn_biguintn_eq(byte[],byte[])bool", method "verify_biguintn_biguintn_eq(byte[],byte[])bool", method "verify_uintn_uintn_ne(byte[],byte[])bool", method "verify_biguintn_uintn_ne(byte[],byte[])bool", method "verify_uintn_biguintn_ne(byte[],byte[])bool", method "verify_biguintn_biguintn_ne(byte[],byte[])bool", method "verify_uintn_uintn_lt(byte[],byte[])bool", method "verify_biguintn_uintn_lt(byte[],byte[])bool", method "verify_uintn_biguintn_lt(byte[],byte[])bool", method "verify_biguintn_biguintn_lt(byte[],byte[])bool", method "verify_uintn_uintn_le(byte[],byte[])bool", method "verify_biguintn_uintn_le(byte[],byte[])bool", method "verify_uintn_biguintn_le(byte[],byte[])bool", method "verify_biguintn_biguintn_le(byte[],byte[])bool", method "verify_uintn_uintn_gt(byte[],byte[])bool", method "verify_biguintn_uintn_gt(byte[],byte[])bool", method "verify_uintn_biguintn_gt(byte[],byte[])bool", method "verify_biguintn_biguintn_gt(byte[],byte[])bool", method "verify_uintn_uintn_ge(byte[],byte[])bool", method "verify_biguintn_uintn_ge(byte[],byte[])bool", method "verify_uintn_biguintn_ge(byte[],byte[])bool", method "verify_biguintn_biguintn_ge(byte[],byte[])bool", method "verify_uintn_init(byte[])uint32", method "verify_biguintn_init(byte[])uint256", method "verify_uintn_from_bytes(byte[])uint32", method "verify_biguintn_from_bytes(byte[])uint256", method "verify_uintn_from_log(byte[])uint32", method "verify_biguintn_from_log(byte[])uint256", method "verify_biguintn_as_uint64(byte[])uint64", method "verify_biguintn_as_biguint(byte[])uint512", method "verify_uintn64_as_uint64(byte[])uint64", method "verify_uintn64_as_biguint(byte[])uint512", method "verify_ufixednxm_bytes(ufixed32x8)byte[]", method "verify_bigufixednxm_bytes(ufixed256x16)byte[]", method "verify_ufixednxm_from_bytes(byte[])ufixed32x8", method "verify_bigufixednxm_from_bytes(byte[])ufixed256x16", method "verify_ufixednxm_from_log(byte[])ufixed32x8", method "verify_bigufixednxm_from_log(byte[])ufixed256x16", method "verify_string_init(string)string", method "verify_string_add(string,string)string", method "verify_string_eq(string,string)bool", method "verify_string_bytes(string)byte[]", method "verify_string_from_bytes(byte[])string", method "verify_string_from_log(byte[])string", method "verify_bool_bytes(bool)byte[]", method "verify_bool_from_bytes(byte[])bool", method "verify_bool_from_log(byte[])bool", method "verify_emit(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,byte[],byte[],byte[])void" + txna ApplicationArgs 0 + match verify_uintn_uintn_eq verify_biguintn_uintn_eq verify_uintn_biguintn_eq verify_biguintn_biguintn_eq verify_uintn_uintn_ne verify_biguintn_uintn_ne verify_uintn_biguintn_ne verify_biguintn_biguintn_ne verify_uintn_uintn_lt verify_biguintn_uintn_lt verify_uintn_biguintn_lt verify_biguintn_biguintn_lt verify_uintn_uintn_le verify_biguintn_uintn_le verify_uintn_biguintn_le verify_biguintn_biguintn_le verify_uintn_uintn_gt verify_biguintn_uintn_gt verify_uintn_biguintn_gt verify_biguintn_biguintn_gt verify_uintn_uintn_ge verify_biguintn_uintn_ge verify_uintn_biguintn_ge verify_biguintn_biguintn_ge verify_uintn_init verify_biguintn_init verify_uintn_from_bytes verify_biguintn_from_bytes verify_uintn_from_log verify_biguintn_from_log verify_biguintn_as_uint64 verify_biguintn_as_biguint verify_uintn64_as_uint64 verify_uintn64_as_biguint verify_ufixednxm_bytes verify_bigufixednxm_bytes verify_ufixednxm_from_bytes verify_bigufixednxm_from_bytes verify_ufixednxm_from_log verify_bigufixednxm_from_log verify_string_init verify_string_add verify_string_eq verify_string_bytes verify_string_from_bytes verify_string_from_log verify_bool_bytes verify_bool_from_bytes verify_bool_from_log verify_emit + err -main_verify_uintn_uintn_lt_route@11: - // tests/artifacts/Arc4PrimitiveOps/contract.py:55 - // @arc4.abimethod() +main___algopy_default_create@57: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:55 - // @arc4.abimethod() - callsub verify_uintn_uintn_lt - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguintn_biguintn_ne_route@10: - // tests/artifacts/Arc4PrimitiveOps/contract.py:49 - // @arc4.abimethod() - txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:49 - // @arc4.abimethod() - callsub verify_biguintn_biguintn_ne - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_uintn_biguintn_ne_route@9: - // tests/artifacts/Arc4PrimitiveOps/contract.py:43 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:43 - // @arc4.abimethod() - callsub verify_uintn_biguintn_ne - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_biguintn_uintn_ne_route@8: - // tests/artifacts/Arc4PrimitiveOps/contract.py:37 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_eq[routing]() -> void: +verify_uintn_uintn_eq: + // tests/artifacts/Arc4PrimitiveOps/contract.py:7 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:37 - // @arc4.abimethod() - callsub verify_biguintn_uintn_ne - bytec_1 // 0x00 - intc_3 // 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:11 + // return arc4.UInt64(a_biguint) == arc4.UInt64(b_biguint) + dig 1 + len + intc_1 // 8 + <= + assert // overflow + intc_1 // 8 + bzero uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uintn_uintn_ne_route@7: - // tests/artifacts/Arc4PrimitiveOps/contract.py:31 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:31 + dig 1 + b| + dig 2 + len + intc_1 // 8 + <= + assert // overflow + cover 2 + b| + b== + // tests/artifacts/Arc4PrimitiveOps/contract.py:7 // @arc4.abimethod() - callsub verify_uintn_uintn_ne bytec_1 // 0x00 intc_3 // 0 uncover 2 @@ -1105,23 +69,38 @@ main_verify_uintn_uintn_ne_route@7: intc_0 // 1 return -main_verify_biguintn_biguintn_eq_route@6: - // tests/artifacts/Arc4PrimitiveOps/contract.py:25 + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_eq[routing]() -> void: +verify_biguintn_uintn_eq: + // tests/artifacts/Arc4PrimitiveOps/contract.py:13 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:25 + // tests/artifacts/Arc4PrimitiveOps/contract.py:17 + // return arc4.UInt512(a_biguint) == arc4.UInt64(b_biguint) + dig 1 + len + intc_2 // 64 + <= + assert // overflow + intc_2 // 64 + bzero + uncover 2 + b| + dig 1 + len + intc_1 // 8 + <= + assert // overflow + intc_1 // 8 + bzero + uncover 2 + b| + b== + // tests/artifacts/Arc4PrimitiveOps/contract.py:13 // @arc4.abimethod() - callsub verify_biguintn_biguintn_eq bytec_1 // 0x00 intc_3 // 0 uncover 2 @@ -1133,23 +112,38 @@ main_verify_biguintn_biguintn_eq_route@6: intc_0 // 1 return -main_verify_uintn_biguintn_eq_route@5: + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_eq[routing]() -> void: +verify_uintn_biguintn_eq: // tests/artifacts/Arc4PrimitiveOps/contract.py:19 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:23 + // return arc4.UInt64(a_biguint) == arc4.UInt512(b_biguint) + dig 1 + len + intc_1 // 8 + <= + assert // overflow + intc_1 // 8 + bzero + uncover 2 + b| + dig 1 + len + intc_2 // 64 + <= + assert // overflow + intc_2 // 64 + bzero + uncover 2 + b| + b== // tests/artifacts/Arc4PrimitiveOps/contract.py:19 // @arc4.abimethod() - callsub verify_uintn_biguintn_eq bytec_1 // 0x00 intc_3 // 0 uncover 2 @@ -1161,51 +155,37 @@ main_verify_uintn_biguintn_eq_route@5: intc_0 // 1 return -main_verify_biguintn_uintn_eq_route@4: - // tests/artifacts/Arc4PrimitiveOps/contract.py:13 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:13 - // @arc4.abimethod() - callsub verify_biguintn_uintn_eq - bytec_1 // 0x00 - intc_3 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_uintn_uintn_eq_route@3: - // tests/artifacts/Arc4PrimitiveOps/contract.py:7 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_eq[routing]() -> void: +verify_biguintn_biguintn_eq: + // tests/artifacts/Arc4PrimitiveOps/contract.py:25 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 extract 2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:7 + // tests/artifacts/Arc4PrimitiveOps/contract.py:29 + // return arc4.UInt512(a_biguint) == arc4.UInt512(b_biguint) + dig 1 + len + intc_2 // 64 + <= + assert // overflow + intc_2 // 64 + bzero + uncover 2 + dig 1 + b| + dig 2 + len + intc_2 // 64 + <= + assert // overflow + cover 2 + b| + b== + // tests/artifacts/Arc4PrimitiveOps/contract.py:25 // @arc4.abimethod() - callsub verify_uintn_uintn_eq bytec_1 // 0x00 intc_3 // 0 uncover 2 @@ -1217,864 +197,1240 @@ main_verify_uintn_uintn_eq_route@3: intc_0 // 1 return -main_bare_routing@51: - // tests/artifacts/Arc4PrimitiveOps/contract.py:6 - // class Arc4PrimitiveOpsContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@55 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_eq(a: bytes, b: bytes) -> uint64: -verify_uintn_uintn_eq: - // tests/artifacts/Arc4PrimitiveOps/contract.py:7-8 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ne[routing]() -> void: +verify_uintn_uintn_ne: + // tests/artifacts/Arc4PrimitiveOps/contract.py:31 // @arc4.abimethod() - // def verify_uintn_uintn_eq(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:11 - // return arc4.UInt64(a_biguint) == arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:35 + // return arc4.UInt64(a_biguint) != arc4.UInt64(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_1 // 8 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b== - retsub + b!= + // tests/artifacts/Arc4PrimitiveOps/contract.py:31 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_eq(a: bytes, b: bytes) -> uint64: -verify_biguintn_uintn_eq: - // tests/artifacts/Arc4PrimitiveOps/contract.py:13-14 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ne[routing]() -> void: +verify_biguintn_uintn_ne: + // tests/artifacts/Arc4PrimitiveOps/contract.py:37 // @arc4.abimethod() - // def verify_biguintn_uintn_eq(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:17 - // return arc4.UInt512(a_biguint) == arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:41 + // return arc4.UInt512(a_biguint) != arc4.UInt64(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -1 + uncover 2 b| - b== - retsub + b!= + // tests/artifacts/Arc4PrimitiveOps/contract.py:37 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_eq(a: bytes, b: bytes) -> uint64: -verify_uintn_biguintn_eq: - // tests/artifacts/Arc4PrimitiveOps/contract.py:19-20 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ne[routing]() -> void: +verify_uintn_biguintn_ne: + // tests/artifacts/Arc4PrimitiveOps/contract.py:43 // @arc4.abimethod() - // def verify_uintn_biguintn_eq(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:23 - // return arc4.UInt64(a_biguint) == arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:47 + // return arc4.UInt64(a_biguint) != arc4.UInt512(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -1 + uncover 2 b| - b== - retsub + b!= + // tests/artifacts/Arc4PrimitiveOps/contract.py:43 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_eq(a: bytes, b: bytes) -> uint64: -verify_biguintn_biguintn_eq: - // tests/artifacts/Arc4PrimitiveOps/contract.py:25-26 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ne[routing]() -> void: +verify_biguintn_biguintn_ne: + // tests/artifacts/Arc4PrimitiveOps/contract.py:49 // @arc4.abimethod() - // def verify_biguintn_biguintn_eq(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:29 - // return arc4.UInt512(a_biguint) == arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:53 + // return arc4.UInt512(a_biguint) != arc4.UInt512(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_2 // 64 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b== - retsub + b!= + // tests/artifacts/Arc4PrimitiveOps/contract.py:49 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ne(a: bytes, b: bytes) -> uint64: -verify_uintn_uintn_ne: - // tests/artifacts/Arc4PrimitiveOps/contract.py:31-32 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_lt[routing]() -> void: +verify_uintn_uintn_lt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:55 // @arc4.abimethod() - // def verify_uintn_uintn_ne(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:35 - // return arc4.UInt64(a_biguint) != arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:59 + // return arc4.UInt64(a_biguint) < arc4.UInt64(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_1 // 8 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b!= - retsub + b< + // tests/artifacts/Arc4PrimitiveOps/contract.py:55 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ne(a: bytes, b: bytes) -> uint64: -verify_biguintn_uintn_ne: - // tests/artifacts/Arc4PrimitiveOps/contract.py:37-38 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_lt[routing]() -> void: +verify_biguintn_uintn_lt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:61 // @arc4.abimethod() - // def verify_biguintn_uintn_ne(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:41 - // return arc4.UInt512(a_biguint) != arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:65 + // return arc4.UInt512(a_biguint) < arc4.UInt64(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -1 + uncover 2 b| - b!= - retsub + b< + // tests/artifacts/Arc4PrimitiveOps/contract.py:61 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ne(a: bytes, b: bytes) -> uint64: -verify_uintn_biguintn_ne: - // tests/artifacts/Arc4PrimitiveOps/contract.py:43-44 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_lt[routing]() -> void: +verify_uintn_biguintn_lt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:67 // @arc4.abimethod() - // def verify_uintn_biguintn_ne(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:47 - // return arc4.UInt64(a_biguint) != arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:71 + // return arc4.UInt64(a_biguint) < arc4.UInt512(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -1 + uncover 2 b| - b!= - retsub + b< + // tests/artifacts/Arc4PrimitiveOps/contract.py:67 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ne(a: bytes, b: bytes) -> uint64: -verify_biguintn_biguintn_ne: - // tests/artifacts/Arc4PrimitiveOps/contract.py:49-50 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_lt[routing]() -> void: +verify_biguintn_biguintn_lt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:73 // @arc4.abimethod() - // def verify_biguintn_biguintn_ne(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:53 - // return arc4.UInt512(a_biguint) != arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:77 + // return arc4.UInt512(a_biguint) < arc4.UInt512(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_2 // 64 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b!= - retsub + b< + // tests/artifacts/Arc4PrimitiveOps/contract.py:73 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_lt(a: bytes, b: bytes) -> uint64: -verify_uintn_uintn_lt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:55-56 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_le[routing]() -> void: +verify_uintn_uintn_le: + // tests/artifacts/Arc4PrimitiveOps/contract.py:79 // @arc4.abimethod() - // def verify_uintn_uintn_lt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:59 - // return arc4.UInt64(a_biguint) < arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:83 + // return arc4.UInt64(a_biguint) <= arc4.UInt64(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_1 // 8 <= assert // overflow - frame_dig -1 + cover 2 + b| + b<= + // tests/artifacts/Arc4PrimitiveOps/contract.py:79 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 uncover 2 - b| - b< - retsub + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_lt(a: bytes, b: bytes) -> uint64: -verify_biguintn_uintn_lt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:61-62 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_le[routing]() -> void: +verify_biguintn_uintn_le: + // tests/artifacts/Arc4PrimitiveOps/contract.py:85 // @arc4.abimethod() - // def verify_biguintn_uintn_lt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:65 - // return arc4.UInt512(a_biguint) < arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:89 + // return arc4.UInt512(a_biguint) <= arc4.UInt64(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -1 + uncover 2 b| - b< - retsub + b<= + // tests/artifacts/Arc4PrimitiveOps/contract.py:85 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_lt(a: bytes, b: bytes) -> uint64: -verify_uintn_biguintn_lt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:67-68 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_le[routing]() -> void: +verify_uintn_biguintn_le: + // tests/artifacts/Arc4PrimitiveOps/contract.py:91 // @arc4.abimethod() - // def verify_uintn_biguintn_lt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:71 - // return arc4.UInt64(a_biguint) < arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:95 + // return arc4.UInt64(a_biguint) <= arc4.UInt512(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -1 + uncover 2 b| - b< - retsub + b<= + // tests/artifacts/Arc4PrimitiveOps/contract.py:91 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_lt(a: bytes, b: bytes) -> uint64: -verify_biguintn_biguintn_lt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:73-74 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_le[routing]() -> void: +verify_biguintn_biguintn_le: + // tests/artifacts/Arc4PrimitiveOps/contract.py:97 // @arc4.abimethod() - // def verify_biguintn_biguintn_lt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:77 - // return arc4.UInt512(a_biguint) < arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:101 + // return arc4.UInt512(a_biguint) <= arc4.UInt512(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_2 // 64 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b< - retsub + b<= + // tests/artifacts/Arc4PrimitiveOps/contract.py:97 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_le(a: bytes, b: bytes) -> uint64: -verify_uintn_uintn_le: - // tests/artifacts/Arc4PrimitiveOps/contract.py:79-80 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_gt[routing]() -> void: +verify_uintn_uintn_gt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:103 // @arc4.abimethod() - // def verify_uintn_uintn_le(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:83 - // return arc4.UInt64(a_biguint) <= arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:107 + // return arc4.UInt64(a_biguint) > arc4.UInt64(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_1 // 8 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b<= - retsub + b> + // tests/artifacts/Arc4PrimitiveOps/contract.py:103 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_le(a: bytes, b: bytes) -> uint64: -verify_biguintn_uintn_le: - // tests/artifacts/Arc4PrimitiveOps/contract.py:85-86 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_gt[routing]() -> void: +verify_biguintn_uintn_gt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:109 // @arc4.abimethod() - // def verify_biguintn_uintn_le(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:89 - // return arc4.UInt512(a_biguint) <= arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:113 + // return arc4.UInt512(a_biguint) > arc4.UInt64(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -1 + uncover 2 b| - b<= - retsub + b> + // tests/artifacts/Arc4PrimitiveOps/contract.py:109 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_le(a: bytes, b: bytes) -> uint64: -verify_uintn_biguintn_le: - // tests/artifacts/Arc4PrimitiveOps/contract.py:91-92 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_gt[routing]() -> void: +verify_uintn_biguintn_gt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:115 // @arc4.abimethod() - // def verify_uintn_biguintn_le(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:95 - // return arc4.UInt64(a_biguint) <= arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:119 + // return arc4.UInt64(a_biguint) > arc4.UInt512(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -1 + uncover 2 b| - b<= - retsub + b> + // tests/artifacts/Arc4PrimitiveOps/contract.py:115 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_le(a: bytes, b: bytes) -> uint64: -verify_biguintn_biguintn_le: - // tests/artifacts/Arc4PrimitiveOps/contract.py:97-98 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_gt[routing]() -> void: +verify_biguintn_biguintn_gt: + // tests/artifacts/Arc4PrimitiveOps/contract.py:121 // @arc4.abimethod() - // def verify_biguintn_biguintn_le(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:101 - // return arc4.UInt512(a_biguint) <= arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:125 + // return arc4.UInt512(a_biguint) > arc4.UInt512(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_2 // 64 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b<= - retsub + b> + // tests/artifacts/Arc4PrimitiveOps/contract.py:121 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_gt(a: bytes, b: bytes) -> uint64: -verify_uintn_uintn_gt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:103-104 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ge[routing]() -> void: +verify_uintn_uintn_ge: + // tests/artifacts/Arc4PrimitiveOps/contract.py:127 // @arc4.abimethod() - // def verify_uintn_uintn_gt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:107 - // return arc4.UInt64(a_biguint) > arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:131 + // return arc4.UInt64(a_biguint) >= arc4.UInt64(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_1 // 8 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b> - retsub + b>= + // tests/artifacts/Arc4PrimitiveOps/contract.py:127 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_gt(a: bytes, b: bytes) -> uint64: -verify_biguintn_uintn_gt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:109-110 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ge[routing]() -> void: +verify_biguintn_uintn_ge: + // tests/artifacts/Arc4PrimitiveOps/contract.py:133 // @arc4.abimethod() - // def verify_biguintn_uintn_gt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:113 - // return arc4.UInt512(a_biguint) > arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:137 + // return arc4.UInt512(a_biguint) >= arc4.UInt64(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -1 + uncover 2 b| - b> - retsub + b>= + // tests/artifacts/Arc4PrimitiveOps/contract.py:133 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_gt(a: bytes, b: bytes) -> uint64: -verify_uintn_biguintn_gt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:115-116 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ge[routing]() -> void: +verify_uintn_biguintn_ge: + // tests/artifacts/Arc4PrimitiveOps/contract.py:139 // @arc4.abimethod() - // def verify_uintn_biguintn_gt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:119 - // return arc4.UInt64(a_biguint) > arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:143 + // return arc4.UInt64(a_biguint) >= arc4.UInt512(b_biguint) + dig 1 len intc_1 // 8 <= assert // overflow intc_1 // 8 bzero - frame_dig -2 + uncover 2 b| - frame_dig -1 + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -1 + uncover 2 b| - b> - retsub + b>= + // tests/artifacts/Arc4PrimitiveOps/contract.py:139 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_gt(a: bytes, b: bytes) -> uint64: -verify_biguintn_biguintn_gt: - // tests/artifacts/Arc4PrimitiveOps/contract.py:121-122 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ge[routing]() -> void: +verify_biguintn_biguintn_ge: + // tests/artifacts/Arc4PrimitiveOps/contract.py:145 // @arc4.abimethod() - // def verify_biguintn_biguintn_gt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:125 - // return arc4.UInt512(a_biguint) > arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:149 + // return arc4.UInt512(a_biguint) >= arc4.UInt512(b_biguint) + dig 1 len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -2 + uncover 2 dig 1 b| - frame_dig -1 + dig 2 len intc_2 // 64 <= assert // overflow - frame_dig -1 - uncover 2 + cover 2 b| - b> - retsub + b>= + // tests/artifacts/Arc4PrimitiveOps/contract.py:145 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ge(a: bytes, b: bytes) -> uint64: -verify_uintn_uintn_ge: - // tests/artifacts/Arc4PrimitiveOps/contract.py:127-128 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_init[routing]() -> void: +verify_uintn_init: + // tests/artifacts/Arc4PrimitiveOps/contract.py:151 // @arc4.abimethod() - // def verify_uintn_uintn_ge(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:131 - // return arc4.UInt64(a_biguint) >= arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:154 + // return arc4.UInt32(a_biguint) + dup len - intc_1 // 8 + pushint 4 // 4 <= assert // overflow - intc_1 // 8 + pushint 4 // 4 bzero - frame_dig -2 - dig 1 b| - frame_dig -1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:151 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_init[routing]() -> void: +verify_biguintn_init: + // tests/artifacts/Arc4PrimitiveOps/contract.py:156 + // @arc4.abimethod() + txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:159 + // return arc4.UInt256(a_biguint) + dup len - intc_1 // 8 + pushint 32 // 32 <= assert // overflow - frame_dig -1 - uncover 2 + pushint 32 // 32 + bzero b| - b>= - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:156 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ge(a: bytes, b: bytes) -> uint64: -verify_biguintn_uintn_ge: - // tests/artifacts/Arc4PrimitiveOps/contract.py:133-134 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_bytes[routing]() -> void: +verify_uintn_from_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:161 // @arc4.abimethod() - // def verify_biguintn_uintn_ge(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:137 - // return arc4.UInt512(a_biguint) >= arc4.UInt64(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_bytes[routing]() -> void: +verify_biguintn_from_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:165 + // @arc4.abimethod() + txna ApplicationArgs 1 + extract 2 0 + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_log[routing]() -> void: +verify_uintn_from_log: + // tests/artifacts/Arc4PrimitiveOps/contract.py:169 + // @arc4.abimethod() + txna ApplicationArgs 1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:171 + // return arc4.UInt32.from_log(a) + dup + extract 6 0 + swap + extract 2 4 + bytec_0 // 0x151f7c75 + == + assert // application log value is not the result of an ABI return + // tests/artifacts/Arc4PrimitiveOps/contract.py:169 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_log[routing]() -> void: +verify_biguintn_from_log: + // tests/artifacts/Arc4PrimitiveOps/contract.py:173 + // @arc4.abimethod() + txna ApplicationArgs 1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:175 + // return arc4.UInt256.from_log(a) + dup + extract 6 0 + swap + extract 2 4 + bytec_0 // 0x151f7c75 + == + assert // application log value is not the result of an ABI return + // tests/artifacts/Arc4PrimitiveOps/contract.py:173 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_as_uint64[routing]() -> void: +verify_biguintn_as_uint64: + // tests/artifacts/Arc4PrimitiveOps/contract.py:177 + // @arc4.abimethod() + txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:180 + // return arc4.UInt256(a_biguint).as_uint64() + dup len - intc_2 // 64 + pushint 32 // 32 <= assert // overflow - intc_2 // 64 + pushint 32 // 32 bzero - frame_dig -2 b| - frame_dig -1 - len - intc_1 // 8 + dup + bitlen + intc_2 // 64 <= assert // overflow + dup + len intc_1 // 8 - bzero - frame_dig -1 - b| - b>= - retsub + - + intc_1 // 8 + // tests/artifacts/Arc4PrimitiveOps/contract.py:177 + // @arc4.abimethod() + extract3 + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ge(a: bytes, b: bytes) -> uint64: -verify_uintn_biguintn_ge: - // tests/artifacts/Arc4PrimitiveOps/contract.py:139-140 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_as_biguint[routing]() -> void: +verify_biguintn_as_biguint: + // tests/artifacts/Arc4PrimitiveOps/contract.py:182 // @arc4.abimethod() - // def verify_uintn_biguintn_ge(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:143 - // return arc4.UInt64(a_biguint) >= arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:185 + // return arc4.UInt256(a_biguint).as_biguint() + dup len - intc_1 // 8 + pushint 32 // 32 <= assert // overflow - intc_1 // 8 + pushint 32 // 32 bzero - frame_dig -2 b| - frame_dig -1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:182 + // @arc4.abimethod() + dup len intc_2 // 64 <= assert // overflow intc_2 // 64 bzero - frame_dig -1 b| - b>= - retsub + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ge(a: bytes, b: bytes) -> uint64: -verify_biguintn_biguintn_ge: - // tests/artifacts/Arc4PrimitiveOps/contract.py:145-146 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn64_as_uint64[routing]() -> void: +verify_uintn64_as_uint64: + // tests/artifacts/Arc4PrimitiveOps/contract.py:187 // @arc4.abimethod() - // def verify_biguintn_biguintn_ge(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:149 - // return arc4.UInt512(a_biguint) >= arc4.UInt512(b_biguint) - frame_dig -2 + txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:190 + // return arc4.UInt64(a_biguint).as_uint64() + dup + len + intc_1 // 8 + <= + assert // overflow + intc_1 // 8 + bzero + b| + // tests/artifacts/Arc4PrimitiveOps/contract.py:187 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn64_as_biguint[routing]() -> void: +verify_uintn64_as_biguint: + // tests/artifacts/Arc4PrimitiveOps/contract.py:192 + // @arc4.abimethod() + txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:195 + // return arc4.UInt64(a_biguint).as_biguint() + dup len - intc_2 // 64 + intc_1 // 8 <= assert // overflow - intc_2 // 64 + intc_1 // 8 bzero - frame_dig -2 - dig 1 b| - frame_dig -1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:192 + // @arc4.abimethod() + dup len intc_2 // 64 <= assert // overflow - frame_dig -1 - uncover 2 + intc_2 // 64 + bzero b| - b>= - retsub + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_init(a: bytes) -> bytes: -verify_uintn_init: - // tests/artifacts/Arc4PrimitiveOps/contract.py:151-152 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_bytes[routing]() -> void: +verify_ufixednxm_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:197 // @arc4.abimethod() - // def verify_uintn_init(self, a: Bytes) -> arc4.UInt32: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:154 - // return arc4.UInt32(a_biguint) - frame_dig -1 + txna ApplicationArgs 1 + dup len - pushint 4 // 4 - <= - assert // overflow - pushint 4 // 4 - bzero - frame_dig -1 - b| - retsub + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_init(a: bytes) -> bytes: -verify_biguintn_init: - // tests/artifacts/Arc4PrimitiveOps/contract.py:156-157 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_bytes[routing]() -> void: +verify_bigufixednxm_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:203 // @arc4.abimethod() - // def verify_biguintn_init(self, a: Bytes) -> arc4.UInt256: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:159 - // return arc4.UInt256(a_biguint) - frame_dig -1 + txna ApplicationArgs 1 + dup len - pushint 32 // 32 - <= - assert // overflow - pushint 32 // 32 - bzero - frame_dig -1 - b| - retsub + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_log(a: bytes) -> bytes: -verify_uintn_from_log: - // tests/artifacts/Arc4PrimitiveOps/contract.py:169-170 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_bytes[routing]() -> void: +verify_ufixednxm_from_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:209 // @arc4.abimethod() - // def verify_uintn_from_log(self, a: Bytes) -> arc4.UInt32: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:171 - // return arc4.UInt32.from_log(a) - frame_dig -1 - extract 4 0 - frame_dig -1 - extract 0 4 + txna ApplicationArgs 1 + extract 2 0 bytec_0 // 0x151f7c75 - == - assert // application log value is not the result of an ABI return - retsub + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_log(a: bytes) -> bytes: -verify_biguintn_from_log: - // tests/artifacts/Arc4PrimitiveOps/contract.py:173-174 +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_bytes[routing]() -> void: +verify_bigufixednxm_from_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:215 // @arc4.abimethod() - // def verify_biguintn_from_log(self, a: Bytes) -> arc4.UInt256: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:175 - // return arc4.UInt256.from_log(a) - frame_dig -1 - extract 4 0 - frame_dig -1 - extract 0 4 + txna ApplicationArgs 1 + extract 2 0 bytec_0 // 0x151f7c75 - == - assert // application log value is not the result of an ABI return - retsub + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_log(a: bytes) -> bytes: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_log[routing]() -> void: verify_ufixednxm_from_log: - // tests/artifacts/Arc4PrimitiveOps/contract.py:201-204 + // tests/artifacts/Arc4PrimitiveOps/contract.py:221 // @arc4.abimethod() - // def verify_ufixednxm_from_log( - // self, a: Bytes - // ) -> arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]]: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:205 + txna ApplicationArgs 1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:225 // return arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]].from_log(a) - frame_dig -1 - extract 4 0 - frame_dig -1 - extract 0 4 + dup + extract 6 0 + swap + extract 2 4 bytec_0 // 0x151f7c75 == assert // application log value is not the result of an ABI return - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:221 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_log(a: bytes) -> bytes: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_log[routing]() -> void: verify_bigufixednxm_from_log: - // tests/artifacts/Arc4PrimitiveOps/contract.py:207-210 + // tests/artifacts/Arc4PrimitiveOps/contract.py:227 // @arc4.abimethod() - // def verify_bigufixednxm_from_log( - // self, a: Bytes - // ) -> arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]]: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:211 + txna ApplicationArgs 1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:231 // return arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]].from_log(a) - frame_dig -1 - extract 4 0 - frame_dig -1 - extract 0 4 + dup + extract 6 0 + swap + extract 2 4 bytec_0 // 0x151f7c75 == assert // application log value is not the result of an ABI return - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:227 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_init(a: bytes) -> bytes: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_init[routing]() -> void: verify_string_init: - // tests/artifacts/Arc4PrimitiveOps/contract.py:213-214 + // tests/artifacts/Arc4PrimitiveOps/contract.py:233 // @arc4.abimethod - // def verify_string_init(self, a: String) -> arc4.String: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:215 + txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:235 // result = arc4.String(String("Hello, ") + a) pushbytes "Hello, " - frame_dig -1 + swap concat dup len @@ -2082,23 +1438,25 @@ verify_string_init: extract 6 2 swap concat - // tests/artifacts/Arc4PrimitiveOps/contract.py:216 - // return result - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:233 + // @arc4.abimethod + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_add(a: bytes, b: bytes) -> bytes: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_add[routing]() -> void: verify_string_add: - // tests/artifacts/Arc4PrimitiveOps/contract.py:218-219 + // tests/artifacts/Arc4PrimitiveOps/contract.py:238 // @arc4.abimethod - // def verify_string_add(self, a: arc4.String, b: arc4.String) -> arc4.String: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:220 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + // tests/artifacts/Arc4PrimitiveOps/contract.py:240 // result = a + b - frame_dig -1 extract 2 0 - frame_dig -2 - swap concat // on error: max array length exceeded dup extract 2 0 @@ -2106,120 +1464,205 @@ verify_string_add: itob extract 6 2 replace2 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:221 - // return result - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:238 + // @arc4.abimethod + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_eq(a: bytes, b: bytes) -> uint64: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_eq[routing]() -> void: verify_string_eq: - // tests/artifacts/Arc4PrimitiveOps/contract.py:223-224 + // tests/artifacts/Arc4PrimitiveOps/contract.py:243 // @arc4.abimethod() - // def verify_string_eq(self, a: arc4.String, b: arc4.String) -> bool: - proto 2 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:225 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + // tests/artifacts/Arc4PrimitiveOps/contract.py:245 // return a == b - frame_dig -2 - frame_dig -1 == - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:243 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_3 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_bytes(a: bytes) -> bytes: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_bytes[routing]() -> void: verify_string_bytes: - // tests/artifacts/Arc4PrimitiveOps/contract.py:227-228 + // tests/artifacts/Arc4PrimitiveOps/contract.py:247 // @arc4.abimethod() - // def verify_string_bytes(self, a: String) -> Bytes: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:229 - // result = arc4.String(a) - frame_dig -1 + txna ApplicationArgs 1 + dup len itob extract 6 2 - frame_dig -1 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_bytes[routing]() -> void: +verify_string_from_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:252 + // @arc4.abimethod() + txna ApplicationArgs 1 + extract 2 0 + bytec_0 // 0x151f7c75 + swap concat - // tests/artifacts/Arc4PrimitiveOps/contract.py:230 - // return result.bytes - retsub + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_log(a: bytes) -> bytes: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_log[routing]() -> void: verify_string_from_log: - // tests/artifacts/Arc4PrimitiveOps/contract.py:236-237 + // tests/artifacts/Arc4PrimitiveOps/contract.py:256 // @arc4.abimethod() - // def verify_string_from_log(self, a: Bytes) -> arc4.String: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:238 + txna ApplicationArgs 1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:258 // return arc4.String.from_log(a) - frame_dig -1 - extract 4 0 - frame_dig -1 - extract 0 4 + dup + extract 6 0 + swap + extract 2 4 bytec_0 // 0x151f7c75 == assert // application log value is not the result of an ABI return - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:256 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_bytes[routing]() -> void: +verify_bool_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:260 + // @arc4.abimethod() + txna ApplicationArgs 1 + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_bytes[routing]() -> void: +verify_bool_from_bytes: + // tests/artifacts/Arc4PrimitiveOps/contract.py:264 + // @arc4.abimethod() + txna ApplicationArgs 1 + extract 2 0 + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_log(a: bytes) -> bytes: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_log[routing]() -> void: verify_bool_from_log: - // tests/artifacts/Arc4PrimitiveOps/contract.py:248-249 + // tests/artifacts/Arc4PrimitiveOps/contract.py:268 // @arc4.abimethod() - // def verify_bool_from_log(self, a: Bytes) -> arc4.Bool: - proto 1 1 - // tests/artifacts/Arc4PrimitiveOps/contract.py:250 + txna ApplicationArgs 1 + // tests/artifacts/Arc4PrimitiveOps/contract.py:270 // return arc4.Bool.from_log(a) - frame_dig -1 - extract 4 0 - frame_dig -1 - extract 0 4 + dup + extract 6 0 + swap + extract 2 4 bytec_0 // 0x151f7c75 == assert // application log value is not the result of an ABI return - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:268 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_emit(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes, f: bytes, g: bytes, h: bytes, m: bytes, n: bytes, o: bytes, p: bytes, q: bytes, r: bytes, s: bytes, t: bytes) -> void: +// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_emit[routing]() -> void: verify_emit: - // tests/artifacts/Arc4PrimitiveOps/contract.py:252-271 - // @arc4.abimethod() - // def verify_emit( # noqa: PLR0913 - // self, - // a: arc4.String, - // b: arc4.UInt512, - // c: arc4.UInt64, - // d: arc4.DynamicBytes, - // e: arc4.UInt64, - // f: arc4.Bool, - // g: arc4.DynamicBytes, - // h: arc4.String, - // m: arc4.UIntN[typing.Literal[64]], - // n: arc4.BigUIntN[typing.Literal[256]], - // o: arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]], - // p: arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]], - // q: arc4.Bool, - // r: Bytes, - // s: Bytes, - // t: Bytes, - // ) -> None: - proto 16 0 - // tests/artifacts/Arc4PrimitiveOps/contract.py:276 + // tests/artifacts/Arc4PrimitiveOps/contract.py:272 + // @arc4.abimethod() + txna ApplicationArgs 1 + txna ApplicationArgs 2 + txna ApplicationArgs 3 + txna ApplicationArgs 4 + txna ApplicationArgs 5 + txna ApplicationArgs 6 + txna ApplicationArgs 7 + txna ApplicationArgs 8 + txna ApplicationArgs 9 + txna ApplicationArgs 10 + txna ApplicationArgs 11 + txna ApplicationArgs 12 + txna ApplicationArgs 13 + txna ApplicationArgs 14 + extract 2 0 + txna ApplicationArgs 15 + dup + intc_3 // 0 + extract_uint16 + dig 1 + pushint 2 // 2 + extract_uint16 + substring3 + extract 2 0 + txna ApplicationArgs 15 + dup + pushint 2 // 2 + extract_uint16 + dig 1 + len + substring3 + extract 2 0 + // tests/artifacts/Arc4PrimitiveOps/contract.py:296 // arc4.emit(SwappedArc4(m, n, o, p, q, arc4_r, arc4_s, arc4_t)) - frame_dig -8 - frame_dig -7 + dig 7 + dig 7 concat - frame_dig -6 + dig 6 concat - frame_dig -5 + dig 5 concat - frame_dig -4 + dig 4 concat - frame_dig -3 + dig 3 concat pushbytes 0x0054 concat - frame_dig -2 + dig 2 len pushint 84 // 84 dig 1 @@ -2229,15 +1672,15 @@ verify_emit: uncover 2 swap concat - frame_dig -2 + dig 3 concat - frame_dig -1 + dig 2 concat pushbytes 0x66bb0333 // method "SwappedArc4(uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))" swap concat log - // tests/artifacts/Arc4PrimitiveOps/contract.py:277-295 + // tests/artifacts/Arc4PrimitiveOps/contract.py:297-315 // arc4.emit( // "Swapped", // a, @@ -2257,33 +1700,33 @@ verify_emit: // arc4_s.copy(), // arc4_t, // ) - frame_dig -16 + dig 16 len pushint 173 // 173 + pushbytes 0x00ad - frame_dig -15 + uncover 17 concat - frame_dig -14 + uncover 16 concat dig 1 itob extract 6 2 concat - frame_dig -13 + dig 15 len uncover 2 + swap - frame_dig -12 + uncover 14 concat - frame_dig -11 + uncover 13 concat dig 1 itob extract 6 2 concat - frame_dig -10 + dig 12 len uncover 2 + @@ -2293,22 +1736,22 @@ verify_emit: uncover 2 swap concat - frame_dig -9 + dig 11 len uncover 2 + swap - frame_dig -8 + uncover 10 concat - frame_dig -7 + uncover 9 concat - frame_dig -6 + uncover 8 concat - frame_dig -5 + uncover 7 concat - frame_dig -4 + uncover 6 concat - frame_dig -3 + uncover 5 concat dig 1 itob @@ -2320,24 +1763,24 @@ verify_emit: itob extract 6 2 concat - frame_dig -16 + uncover 6 concat - frame_dig -13 + uncover 5 concat - frame_dig -10 + uncover 4 concat - frame_dig -9 + uncover 3 concat - frame_dig -2 + uncover 2 concat - frame_dig -1 + swap concat pushbytes 0xec3319bb // method "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))" swap concat dup log - // tests/artifacts/Arc4PrimitiveOps/contract.py:296-314 + // tests/artifacts/Arc4PrimitiveOps/contract.py:316-334 // arc4.emit( // "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))", // a, @@ -2358,4 +1801,7 @@ verify_emit: // arc4_t, // ) log - retsub + // tests/artifacts/Arc4PrimitiveOps/contract.py:272 + // @arc4.abimethod() + intc_0 // 1 + return diff --git a/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc32.json b/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc32.json index ca4e428..182003e 100644 --- a/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc32.json +++ b/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc32.json @@ -150,6 +150,26 @@ "no_op": "CALL" } }, + "verify_biguintn_as_uint64(byte[])uint64": { + "call_config": { + "no_op": "CALL" + } + }, + "verify_biguintn_as_biguint(byte[])uint512": { + "call_config": { + "no_op": "CALL" + } + }, + "verify_uintn64_as_uint64(byte[])uint64": { + "call_config": { + "no_op": "CALL" + } + }, + "verify_uintn64_as_biguint(byte[])uint512": { + "call_config": { + "no_op": "CALL" + } + }, "verify_ufixednxm_bytes(ufixed32x8)byte[]": { "call_config": { "no_op": "CALL" @@ -232,7 +252,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 8 64 0
    bytecblock 0x151f7c75 0x00
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@51
    pushbytess 0x96f14116 0xed666096 0x2ca0352b 0x85907d40 0x2cbec45b 0x07666fd9 0x370babd3 0x2b6b3ef0 0x339da97c 0x7898ed97 0x1f130cec 0xc748664e 0x7a460cb1 0xdcab1f01 0x97d9064d 0xce06c2a0 0xdcdbcee0 0x77a4b68d 0x4f540626 0x095aed41 0xe3b7e918 0x55337008 0x9bb1cd66 0x81484d9d 0x9a03df10 0xd3f0e44b 0x982db233 0xaffbdf0e 0x288af76e 0x8bd84a04 0x0f1574fe 0xb2cb13be 0xd059eea7 0x4cc4c157 0x3d17ac6e 0xf7f3d5fc 0xf8c8f8d5 0x43f7162a 0x42e09075 0xd956f575 0x6c0160df 0xa890150b 0x0b2f4c3f 0x9db9d327 0xe4d950a1 0xb605e80c // method "verify_uintn_uintn_eq(byte[],byte[])bool", method "verify_biguintn_uintn_eq(byte[],byte[])bool", method "verify_uintn_biguintn_eq(byte[],byte[])bool", method "verify_biguintn_biguintn_eq(byte[],byte[])bool", method "verify_uintn_uintn_ne(byte[],byte[])bool", method "verify_biguintn_uintn_ne(byte[],byte[])bool", method "verify_uintn_biguintn_ne(byte[],byte[])bool", method "verify_biguintn_biguintn_ne(byte[],byte[])bool", method "verify_uintn_uintn_lt(byte[],byte[])bool", method "verify_biguintn_uintn_lt(byte[],byte[])bool", method "verify_uintn_biguintn_lt(byte[],byte[])bool", method "verify_biguintn_biguintn_lt(byte[],byte[])bool", method "verify_uintn_uintn_le(byte[],byte[])bool", method "verify_biguintn_uintn_le(byte[],byte[])bool", method "verify_uintn_biguintn_le(byte[],byte[])bool", method "verify_biguintn_biguintn_le(byte[],byte[])bool", method "verify_uintn_uintn_gt(byte[],byte[])bool", method "verify_biguintn_uintn_gt(byte[],byte[])bool", method "verify_uintn_biguintn_gt(byte[],byte[])bool", method "verify_biguintn_biguintn_gt(byte[],byte[])bool", method "verify_uintn_uintn_ge(byte[],byte[])bool", method "verify_biguintn_uintn_ge(byte[],byte[])bool", method "verify_uintn_biguintn_ge(byte[],byte[])bool", method "verify_biguintn_biguintn_ge(byte[],byte[])bool", method "verify_uintn_init(byte[])uint32", method "verify_biguintn_init(byte[])uint256", method "verify_uintn_from_bytes(byte[])uint32", method "verify_biguintn_from_bytes(byte[])uint256", method "verify_uintn_from_log(byte[])uint32", method "verify_biguintn_from_log(byte[])uint256", method "verify_ufixednxm_bytes(ufixed32x8)byte[]", method "verify_bigufixednxm_bytes(ufixed256x16)byte[]", method "verify_ufixednxm_from_bytes(byte[])ufixed32x8", method "verify_bigufixednxm_from_bytes(byte[])ufixed256x16", method "verify_ufixednxm_from_log(byte[])ufixed32x8", method "verify_bigufixednxm_from_log(byte[])ufixed256x16", method "verify_string_init(string)string", method "verify_string_add(string,string)string", method "verify_string_eq(string,string)bool", method "verify_string_bytes(string)byte[]", method "verify_string_from_bytes(byte[])string", method "verify_string_from_log(byte[])string", method "verify_bool_bytes(bool)byte[]", method "verify_bool_from_bytes(byte[])bool", method "verify_bool_from_log(byte[])bool", method "verify_emit(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match main_verify_uintn_uintn_eq_route@3 main_verify_biguintn_uintn_eq_route@4 main_verify_uintn_biguintn_eq_route@5 main_verify_biguintn_biguintn_eq_route@6 main_verify_uintn_uintn_ne_route@7 main_verify_biguintn_uintn_ne_route@8 main_verify_uintn_biguintn_ne_route@9 main_verify_biguintn_biguintn_ne_route@10 main_verify_uintn_uintn_lt_route@11 main_verify_biguintn_uintn_lt_route@12 main_verify_uintn_biguintn_lt_route@13 main_verify_biguintn_biguintn_lt_route@14 main_verify_uintn_uintn_le_route@15 main_verify_biguintn_uintn_le_route@16 main_verify_uintn_biguintn_le_route@17 main_verify_biguintn_biguintn_le_route@18 main_verify_uintn_uintn_gt_route@19 main_verify_biguintn_uintn_gt_route@20 main_verify_uintn_biguintn_gt_route@21 main_verify_biguintn_biguintn_gt_route@22 main_verify_uintn_uintn_ge_route@23 main_verify_biguintn_uintn_ge_route@24 main_verify_uintn_biguintn_ge_route@25 main_verify_biguintn_biguintn_ge_route@26 main_verify_uintn_init_route@27 main_verify_biguintn_init_route@28 main_verify_uintn_from_bytes_route@29 main_verify_biguintn_from_bytes_route@30 main_verify_uintn_from_log_route@31 main_verify_biguintn_from_log_route@32 main_verify_ufixednxm_bytes_route@33 main_verify_bigufixednxm_bytes_route@34 main_verify_ufixednxm_from_bytes_route@35 main_verify_bigufixednxm_from_bytes_route@36 main_verify_ufixednxm_from_log_route@37 main_verify_bigufixednxm_from_log_route@38 main_verify_string_init_route@39 main_verify_string_add_route@40 main_verify_string_eq_route@41 main_verify_string_bytes_route@42 main_verify_string_from_bytes_route@43 main_verify_string_from_log_route@44 main_verify_bool_bytes_route@45 main_verify_bool_from_bytes_route@46 main_verify_bool_from_log_route@47 main_verify_emit_route@48

main_after_if_else@55:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    intc_3 // 0
    return

main_verify_emit_route@48:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    txna ApplicationArgs 12
    txna ApplicationArgs 13
    txna ApplicationArgs 14
    extract 2 0
    txna ApplicationArgs 15
    dup
    intc_3 // 0
    extract_uint16
    dig 1
    pushint 2 // 2
    extract_uint16
    substring3
    extract 2 0
    txna ApplicationArgs 15
    dup
    pushint 2 // 2
    extract_uint16
    dig 1
    len
    substring3
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252
    // @arc4.abimethod()
    callsub verify_emit
    intc_0 // 1
    return

main_verify_bool_from_log_route@47:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:248
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:248
    // @arc4.abimethod()
    callsub verify_bool_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bool_from_bytes_route@46:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:244
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:244
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bool_bytes_route@45:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_from_log_route@44:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:236
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:236
    // @arc4.abimethod()
    callsub verify_string_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_from_bytes_route@43:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:232
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:232
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_bytes_route@42:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    callsub verify_string_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_eq_route@41:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:223
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:223
    // @arc4.abimethod()
    callsub verify_string_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_add_route@40:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:218
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:218
    // @arc4.abimethod
    callsub verify_string_add
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_init_route@39:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:213
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:213
    // @arc4.abimethod
    callsub verify_string_init
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bigufixednxm_from_log_route@38:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:207
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:207
    // @arc4.abimethod()
    callsub verify_bigufixednxm_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_ufixednxm_from_log_route@37:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    callsub verify_ufixednxm_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bigufixednxm_from_bytes_route@36:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_ufixednxm_from_bytes_route@35:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:189
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:189
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bigufixednxm_bytes_route@34:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:183
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:183
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_ufixednxm_bytes_route@33:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_from_log_route@32:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    callsub verify_biguintn_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_from_log_route@31:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    callsub verify_uintn_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_from_bytes_route@30:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:165
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:165
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_from_bytes_route@29:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:161
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:161
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_init_route@28:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    callsub verify_biguintn_init
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_init_route@27:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    callsub verify_uintn_init
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_ge_route@26:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_ge_route@25:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_ge_route@24:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_ge_route@23:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    callsub verify_uintn_uintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_gt_route@22:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_gt_route@21:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_gt_route@20:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_gt_route@19:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    callsub verify_uintn_uintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_le_route@18:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_le_route@17:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_le_route@16:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_le_route@15:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    callsub verify_uintn_uintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_lt_route@14:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_lt_route@13:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_lt_route@12:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_lt_route@11:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    callsub verify_uintn_uintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_ne_route@10:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_ne_route@9:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_ne_route@8:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_ne_route@7:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    callsub verify_uintn_uintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_eq_route@6:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_eq_route@5:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_eq_route@4:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_eq_route@3:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    callsub verify_uintn_uintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@51:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@55
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_eq(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7-8
    // @arc4.abimethod()
    // def verify_uintn_uintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:11
    // return arc4.UInt64(a_biguint) == arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_eq(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13-14
    // @arc4.abimethod()
    // def verify_biguintn_uintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:17
    // return arc4.UInt512(a_biguint) == arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_eq(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19-20
    // @arc4.abimethod()
    // def verify_uintn_biguintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:23
    // return arc4.UInt64(a_biguint) == arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_eq(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25-26
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:29
    // return arc4.UInt512(a_biguint) == arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ne(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31-32
    // @arc4.abimethod()
    // def verify_uintn_uintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:35
    // return arc4.UInt64(a_biguint) != arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ne(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37-38
    // @arc4.abimethod()
    // def verify_biguintn_uintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:41
    // return arc4.UInt512(a_biguint) != arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ne(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43-44
    // @arc4.abimethod()
    // def verify_uintn_biguintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:47
    // return arc4.UInt64(a_biguint) != arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ne(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49-50
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:53
    // return arc4.UInt512(a_biguint) != arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_lt(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55-56
    // @arc4.abimethod()
    // def verify_uintn_uintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:59
    // return arc4.UInt64(a_biguint) < arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_lt(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61-62
    // @arc4.abimethod()
    // def verify_biguintn_uintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:65
    // return arc4.UInt512(a_biguint) < arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_lt(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67-68
    // @arc4.abimethod()
    // def verify_uintn_biguintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:71
    // return arc4.UInt64(a_biguint) < arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_lt(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73-74
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:77
    // return arc4.UInt512(a_biguint) < arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_le(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79-80
    // @arc4.abimethod()
    // def verify_uintn_uintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:83
    // return arc4.UInt64(a_biguint) <= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_le(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85-86
    // @arc4.abimethod()
    // def verify_biguintn_uintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:89
    // return arc4.UInt512(a_biguint) <= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_le(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91-92
    // @arc4.abimethod()
    // def verify_uintn_biguintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:95
    // return arc4.UInt64(a_biguint) <= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_le(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97-98
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:101
    // return arc4.UInt512(a_biguint) <= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_gt(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103-104
    // @arc4.abimethod()
    // def verify_uintn_uintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:107
    // return arc4.UInt64(a_biguint) > arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_gt(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109-110
    // @arc4.abimethod()
    // def verify_biguintn_uintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:113
    // return arc4.UInt512(a_biguint) > arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_gt(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115-116
    // @arc4.abimethod()
    // def verify_uintn_biguintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:119
    // return arc4.UInt64(a_biguint) > arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_gt(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121-122
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:125
    // return arc4.UInt512(a_biguint) > arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ge(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127-128
    // @arc4.abimethod()
    // def verify_uintn_uintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:131
    // return arc4.UInt64(a_biguint) >= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ge(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133-134
    // @arc4.abimethod()
    // def verify_biguintn_uintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:137
    // return arc4.UInt512(a_biguint) >= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ge(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139-140
    // @arc4.abimethod()
    // def verify_uintn_biguintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:143
    // return arc4.UInt64(a_biguint) >= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ge(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145-146
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:149
    // return arc4.UInt512(a_biguint) >= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_init(a: bytes) -> bytes:
verify_uintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151-152
    // @arc4.abimethod()
    // def verify_uintn_init(self, a: Bytes) -> arc4.UInt32:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:154
    // return arc4.UInt32(a_biguint)
    frame_dig -1
    len
    pushint 4 // 4
    <=
    assert // overflow
    pushint 4 // 4
    bzero
    frame_dig -1
    b|
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_init(a: bytes) -> bytes:
verify_biguintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156-157
    // @arc4.abimethod()
    // def verify_biguintn_init(self, a: Bytes) -> arc4.UInt256:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:159
    // return arc4.UInt256(a_biguint)
    frame_dig -1
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    frame_dig -1
    b|
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_log(a: bytes) -> bytes:
verify_uintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169-170
    // @arc4.abimethod()
    // def verify_uintn_from_log(self, a: Bytes) -> arc4.UInt32:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:171
    // return arc4.UInt32.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_log(a: bytes) -> bytes:
verify_biguintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173-174
    // @arc4.abimethod()
    // def verify_biguintn_from_log(self, a: Bytes) -> arc4.UInt256:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:175
    // return arc4.UInt256.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_log(a: bytes) -> bytes:
verify_ufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:201-204
    // @arc4.abimethod()
    // def verify_ufixednxm_from_log(
    //     self, a: Bytes
    // ) -> arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]]:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:205
    // return arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]].from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_log(a: bytes) -> bytes:
verify_bigufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:207-210
    // @arc4.abimethod()
    // def verify_bigufixednxm_from_log(
    //     self, a: Bytes
    // ) -> arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]]:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:211
    // return arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]].from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_init(a: bytes) -> bytes:
verify_string_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:213-214
    // @arc4.abimethod
    // def verify_string_init(self, a: String) -> arc4.String:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:215
    // result = arc4.String(String("Hello, ") + a)
    pushbytes "Hello, "
    frame_dig -1
    concat
    dup
    len
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arc4PrimitiveOps/contract.py:216
    // return result
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_add(a: bytes, b: bytes) -> bytes:
verify_string_add:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:218-219
    // @arc4.abimethod
    // def verify_string_add(self, a: arc4.String, b: arc4.String) -> arc4.String:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:220
    // result = a + b
    frame_dig -1
    extract 2 0
    frame_dig -2
    swap
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:221
    // return result
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_eq(a: bytes, b: bytes) -> uint64:
verify_string_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:223-224
    // @arc4.abimethod()
    // def verify_string_eq(self, a: arc4.String, b: arc4.String) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:225
    // return a == b
    frame_dig -2
    frame_dig -1
    ==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_bytes(a: bytes) -> bytes:
verify_string_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227-228
    // @arc4.abimethod()
    // def verify_string_bytes(self, a: String) -> Bytes:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:229
    // result = arc4.String(a)
    frame_dig -1
    len
    itob
    extract 6 2
    frame_dig -1
    concat
    // tests/artifacts/Arc4PrimitiveOps/contract.py:230
    // return result.bytes
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_log(a: bytes) -> bytes:
verify_string_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:236-237
    // @arc4.abimethod()
    // def verify_string_from_log(self, a: Bytes) -> arc4.String:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:238
    // return arc4.String.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_log(a: bytes) -> bytes:
verify_bool_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:248-249
    // @arc4.abimethod()
    // def verify_bool_from_log(self, a: Bytes) -> arc4.Bool:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:250
    // return arc4.Bool.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_emit(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes, f: bytes, g: bytes, h: bytes, m: bytes, n: bytes, o: bytes, p: bytes, q: bytes, r: bytes, s: bytes, t: bytes) -> void:
verify_emit:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252-271
    // @arc4.abimethod()
    // def verify_emit(  # noqa: PLR0913
    //     self,
    //     a: arc4.String,
    //     b: arc4.UInt512,
    //     c: arc4.UInt64,
    //     d: arc4.DynamicBytes,
    //     e: arc4.UInt64,
    //     f: arc4.Bool,
    //     g: arc4.DynamicBytes,
    //     h: arc4.String,
    //     m: arc4.UIntN[typing.Literal[64]],
    //     n: arc4.BigUIntN[typing.Literal[256]],
    //     o: arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]],
    //     p: arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]],
    //     q: arc4.Bool,
    //     r: Bytes,
    //     s: Bytes,
    //     t: Bytes,
    // ) -> None:
    proto 16 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:276
    // arc4.emit(SwappedArc4(m, n, o, p, q, arc4_r, arc4_s, arc4_t))
    frame_dig -8
    frame_dig -7
    concat
    frame_dig -6
    concat
    frame_dig -5
    concat
    frame_dig -4
    concat
    frame_dig -3
    concat
    pushbytes 0x0054
    concat
    frame_dig -2
    len
    pushint 84 // 84
    dig 1
    +
    itob
    extract 6 2
    uncover 2
    swap
    concat
    frame_dig -2
    concat
    frame_dig -1
    concat
    pushbytes 0x66bb0333 // method "SwappedArc4(uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:277-295
    // arc4.emit(
    //     "Swapped",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    frame_dig -16
    len
    pushint 173 // 173
    +
    pushbytes 0x00ad
    frame_dig -15
    concat
    frame_dig -14
    concat
    dig 1
    itob
    extract 6 2
    concat
    frame_dig -13
    len
    uncover 2
    +
    swap
    frame_dig -12
    concat
    frame_dig -11
    concat
    dig 1
    itob
    extract 6 2
    concat
    frame_dig -10
    len
    uncover 2
    +
    dup
    itob
    extract 6 2
    uncover 2
    swap
    concat
    frame_dig -9
    len
    uncover 2
    +
    swap
    frame_dig -8
    concat
    frame_dig -7
    concat
    frame_dig -6
    concat
    frame_dig -5
    concat
    frame_dig -4
    concat
    frame_dig -3
    concat
    dig 1
    itob
    extract 6 2
    concat
    swap
    uncover 2
    +
    itob
    extract 6 2
    concat
    frame_dig -16
    concat
    frame_dig -13
    concat
    frame_dig -10
    concat
    frame_dig -9
    concat
    frame_dig -2
    concat
    frame_dig -1
    concat
    pushbytes 0xec3319bb // method "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    dup
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:296-314
    // arc4.emit(
    //     "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    log
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 8 64 0
    bytecblock 0x151f7c75 0x00
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@57
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x96f14116 0xed666096 0x2ca0352b 0x85907d40 0x2cbec45b 0x07666fd9 0x370babd3 0x2b6b3ef0 0x339da97c 0x7898ed97 0x1f130cec 0xc748664e 0x7a460cb1 0xdcab1f01 0x97d9064d 0xce06c2a0 0xdcdbcee0 0x77a4b68d 0x4f540626 0x095aed41 0xe3b7e918 0x55337008 0x9bb1cd66 0x81484d9d 0x9a03df10 0xd3f0e44b 0x982db233 0xaffbdf0e 0x288af76e 0x8bd84a04 0x302b8a0a 0x337ae20b 0x6e259270 0x79e35f77 0x0f1574fe 0xb2cb13be 0xd059eea7 0x4cc4c157 0x3d17ac6e 0xf7f3d5fc 0xf8c8f8d5 0x43f7162a 0x42e09075 0xd956f575 0x6c0160df 0xa890150b 0x0b2f4c3f 0x9db9d327 0xe4d950a1 0xb605e80c // method "verify_uintn_uintn_eq(byte[],byte[])bool", method "verify_biguintn_uintn_eq(byte[],byte[])bool", method "verify_uintn_biguintn_eq(byte[],byte[])bool", method "verify_biguintn_biguintn_eq(byte[],byte[])bool", method "verify_uintn_uintn_ne(byte[],byte[])bool", method "verify_biguintn_uintn_ne(byte[],byte[])bool", method "verify_uintn_biguintn_ne(byte[],byte[])bool", method "verify_biguintn_biguintn_ne(byte[],byte[])bool", method "verify_uintn_uintn_lt(byte[],byte[])bool", method "verify_biguintn_uintn_lt(byte[],byte[])bool", method "verify_uintn_biguintn_lt(byte[],byte[])bool", method "verify_biguintn_biguintn_lt(byte[],byte[])bool", method "verify_uintn_uintn_le(byte[],byte[])bool", method "verify_biguintn_uintn_le(byte[],byte[])bool", method "verify_uintn_biguintn_le(byte[],byte[])bool", method "verify_biguintn_biguintn_le(byte[],byte[])bool", method "verify_uintn_uintn_gt(byte[],byte[])bool", method "verify_biguintn_uintn_gt(byte[],byte[])bool", method "verify_uintn_biguintn_gt(byte[],byte[])bool", method "verify_biguintn_biguintn_gt(byte[],byte[])bool", method "verify_uintn_uintn_ge(byte[],byte[])bool", method "verify_biguintn_uintn_ge(byte[],byte[])bool", method "verify_uintn_biguintn_ge(byte[],byte[])bool", method "verify_biguintn_biguintn_ge(byte[],byte[])bool", method "verify_uintn_init(byte[])uint32", method "verify_biguintn_init(byte[])uint256", method "verify_uintn_from_bytes(byte[])uint32", method "verify_biguintn_from_bytes(byte[])uint256", method "verify_uintn_from_log(byte[])uint32", method "verify_biguintn_from_log(byte[])uint256", method "verify_biguintn_as_uint64(byte[])uint64", method "verify_biguintn_as_biguint(byte[])uint512", method "verify_uintn64_as_uint64(byte[])uint64", method "verify_uintn64_as_biguint(byte[])uint512", method "verify_ufixednxm_bytes(ufixed32x8)byte[]", method "verify_bigufixednxm_bytes(ufixed256x16)byte[]", method "verify_ufixednxm_from_bytes(byte[])ufixed32x8", method "verify_bigufixednxm_from_bytes(byte[])ufixed256x16", method "verify_ufixednxm_from_log(byte[])ufixed32x8", method "verify_bigufixednxm_from_log(byte[])ufixed256x16", method "verify_string_init(string)string", method "verify_string_add(string,string)string", method "verify_string_eq(string,string)bool", method "verify_string_bytes(string)byte[]", method "verify_string_from_bytes(byte[])string", method "verify_string_from_log(byte[])string", method "verify_bool_bytes(bool)byte[]", method "verify_bool_from_bytes(byte[])bool", method "verify_bool_from_log(byte[])bool", method "verify_emit(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match verify_uintn_uintn_eq verify_biguintn_uintn_eq verify_uintn_biguintn_eq verify_biguintn_biguintn_eq verify_uintn_uintn_ne verify_biguintn_uintn_ne verify_uintn_biguintn_ne verify_biguintn_biguintn_ne verify_uintn_uintn_lt verify_biguintn_uintn_lt verify_uintn_biguintn_lt verify_biguintn_biguintn_lt verify_uintn_uintn_le verify_biguintn_uintn_le verify_uintn_biguintn_le verify_biguintn_biguintn_le verify_uintn_uintn_gt verify_biguintn_uintn_gt verify_uintn_biguintn_gt verify_biguintn_biguintn_gt verify_uintn_uintn_ge verify_biguintn_uintn_ge verify_uintn_biguintn_ge verify_biguintn_biguintn_ge verify_uintn_init verify_biguintn_init verify_uintn_from_bytes verify_biguintn_from_bytes verify_uintn_from_log verify_biguintn_from_log verify_biguintn_as_uint64 verify_biguintn_as_biguint verify_uintn64_as_uint64 verify_uintn64_as_biguint verify_ufixednxm_bytes verify_bigufixednxm_bytes verify_ufixednxm_from_bytes verify_bigufixednxm_from_bytes verify_ufixednxm_from_log verify_bigufixednxm_from_log verify_string_init verify_string_add verify_string_eq verify_string_bytes verify_string_from_bytes verify_string_from_log verify_bool_bytes verify_bool_from_bytes verify_bool_from_log verify_emit
    err

main___algopy_default_create@57:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_eq[routing]() -> void:
verify_uintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:11
    // return arc4.UInt64(a_biguint) == arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_eq[routing]() -> void:
verify_biguintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:17
    // return arc4.UInt512(a_biguint) == arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_eq[routing]() -> void:
verify_uintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:23
    // return arc4.UInt64(a_biguint) == arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_eq[routing]() -> void:
verify_biguintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:29
    // return arc4.UInt512(a_biguint) == arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ne[routing]() -> void:
verify_uintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:35
    // return arc4.UInt64(a_biguint) != arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ne[routing]() -> void:
verify_biguintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:41
    // return arc4.UInt512(a_biguint) != arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ne[routing]() -> void:
verify_uintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:47
    // return arc4.UInt64(a_biguint) != arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ne[routing]() -> void:
verify_biguintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:53
    // return arc4.UInt512(a_biguint) != arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_lt[routing]() -> void:
verify_uintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:59
    // return arc4.UInt64(a_biguint) < arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_lt[routing]() -> void:
verify_biguintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:65
    // return arc4.UInt512(a_biguint) < arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_lt[routing]() -> void:
verify_uintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:71
    // return arc4.UInt64(a_biguint) < arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_lt[routing]() -> void:
verify_biguintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:77
    // return arc4.UInt512(a_biguint) < arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_le[routing]() -> void:
verify_uintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:83
    // return arc4.UInt64(a_biguint) <= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_le[routing]() -> void:
verify_biguintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:89
    // return arc4.UInt512(a_biguint) <= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_le[routing]() -> void:
verify_uintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:95
    // return arc4.UInt64(a_biguint) <= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_le[routing]() -> void:
verify_biguintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:101
    // return arc4.UInt512(a_biguint) <= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_gt[routing]() -> void:
verify_uintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:107
    // return arc4.UInt64(a_biguint) > arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_gt[routing]() -> void:
verify_biguintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:113
    // return arc4.UInt512(a_biguint) > arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_gt[routing]() -> void:
verify_uintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:119
    // return arc4.UInt64(a_biguint) > arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_gt[routing]() -> void:
verify_biguintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:125
    // return arc4.UInt512(a_biguint) > arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ge[routing]() -> void:
verify_uintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:131
    // return arc4.UInt64(a_biguint) >= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ge[routing]() -> void:
verify_biguintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:137
    // return arc4.UInt512(a_biguint) >= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ge[routing]() -> void:
verify_uintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:143
    // return arc4.UInt64(a_biguint) >= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ge[routing]() -> void:
verify_biguintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:149
    // return arc4.UInt512(a_biguint) >= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_init[routing]() -> void:
verify_uintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:154
    // return arc4.UInt32(a_biguint)
    dup
    len
    pushint 4 // 4
    <=
    assert // overflow
    pushint 4 // 4
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_init[routing]() -> void:
verify_biguintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:159
    // return arc4.UInt256(a_biguint)
    dup
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_bytes[routing]() -> void:
verify_uintn_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:161
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_bytes[routing]() -> void:
verify_biguintn_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:165
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_log[routing]() -> void:
verify_uintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:171
    // return arc4.UInt32.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_log[routing]() -> void:
verify_biguintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:175
    // return arc4.UInt256.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_as_uint64[routing]() -> void:
verify_biguintn_as_uint64:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:180
    // return arc4.UInt256(a_biguint).as_uint64()
    dup
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    b|
    dup
    bitlen
    intc_2 // 64
    <=
    assert // overflow
    dup
    len
    intc_1 // 8
    -
    intc_1 // 8
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    extract3
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_as_biguint[routing]() -> void:
verify_biguintn_as_biguint:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:185
    // return arc4.UInt256(a_biguint).as_biguint()
    dup
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    dup
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    b|
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn64_as_uint64[routing]() -> void:
verify_uintn64_as_uint64:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:187
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:190
    // return arc4.UInt64(a_biguint).as_uint64()
    dup
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:187
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn64_as_biguint[routing]() -> void:
verify_uintn64_as_biguint:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:192
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:195
    // return arc4.UInt64(a_biguint).as_biguint()
    dup
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:192
    // @arc4.abimethod()
    dup
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    b|
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_bytes[routing]() -> void:
verify_ufixednxm_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:197
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_bytes[routing]() -> void:
verify_bigufixednxm_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:203
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_bytes[routing]() -> void:
verify_ufixednxm_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:209
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_bytes[routing]() -> void:
verify_bigufixednxm_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:215
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_log[routing]() -> void:
verify_ufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:225
    // return arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]].from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_log[routing]() -> void:
verify_bigufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:231
    // return arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]].from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_init[routing]() -> void:
verify_string_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:233
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:235
    // result = arc4.String(String("Hello, ") + a)
    pushbytes "Hello, "
    swap
    concat
    dup
    len
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arc4PrimitiveOps/contract.py:233
    // @arc4.abimethod
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_add[routing]() -> void:
verify_string_add:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:238
    // @arc4.abimethod
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:240
    // result = a + b
    extract 2 0
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:238
    // @arc4.abimethod
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_eq[routing]() -> void:
verify_string_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:243
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:245
    // return a == b
    ==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:243
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_bytes[routing]() -> void:
verify_string_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_bytes[routing]() -> void:
verify_string_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_log[routing]() -> void:
verify_string_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:256
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:258
    // return arc4.String.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:256
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_bytes[routing]() -> void:
verify_bool_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_bytes[routing]() -> void:
verify_bool_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:264
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_log[routing]() -> void:
verify_bool_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:268
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:270
    // return arc4.Bool.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:268
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_emit[routing]() -> void:
verify_emit:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:272
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    txna ApplicationArgs 12
    txna ApplicationArgs 13
    txna ApplicationArgs 14
    extract 2 0
    txna ApplicationArgs 15
    dup
    intc_3 // 0
    extract_uint16
    dig 1
    pushint 2 // 2
    extract_uint16
    substring3
    extract 2 0
    txna ApplicationArgs 15
    dup
    pushint 2 // 2
    extract_uint16
    dig 1
    len
    substring3
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:296
    // arc4.emit(SwappedArc4(m, n, o, p, q, arc4_r, arc4_s, arc4_t))
    dig 7
    dig 7
    concat
    dig 6
    concat
    dig 5
    concat
    dig 4
    concat
    dig 3
    concat
    pushbytes 0x0054
    concat
    dig 2
    len
    pushint 84 // 84
    dig 1
    +
    itob
    extract 6 2
    uncover 2
    swap
    concat
    dig 3
    concat
    dig 2
    concat
    pushbytes 0x66bb0333 // method "SwappedArc4(uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:297-315
    // arc4.emit(
    //     "Swapped",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    dig 16
    len
    pushint 173 // 173
    +
    pushbytes 0x00ad
    uncover 17
    concat
    uncover 16
    concat
    dig 1
    itob
    extract 6 2
    concat
    dig 15
    len
    uncover 2
    +
    swap
    uncover 14
    concat
    uncover 13
    concat
    dig 1
    itob
    extract 6 2
    concat
    dig 12
    len
    uncover 2
    +
    dup
    itob
    extract 6 2
    uncover 2
    swap
    concat
    dig 11
    len
    uncover 2
    +
    swap
    uncover 10
    concat
    uncover 9
    concat
    uncover 8
    concat
    uncover 7
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 1
    itob
    extract 6 2
    concat
    swap
    uncover 2
    +
    itob
    extract 6 2
    concat
    uncover 6
    concat
    uncover 5
    concat
    uncover 4
    concat
    uncover 3
    concat
    uncover 2
    concat
    swap
    concat
    pushbytes 0xec3319bb // method "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    dup
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:316-334
    // arc4.emit(
    //     "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:272
    // @arc4.abimethod()
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -744,6 +764,58 @@ "type": "uint256" } }, + { + "name": "verify_biguintn_as_uint64", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "readonly": false, + "returns": { + "type": "uint64" + } + }, + { + "name": "verify_biguintn_as_biguint", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "readonly": false, + "returns": { + "type": "uint512" + } + }, + { + "name": "verify_uintn64_as_uint64", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "readonly": false, + "returns": { + "type": "uint64" + } + }, + { + "name": "verify_uintn64_as_biguint", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "readonly": false, + "returns": { + "type": "uint512" + } + }, { "name": "verify_ufixednxm_bytes", "args": [ diff --git a/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc56.json b/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc56.json index d07c289..2c29ada 100644 --- a/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc56.json +++ b/tests/artifacts/Arc4PrimitiveOps/data/Arc4PrimitiveOpsContract.arc56.json @@ -728,6 +728,90 @@ "events": [], "recommendations": {} }, + { + "name": "verify_biguintn_as_uint64", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "returns": { + "type": "uint64" + }, + "actions": { + "create": [], + "call": [ + "NoOp" + ] + }, + "readonly": false, + "events": [], + "recommendations": {} + }, + { + "name": "verify_biguintn_as_biguint", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "returns": { + "type": "uint512" + }, + "actions": { + "create": [], + "call": [ + "NoOp" + ] + }, + "readonly": false, + "events": [], + "recommendations": {} + }, + { + "name": "verify_uintn64_as_uint64", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "returns": { + "type": "uint64" + }, + "actions": { + "create": [], + "call": [ + "NoOp" + ] + }, + "readonly": false, + "events": [], + "recommendations": {} + }, + { + "name": "verify_uintn64_as_biguint", + "args": [ + { + "type": "byte[]", + "name": "a" + } + ], + "returns": { + "type": "uint512" + }, + "actions": { + "create": [], + "call": [ + "NoOp" + ] + }, + "readonly": false, + "events": [], + "recommendations": {} + }, { "name": "verify_ufixednxm_bytes", "args": [ @@ -1278,181 +1362,92 @@ "sourceInfo": [ { "pc": [ - 355, - 441, - 463, - 482, - 506, - 528, - 547, - 577, - 604, - 626, - 648, - 670, - 692, - 711, - 730, - 754, - 778, - 800, - 822, - 841, - 860, - 882, - 904, - 937, - 970, - 1003, - 1036, - 1069, - 1102, - 1135, - 1168, - 1201, - 1234, - 1267, - 1300, - 1333, - 1366, - 1399, - 1432, - 1465, - 1498, - 1531, - 1564, - 1597, - 1630, - 1663 - ], - "errorMessage": "OnCompletion is not NoOp" - }, - { - "pc": [ - 2425, - 2442, - 2459, - 2476, - 2564, - 2581 + 24 ], - "errorMessage": "application log value is not the result of an ABI return" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 1701 + 393 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 358, - 444, - 466, - 485, - 509, - 531, - 550, - 580, - 607, - 629, - 651, - 673, - 695, - 714, - 733, - 757, - 781, - 803, - 825, - 844, - 863, - 885, - 907, - 940, - 973, - 1006, - 1039, - 1072, - 1105, - 1138, - 1171, - 1204, - 1237, - 1270, - 1303, - 1336, - 1369, - 1402, - 1435, - 1468, - 1501, - 1534, - 1567, - 1600, - 1633, - 1666 + 1579, + 1599, + 1788, + 1808, + 1933, + 1982 ], - "errorMessage": "can only call when not creating" + "errorMessage": "application log value is not the result of an ABI return" }, { "pc": [ - 2513 + 1855 ], "errorMessage": "max array length exceeded" }, { "pc": [ - 1712, - 1725, - 1741, - 1752, - 1768, - 1779, - 1795, - 1808, - 1824, - 1837, - 1853, - 1864, - 1880, - 1891, - 1907, - 1920, - 1936, - 1949, - 1965, - 1976, - 1992, - 2003, - 2019, - 2032, - 2048, - 2061, - 2077, - 2088, - 2104, - 2115, - 2131, - 2144, - 2160, - 2173, - 2189, - 2200, - 2216, - 2227, - 2243, - 2256, - 2272, - 2285, - 2301, - 2312, - 2328, - 2339, - 2355, - 2368, - 2385, - 2402 + 411, + 424, + 457, + 468, + 503, + 514, + 549, + 562, + 595, + 608, + 641, + 652, + 687, + 698, + 733, + 746, + 779, + 792, + 825, + 836, + 871, + 882, + 917, + 930, + 963, + 976, + 1009, + 1020, + 1055, + 1066, + 1101, + 1114, + 1147, + 1160, + 1193, + 1204, + 1239, + 1250, + 1285, + 1298, + 1331, + 1344, + 1377, + 1388, + 1423, + 1434, + 1469, + 1482, + 1509, + 1531, + 1617, + 1626, + 1650, + 1659, + 1679, + 1699, + 1707 ], "errorMessage": "overflow" } @@ -1465,18 +1460,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 8 64 0
    bytecblock 0x151f7c75 0x00
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@51
    pushbytess 0x96f14116 0xed666096 0x2ca0352b 0x85907d40 0x2cbec45b 0x07666fd9 0x370babd3 0x2b6b3ef0 0x339da97c 0x7898ed97 0x1f130cec 0xc748664e 0x7a460cb1 0xdcab1f01 0x97d9064d 0xce06c2a0 0xdcdbcee0 0x77a4b68d 0x4f540626 0x095aed41 0xe3b7e918 0x55337008 0x9bb1cd66 0x81484d9d 0x9a03df10 0xd3f0e44b 0x982db233 0xaffbdf0e 0x288af76e 0x8bd84a04 0x0f1574fe 0xb2cb13be 0xd059eea7 0x4cc4c157 0x3d17ac6e 0xf7f3d5fc 0xf8c8f8d5 0x43f7162a 0x42e09075 0xd956f575 0x6c0160df 0xa890150b 0x0b2f4c3f 0x9db9d327 0xe4d950a1 0xb605e80c // method "verify_uintn_uintn_eq(byte[],byte[])bool", method "verify_biguintn_uintn_eq(byte[],byte[])bool", method "verify_uintn_biguintn_eq(byte[],byte[])bool", method "verify_biguintn_biguintn_eq(byte[],byte[])bool", method "verify_uintn_uintn_ne(byte[],byte[])bool", method "verify_biguintn_uintn_ne(byte[],byte[])bool", method "verify_uintn_biguintn_ne(byte[],byte[])bool", method "verify_biguintn_biguintn_ne(byte[],byte[])bool", method "verify_uintn_uintn_lt(byte[],byte[])bool", method "verify_biguintn_uintn_lt(byte[],byte[])bool", method "verify_uintn_biguintn_lt(byte[],byte[])bool", method "verify_biguintn_biguintn_lt(byte[],byte[])bool", method "verify_uintn_uintn_le(byte[],byte[])bool", method "verify_biguintn_uintn_le(byte[],byte[])bool", method "verify_uintn_biguintn_le(byte[],byte[])bool", method "verify_biguintn_biguintn_le(byte[],byte[])bool", method "verify_uintn_uintn_gt(byte[],byte[])bool", method "verify_biguintn_uintn_gt(byte[],byte[])bool", method "verify_uintn_biguintn_gt(byte[],byte[])bool", method "verify_biguintn_biguintn_gt(byte[],byte[])bool", method "verify_uintn_uintn_ge(byte[],byte[])bool", method "verify_biguintn_uintn_ge(byte[],byte[])bool", method "verify_uintn_biguintn_ge(byte[],byte[])bool", method "verify_biguintn_biguintn_ge(byte[],byte[])bool", method "verify_uintn_init(byte[])uint32", method "verify_biguintn_init(byte[])uint256", method "verify_uintn_from_bytes(byte[])uint32", method "verify_biguintn_from_bytes(byte[])uint256", method "verify_uintn_from_log(byte[])uint32", method "verify_biguintn_from_log(byte[])uint256", method "verify_ufixednxm_bytes(ufixed32x8)byte[]", method "verify_bigufixednxm_bytes(ufixed256x16)byte[]", method "verify_ufixednxm_from_bytes(byte[])ufixed32x8", method "verify_bigufixednxm_from_bytes(byte[])ufixed256x16", method "verify_ufixednxm_from_log(byte[])ufixed32x8", method "verify_bigufixednxm_from_log(byte[])ufixed256x16", method "verify_string_init(string)string", method "verify_string_add(string,string)string", method "verify_string_eq(string,string)bool", method "verify_string_bytes(string)byte[]", method "verify_string_from_bytes(byte[])string", method "verify_string_from_log(byte[])string", method "verify_bool_bytes(bool)byte[]", method "verify_bool_from_bytes(byte[])bool", method "verify_bool_from_log(byte[])bool", method "verify_emit(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match main_verify_uintn_uintn_eq_route@3 main_verify_biguintn_uintn_eq_route@4 main_verify_uintn_biguintn_eq_route@5 main_verify_biguintn_biguintn_eq_route@6 main_verify_uintn_uintn_ne_route@7 main_verify_biguintn_uintn_ne_route@8 main_verify_uintn_biguintn_ne_route@9 main_verify_biguintn_biguintn_ne_route@10 main_verify_uintn_uintn_lt_route@11 main_verify_biguintn_uintn_lt_route@12 main_verify_uintn_biguintn_lt_route@13 main_verify_biguintn_biguintn_lt_route@14 main_verify_uintn_uintn_le_route@15 main_verify_biguintn_uintn_le_route@16 main_verify_uintn_biguintn_le_route@17 main_verify_biguintn_biguintn_le_route@18 main_verify_uintn_uintn_gt_route@19 main_verify_biguintn_uintn_gt_route@20 main_verify_uintn_biguintn_gt_route@21 main_verify_biguintn_biguintn_gt_route@22 main_verify_uintn_uintn_ge_route@23 main_verify_biguintn_uintn_ge_route@24 main_verify_uintn_biguintn_ge_route@25 main_verify_biguintn_biguintn_ge_route@26 main_verify_uintn_init_route@27 main_verify_biguintn_init_route@28 main_verify_uintn_from_bytes_route@29 main_verify_biguintn_from_bytes_route@30 main_verify_uintn_from_log_route@31 main_verify_biguintn_from_log_route@32 main_verify_ufixednxm_bytes_route@33 main_verify_bigufixednxm_bytes_route@34 main_verify_ufixednxm_from_bytes_route@35 main_verify_bigufixednxm_from_bytes_route@36 main_verify_ufixednxm_from_log_route@37 main_verify_bigufixednxm_from_log_route@38 main_verify_string_init_route@39 main_verify_string_add_route@40 main_verify_string_eq_route@41 main_verify_string_bytes_route@42 main_verify_string_from_bytes_route@43 main_verify_string_from_log_route@44 main_verify_bool_bytes_route@45 main_verify_bool_from_bytes_route@46 main_verify_bool_from_log_route@47 main_verify_emit_route@48

main_after_if_else@55:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    intc_3 // 0
    return

main_verify_emit_route@48:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    txna ApplicationArgs 12
    txna ApplicationArgs 13
    txna ApplicationArgs 14
    extract 2 0
    txna ApplicationArgs 15
    dup
    intc_3 // 0
    extract_uint16
    dig 1
    pushint 2 // 2
    extract_uint16
    substring3
    extract 2 0
    txna ApplicationArgs 15
    dup
    pushint 2 // 2
    extract_uint16
    dig 1
    len
    substring3
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252
    // @arc4.abimethod()
    callsub verify_emit
    intc_0 // 1
    return

main_verify_bool_from_log_route@47:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:248
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:248
    // @arc4.abimethod()
    callsub verify_bool_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bool_from_bytes_route@46:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:244
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:244
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bool_bytes_route@45:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_from_log_route@44:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:236
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:236
    // @arc4.abimethod()
    callsub verify_string_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_from_bytes_route@43:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:232
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:232
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_bytes_route@42:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    callsub verify_string_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_eq_route@41:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:223
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:223
    // @arc4.abimethod()
    callsub verify_string_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_add_route@40:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:218
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:218
    // @arc4.abimethod
    callsub verify_string_add
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_init_route@39:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:213
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:213
    // @arc4.abimethod
    callsub verify_string_init
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bigufixednxm_from_log_route@38:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:207
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:207
    // @arc4.abimethod()
    callsub verify_bigufixednxm_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_ufixednxm_from_log_route@37:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    callsub verify_ufixednxm_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bigufixednxm_from_bytes_route@36:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_ufixednxm_from_bytes_route@35:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:189
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:189
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bigufixednxm_bytes_route@34:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:183
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:183
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_ufixednxm_bytes_route@33:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_from_log_route@32:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    callsub verify_biguintn_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_from_log_route@31:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    callsub verify_uintn_from_log
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_from_bytes_route@30:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:165
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:165
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_from_bytes_route@29:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:161
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:161
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_init_route@28:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    callsub verify_biguintn_init
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_init_route@27:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    callsub verify_uintn_init
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_ge_route@26:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_ge_route@25:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_ge_route@24:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_ge_route@23:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    callsub verify_uintn_uintn_ge
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_gt_route@22:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_gt_route@21:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_gt_route@20:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_gt_route@19:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    callsub verify_uintn_uintn_gt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_le_route@18:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_le_route@17:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_le_route@16:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_le_route@15:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    callsub verify_uintn_uintn_le
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_lt_route@14:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_lt_route@13:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_lt_route@12:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_lt_route@11:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    callsub verify_uintn_uintn_lt
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_ne_route@10:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_ne_route@9:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_ne_route@8:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_ne_route@7:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    callsub verify_uintn_uintn_ne
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_biguintn_eq_route@6:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    callsub verify_biguintn_biguintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_biguintn_eq_route@5:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    callsub verify_uintn_biguintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguintn_uintn_eq_route@4:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    callsub verify_biguintn_uintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uintn_uintn_eq_route@3:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    callsub verify_uintn_uintn_eq
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@51:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@55
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_eq(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7-8
    // @arc4.abimethod()
    // def verify_uintn_uintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:11
    // return arc4.UInt64(a_biguint) == arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_eq(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13-14
    // @arc4.abimethod()
    // def verify_biguintn_uintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:17
    // return arc4.UInt512(a_biguint) == arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_eq(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19-20
    // @arc4.abimethod()
    // def verify_uintn_biguintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:23
    // return arc4.UInt64(a_biguint) == arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_eq(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25-26
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:29
    // return arc4.UInt512(a_biguint) == arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ne(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31-32
    // @arc4.abimethod()
    // def verify_uintn_uintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:35
    // return arc4.UInt64(a_biguint) != arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ne(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37-38
    // @arc4.abimethod()
    // def verify_biguintn_uintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:41
    // return arc4.UInt512(a_biguint) != arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ne(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43-44
    // @arc4.abimethod()
    // def verify_uintn_biguintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:47
    // return arc4.UInt64(a_biguint) != arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ne(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49-50
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:53
    // return arc4.UInt512(a_biguint) != arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b!=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_lt(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55-56
    // @arc4.abimethod()
    // def verify_uintn_uintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:59
    // return arc4.UInt64(a_biguint) < arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_lt(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61-62
    // @arc4.abimethod()
    // def verify_biguintn_uintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:65
    // return arc4.UInt512(a_biguint) < arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_lt(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67-68
    // @arc4.abimethod()
    // def verify_uintn_biguintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:71
    // return arc4.UInt64(a_biguint) < arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_lt(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73-74
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:77
    // return arc4.UInt512(a_biguint) < arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_le(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79-80
    // @arc4.abimethod()
    // def verify_uintn_uintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:83
    // return arc4.UInt64(a_biguint) <= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_le(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85-86
    // @arc4.abimethod()
    // def verify_biguintn_uintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:89
    // return arc4.UInt512(a_biguint) <= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_le(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91-92
    // @arc4.abimethod()
    // def verify_uintn_biguintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:95
    // return arc4.UInt64(a_biguint) <= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_le(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97-98
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:101
    // return arc4.UInt512(a_biguint) <= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b<=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_gt(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103-104
    // @arc4.abimethod()
    // def verify_uintn_uintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:107
    // return arc4.UInt64(a_biguint) > arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_gt(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109-110
    // @arc4.abimethod()
    // def verify_biguintn_uintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:113
    // return arc4.UInt512(a_biguint) > arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_gt(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115-116
    // @arc4.abimethod()
    // def verify_uintn_biguintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:119
    // return arc4.UInt64(a_biguint) > arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_gt(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121-122
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:125
    // return arc4.UInt512(a_biguint) > arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ge(a: bytes, b: bytes) -> uint64:
verify_uintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127-128
    // @arc4.abimethod()
    // def verify_uintn_uintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:131
    // return arc4.UInt64(a_biguint) >= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ge(a: bytes, b: bytes) -> uint64:
verify_biguintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133-134
    // @arc4.abimethod()
    // def verify_biguintn_uintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:137
    // return arc4.UInt512(a_biguint) >= arc4.UInt64(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -1
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ge(a: bytes, b: bytes) -> uint64:
verify_uintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139-140
    // @arc4.abimethod()
    // def verify_uintn_biguintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:143
    // return arc4.UInt64(a_biguint) >= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    frame_dig -2
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -1
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ge(a: bytes, b: bytes) -> uint64:
verify_biguintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145-146
    // @arc4.abimethod()
    // def verify_biguintn_biguintn_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:149
    // return arc4.UInt512(a_biguint) >= arc4.UInt512(b_biguint)
    frame_dig -2
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    frame_dig -2
    dig 1
    b|
    frame_dig -1
    len
    intc_2 // 64
    <=
    assert // overflow
    frame_dig -1
    uncover 2
    b|
    b>=
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_init(a: bytes) -> bytes:
verify_uintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151-152
    // @arc4.abimethod()
    // def verify_uintn_init(self, a: Bytes) -> arc4.UInt32:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:154
    // return arc4.UInt32(a_biguint)
    frame_dig -1
    len
    pushint 4 // 4
    <=
    assert // overflow
    pushint 4 // 4
    bzero
    frame_dig -1
    b|
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_init(a: bytes) -> bytes:
verify_biguintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156-157
    // @arc4.abimethod()
    // def verify_biguintn_init(self, a: Bytes) -> arc4.UInt256:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:159
    // return arc4.UInt256(a_biguint)
    frame_dig -1
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    frame_dig -1
    b|
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_log(a: bytes) -> bytes:
verify_uintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169-170
    // @arc4.abimethod()
    // def verify_uintn_from_log(self, a: Bytes) -> arc4.UInt32:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:171
    // return arc4.UInt32.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_log(a: bytes) -> bytes:
verify_biguintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173-174
    // @arc4.abimethod()
    // def verify_biguintn_from_log(self, a: Bytes) -> arc4.UInt256:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:175
    // return arc4.UInt256.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_log(a: bytes) -> bytes:
verify_ufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:201-204
    // @arc4.abimethod()
    // def verify_ufixednxm_from_log(
    //     self, a: Bytes
    // ) -> arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]]:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:205
    // return arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]].from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_log(a: bytes) -> bytes:
verify_bigufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:207-210
    // @arc4.abimethod()
    // def verify_bigufixednxm_from_log(
    //     self, a: Bytes
    // ) -> arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]]:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:211
    // return arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]].from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_init(a: bytes) -> bytes:
verify_string_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:213-214
    // @arc4.abimethod
    // def verify_string_init(self, a: String) -> arc4.String:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:215
    // result = arc4.String(String("Hello, ") + a)
    pushbytes "Hello, "
    frame_dig -1
    concat
    dup
    len
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arc4PrimitiveOps/contract.py:216
    // return result
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_add(a: bytes, b: bytes) -> bytes:
verify_string_add:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:218-219
    // @arc4.abimethod
    // def verify_string_add(self, a: arc4.String, b: arc4.String) -> arc4.String:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:220
    // result = a + b
    frame_dig -1
    extract 2 0
    frame_dig -2
    swap
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:221
    // return result
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_eq(a: bytes, b: bytes) -> uint64:
verify_string_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:223-224
    // @arc4.abimethod()
    // def verify_string_eq(self, a: arc4.String, b: arc4.String) -> bool:
    proto 2 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:225
    // return a == b
    frame_dig -2
    frame_dig -1
    ==
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_bytes(a: bytes) -> bytes:
verify_string_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227-228
    // @arc4.abimethod()
    // def verify_string_bytes(self, a: String) -> Bytes:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:229
    // result = arc4.String(a)
    frame_dig -1
    len
    itob
    extract 6 2
    frame_dig -1
    concat
    // tests/artifacts/Arc4PrimitiveOps/contract.py:230
    // return result.bytes
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_log(a: bytes) -> bytes:
verify_string_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:236-237
    // @arc4.abimethod()
    // def verify_string_from_log(self, a: Bytes) -> arc4.String:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:238
    // return arc4.String.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_log(a: bytes) -> bytes:
verify_bool_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:248-249
    // @arc4.abimethod()
    // def verify_bool_from_log(self, a: Bytes) -> arc4.Bool:
    proto 1 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:250
    // return arc4.Bool.from_log(a)
    frame_dig -1
    extract 4 0
    frame_dig -1
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    retsub


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_emit(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes, f: bytes, g: bytes, h: bytes, m: bytes, n: bytes, o: bytes, p: bytes, q: bytes, r: bytes, s: bytes, t: bytes) -> void:
verify_emit:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252-271
    // @arc4.abimethod()
    // def verify_emit(  # noqa: PLR0913
    //     self,
    //     a: arc4.String,
    //     b: arc4.UInt512,
    //     c: arc4.UInt64,
    //     d: arc4.DynamicBytes,
    //     e: arc4.UInt64,
    //     f: arc4.Bool,
    //     g: arc4.DynamicBytes,
    //     h: arc4.String,
    //     m: arc4.UIntN[typing.Literal[64]],
    //     n: arc4.BigUIntN[typing.Literal[256]],
    //     o: arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]],
    //     p: arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]],
    //     q: arc4.Bool,
    //     r: Bytes,
    //     s: Bytes,
    //     t: Bytes,
    // ) -> None:
    proto 16 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:276
    // arc4.emit(SwappedArc4(m, n, o, p, q, arc4_r, arc4_s, arc4_t))
    frame_dig -8
    frame_dig -7
    concat
    frame_dig -6
    concat
    frame_dig -5
    concat
    frame_dig -4
    concat
    frame_dig -3
    concat
    pushbytes 0x0054
    concat
    frame_dig -2
    len
    pushint 84 // 84
    dig 1
    +
    itob
    extract 6 2
    uncover 2
    swap
    concat
    frame_dig -2
    concat
    frame_dig -1
    concat
    pushbytes 0x66bb0333 // method "SwappedArc4(uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:277-295
    // arc4.emit(
    //     "Swapped",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    frame_dig -16
    len
    pushint 173 // 173
    +
    pushbytes 0x00ad
    frame_dig -15
    concat
    frame_dig -14
    concat
    dig 1
    itob
    extract 6 2
    concat
    frame_dig -13
    len
    uncover 2
    +
    swap
    frame_dig -12
    concat
    frame_dig -11
    concat
    dig 1
    itob
    extract 6 2
    concat
    frame_dig -10
    len
    uncover 2
    +
    dup
    itob
    extract 6 2
    uncover 2
    swap
    concat
    frame_dig -9
    len
    uncover 2
    +
    swap
    frame_dig -8
    concat
    frame_dig -7
    concat
    frame_dig -6
    concat
    frame_dig -5
    concat
    frame_dig -4
    concat
    frame_dig -3
    concat
    dig 1
    itob
    extract 6 2
    concat
    swap
    uncover 2
    +
    itob
    extract 6 2
    concat
    frame_dig -16
    concat
    frame_dig -13
    concat
    frame_dig -10
    concat
    frame_dig -9
    concat
    frame_dig -2
    concat
    frame_dig -1
    concat
    pushbytes 0xec3319bb // method "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    dup
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:296-314
    // arc4.emit(
    //     "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    log
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 8 64 0
    bytecblock 0x151f7c75 0x00
    // tests/artifacts/Arc4PrimitiveOps/contract.py:6
    // class Arc4PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@57
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x96f14116 0xed666096 0x2ca0352b 0x85907d40 0x2cbec45b 0x07666fd9 0x370babd3 0x2b6b3ef0 0x339da97c 0x7898ed97 0x1f130cec 0xc748664e 0x7a460cb1 0xdcab1f01 0x97d9064d 0xce06c2a0 0xdcdbcee0 0x77a4b68d 0x4f540626 0x095aed41 0xe3b7e918 0x55337008 0x9bb1cd66 0x81484d9d 0x9a03df10 0xd3f0e44b 0x982db233 0xaffbdf0e 0x288af76e 0x8bd84a04 0x302b8a0a 0x337ae20b 0x6e259270 0x79e35f77 0x0f1574fe 0xb2cb13be 0xd059eea7 0x4cc4c157 0x3d17ac6e 0xf7f3d5fc 0xf8c8f8d5 0x43f7162a 0x42e09075 0xd956f575 0x6c0160df 0xa890150b 0x0b2f4c3f 0x9db9d327 0xe4d950a1 0xb605e80c // method "verify_uintn_uintn_eq(byte[],byte[])bool", method "verify_biguintn_uintn_eq(byte[],byte[])bool", method "verify_uintn_biguintn_eq(byte[],byte[])bool", method "verify_biguintn_biguintn_eq(byte[],byte[])bool", method "verify_uintn_uintn_ne(byte[],byte[])bool", method "verify_biguintn_uintn_ne(byte[],byte[])bool", method "verify_uintn_biguintn_ne(byte[],byte[])bool", method "verify_biguintn_biguintn_ne(byte[],byte[])bool", method "verify_uintn_uintn_lt(byte[],byte[])bool", method "verify_biguintn_uintn_lt(byte[],byte[])bool", method "verify_uintn_biguintn_lt(byte[],byte[])bool", method "verify_biguintn_biguintn_lt(byte[],byte[])bool", method "verify_uintn_uintn_le(byte[],byte[])bool", method "verify_biguintn_uintn_le(byte[],byte[])bool", method "verify_uintn_biguintn_le(byte[],byte[])bool", method "verify_biguintn_biguintn_le(byte[],byte[])bool", method "verify_uintn_uintn_gt(byte[],byte[])bool", method "verify_biguintn_uintn_gt(byte[],byte[])bool", method "verify_uintn_biguintn_gt(byte[],byte[])bool", method "verify_biguintn_biguintn_gt(byte[],byte[])bool", method "verify_uintn_uintn_ge(byte[],byte[])bool", method "verify_biguintn_uintn_ge(byte[],byte[])bool", method "verify_uintn_biguintn_ge(byte[],byte[])bool", method "verify_biguintn_biguintn_ge(byte[],byte[])bool", method "verify_uintn_init(byte[])uint32", method "verify_biguintn_init(byte[])uint256", method "verify_uintn_from_bytes(byte[])uint32", method "verify_biguintn_from_bytes(byte[])uint256", method "verify_uintn_from_log(byte[])uint32", method "verify_biguintn_from_log(byte[])uint256", method "verify_biguintn_as_uint64(byte[])uint64", method "verify_biguintn_as_biguint(byte[])uint512", method "verify_uintn64_as_uint64(byte[])uint64", method "verify_uintn64_as_biguint(byte[])uint512", method "verify_ufixednxm_bytes(ufixed32x8)byte[]", method "verify_bigufixednxm_bytes(ufixed256x16)byte[]", method "verify_ufixednxm_from_bytes(byte[])ufixed32x8", method "verify_bigufixednxm_from_bytes(byte[])ufixed256x16", method "verify_ufixednxm_from_log(byte[])ufixed32x8", method "verify_bigufixednxm_from_log(byte[])ufixed256x16", method "verify_string_init(string)string", method "verify_string_add(string,string)string", method "verify_string_eq(string,string)bool", method "verify_string_bytes(string)byte[]", method "verify_string_from_bytes(byte[])string", method "verify_string_from_log(byte[])string", method "verify_bool_bytes(bool)byte[]", method "verify_bool_from_bytes(byte[])bool", method "verify_bool_from_log(byte[])bool", method "verify_emit(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match verify_uintn_uintn_eq verify_biguintn_uintn_eq verify_uintn_biguintn_eq verify_biguintn_biguintn_eq verify_uintn_uintn_ne verify_biguintn_uintn_ne verify_uintn_biguintn_ne verify_biguintn_biguintn_ne verify_uintn_uintn_lt verify_biguintn_uintn_lt verify_uintn_biguintn_lt verify_biguintn_biguintn_lt verify_uintn_uintn_le verify_biguintn_uintn_le verify_uintn_biguintn_le verify_biguintn_biguintn_le verify_uintn_uintn_gt verify_biguintn_uintn_gt verify_uintn_biguintn_gt verify_biguintn_biguintn_gt verify_uintn_uintn_ge verify_biguintn_uintn_ge verify_uintn_biguintn_ge verify_biguintn_biguintn_ge verify_uintn_init verify_biguintn_init verify_uintn_from_bytes verify_biguintn_from_bytes verify_uintn_from_log verify_biguintn_from_log verify_biguintn_as_uint64 verify_biguintn_as_biguint verify_uintn64_as_uint64 verify_uintn64_as_biguint verify_ufixednxm_bytes verify_bigufixednxm_bytes verify_ufixednxm_from_bytes verify_bigufixednxm_from_bytes verify_ufixednxm_from_log verify_bigufixednxm_from_log verify_string_init verify_string_add verify_string_eq verify_string_bytes verify_string_from_bytes verify_string_from_log verify_bool_bytes verify_bool_from_bytes verify_bool_from_log verify_emit
    err

main___algopy_default_create@57:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_eq[routing]() -> void:
verify_uintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:11
    // return arc4.UInt64(a_biguint) == arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_eq[routing]() -> void:
verify_biguintn_uintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:17
    // return arc4.UInt512(a_biguint) == arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:13
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_eq[routing]() -> void:
verify_uintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:23
    // return arc4.UInt64(a_biguint) == arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:19
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_eq[routing]() -> void:
verify_biguintn_biguintn_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:29
    // return arc4.UInt512(a_biguint) == arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:25
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ne[routing]() -> void:
verify_uintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:35
    // return arc4.UInt64(a_biguint) != arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:31
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ne[routing]() -> void:
verify_biguintn_uintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:41
    // return arc4.UInt512(a_biguint) != arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ne[routing]() -> void:
verify_uintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:47
    // return arc4.UInt64(a_biguint) != arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:43
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ne[routing]() -> void:
verify_biguintn_biguintn_ne:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:53
    // return arc4.UInt512(a_biguint) != arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b!=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:49
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_lt[routing]() -> void:
verify_uintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:59
    // return arc4.UInt64(a_biguint) < arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:55
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_lt[routing]() -> void:
verify_biguintn_uintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:65
    // return arc4.UInt512(a_biguint) < arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:61
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_lt[routing]() -> void:
verify_uintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:71
    // return arc4.UInt64(a_biguint) < arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_lt[routing]() -> void:
verify_biguintn_biguintn_lt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:77
    // return arc4.UInt512(a_biguint) < arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b<
    // tests/artifacts/Arc4PrimitiveOps/contract.py:73
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_le[routing]() -> void:
verify_uintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:83
    // return arc4.UInt64(a_biguint) <= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:79
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_le[routing]() -> void:
verify_biguintn_uintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:89
    // return arc4.UInt512(a_biguint) <= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:85
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_le[routing]() -> void:
verify_uintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:95
    // return arc4.UInt64(a_biguint) <= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:91
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_le[routing]() -> void:
verify_biguintn_biguintn_le:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:101
    // return arc4.UInt512(a_biguint) <= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b<=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_gt[routing]() -> void:
verify_uintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:107
    // return arc4.UInt64(a_biguint) > arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:103
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_gt[routing]() -> void:
verify_biguintn_uintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:113
    // return arc4.UInt512(a_biguint) > arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:109
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_gt[routing]() -> void:
verify_uintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:119
    // return arc4.UInt64(a_biguint) > arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:115
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_gt[routing]() -> void:
verify_biguintn_biguintn_gt:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:125
    // return arc4.UInt512(a_biguint) > arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b>
    // tests/artifacts/Arc4PrimitiveOps/contract.py:121
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_uintn_ge[routing]() -> void:
verify_uintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:131
    // return arc4.UInt64(a_biguint) >= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_1 // 8
    <=
    assert // overflow
    cover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_uintn_ge[routing]() -> void:
verify_biguintn_uintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:137
    // return arc4.UInt512(a_biguint) >= arc4.UInt64(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:133
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_biguintn_ge[routing]() -> void:
verify_uintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:143
    // return arc4.UInt64(a_biguint) >= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    uncover 2
    b|
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:139
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_biguintn_ge[routing]() -> void:
verify_biguintn_biguintn_ge:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:149
    // return arc4.UInt512(a_biguint) >= arc4.UInt512(b_biguint)
    dig 1
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    uncover 2
    dig 1
    b|
    dig 2
    len
    intc_2 // 64
    <=
    assert // overflow
    cover 2
    b|
    b>=
    // tests/artifacts/Arc4PrimitiveOps/contract.py:145
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_init[routing]() -> void:
verify_uintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:154
    // return arc4.UInt32(a_biguint)
    dup
    len
    pushint 4 // 4
    <=
    assert // overflow
    pushint 4 // 4
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:151
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_init[routing]() -> void:
verify_biguintn_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:159
    // return arc4.UInt256(a_biguint)
    dup
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_bytes[routing]() -> void:
verify_uintn_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:161
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_bytes[routing]() -> void:
verify_biguintn_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:165
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn_from_log[routing]() -> void:
verify_uintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:171
    // return arc4.UInt32.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_from_log[routing]() -> void:
verify_biguintn_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:175
    // return arc4.UInt256.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:173
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_as_uint64[routing]() -> void:
verify_biguintn_as_uint64:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:180
    // return arc4.UInt256(a_biguint).as_uint64()
    dup
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    b|
    dup
    bitlen
    intc_2 // 64
    <=
    assert // overflow
    dup
    len
    intc_1 // 8
    -
    intc_1 // 8
    // tests/artifacts/Arc4PrimitiveOps/contract.py:177
    // @arc4.abimethod()
    extract3
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_biguintn_as_biguint[routing]() -> void:
verify_biguintn_as_biguint:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:185
    // return arc4.UInt256(a_biguint).as_biguint()
    dup
    len
    pushint 32 // 32
    <=
    assert // overflow
    pushint 32 // 32
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    dup
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    b|
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn64_as_uint64[routing]() -> void:
verify_uintn64_as_uint64:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:187
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:190
    // return arc4.UInt64(a_biguint).as_uint64()
    dup
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:187
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_uintn64_as_biguint[routing]() -> void:
verify_uintn64_as_biguint:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:192
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:195
    // return arc4.UInt64(a_biguint).as_biguint()
    dup
    len
    intc_1 // 8
    <=
    assert // overflow
    intc_1 // 8
    bzero
    b|
    // tests/artifacts/Arc4PrimitiveOps/contract.py:192
    // @arc4.abimethod()
    dup
    len
    intc_2 // 64
    <=
    assert // overflow
    intc_2 // 64
    bzero
    b|
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_bytes[routing]() -> void:
verify_ufixednxm_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:197
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_bytes[routing]() -> void:
verify_bigufixednxm_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:203
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_bytes[routing]() -> void:
verify_ufixednxm_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:209
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_bytes[routing]() -> void:
verify_bigufixednxm_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:215
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_ufixednxm_from_log[routing]() -> void:
verify_ufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:225
    // return arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]].from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bigufixednxm_from_log[routing]() -> void:
verify_bigufixednxm_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:231
    // return arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]].from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_init[routing]() -> void:
verify_string_init:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:233
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:235
    // result = arc4.String(String("Hello, ") + a)
    pushbytes "Hello, "
    swap
    concat
    dup
    len
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arc4PrimitiveOps/contract.py:233
    // @arc4.abimethod
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_add[routing]() -> void:
verify_string_add:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:238
    // @arc4.abimethod
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:240
    // result = a + b
    extract 2 0
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:238
    // @arc4.abimethod
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_eq[routing]() -> void:
verify_string_eq:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:243
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arc4PrimitiveOps/contract.py:245
    // return a == b
    ==
    // tests/artifacts/Arc4PrimitiveOps/contract.py:243
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_3 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_bytes[routing]() -> void:
verify_string_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_bytes[routing]() -> void:
verify_string_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:252
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_string_from_log[routing]() -> void:
verify_string_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:256
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:258
    // return arc4.String.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:256
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_bytes[routing]() -> void:
verify_bool_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_bytes[routing]() -> void:
verify_bool_from_bytes:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:264
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_bool_from_log[routing]() -> void:
verify_bool_from_log:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:268
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arc4PrimitiveOps/contract.py:270
    // return arc4.Bool.from_log(a)
    dup
    extract 6 0
    swap
    extract 2 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/Arc4PrimitiveOps/contract.py:268
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.Arc4PrimitiveOps.contract.Arc4PrimitiveOpsContract.verify_emit[routing]() -> void:
verify_emit:
    // tests/artifacts/Arc4PrimitiveOps/contract.py:272
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    txna ApplicationArgs 12
    txna ApplicationArgs 13
    txna ApplicationArgs 14
    extract 2 0
    txna ApplicationArgs 15
    dup
    intc_3 // 0
    extract_uint16
    dig 1
    pushint 2 // 2
    extract_uint16
    substring3
    extract 2 0
    txna ApplicationArgs 15
    dup
    pushint 2 // 2
    extract_uint16
    dig 1
    len
    substring3
    extract 2 0
    // tests/artifacts/Arc4PrimitiveOps/contract.py:296
    // arc4.emit(SwappedArc4(m, n, o, p, q, arc4_r, arc4_s, arc4_t))
    dig 7
    dig 7
    concat
    dig 6
    concat
    dig 5
    concat
    dig 4
    concat
    dig 3
    concat
    pushbytes 0x0054
    concat
    dig 2
    len
    pushint 84 // 84
    dig 1
    +
    itob
    extract 6 2
    uncover 2
    swap
    concat
    dig 3
    concat
    dig 2
    concat
    pushbytes 0x66bb0333 // method "SwappedArc4(uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:297-315
    // arc4.emit(
    //     "Swapped",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    dig 16
    len
    pushint 173 // 173
    +
    pushbytes 0x00ad
    uncover 17
    concat
    uncover 16
    concat
    dig 1
    itob
    extract 6 2
    concat
    dig 15
    len
    uncover 2
    +
    swap
    uncover 14
    concat
    uncover 13
    concat
    dig 1
    itob
    extract 6 2
    concat
    dig 12
    len
    uncover 2
    +
    dup
    itob
    extract 6 2
    uncover 2
    swap
    concat
    dig 11
    len
    uncover 2
    +
    swap
    uncover 10
    concat
    uncover 9
    concat
    uncover 8
    concat
    uncover 7
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 1
    itob
    extract 6 2
    concat
    swap
    uncover 2
    +
    itob
    extract 6 2
    concat
    uncover 6
    concat
    uncover 5
    concat
    uncover 4
    concat
    uncover 3
    concat
    uncover 2
    concat
    swap
    concat
    pushbytes 0xec3319bb // method "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))"
    swap
    concat
    dup
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:316-334
    // arc4.emit(
    //     "Swapped(string,uint512,uint64,byte[],uint64,bool,byte[],string,uint64,uint256,ufixed32x8,ufixed256x16,bool,uint8[3],uint16[],(uint32,uint64,string))",
    //     a,
    //     b,
    //     c,
    //     d.copy(),
    //     e,
    //     f,
    //     g.copy(),
    //     h,
    //     m,
    //     n,
    //     o,
    //     p,
    //     q,
    //     arc4_r.copy(),
    //     arc4_s.copy(),
    //     arc4_t,
    // )
    log
    // tests/artifacts/Arc4PrimitiveOps/contract.py:272
    // @arc4.abimethod()
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAEAQhAACYCBBUffHUBADEbQQaIgi4ElvFBFgTtZmCWBCygNSsEhZB9QAQsvsRbBAdmb9kENwur0wQraz7wBDOdqXwEeJjtlwQfEwzsBMdIZk4EekYMsQTcqx8BBJfZBk0EzgbCoATc287gBHekto0ET1QGJgQJWu1BBOO36RgEVTNwCASbsc1mBIFITZ0EmgPfEATT8ORLBJgtsjMEr/vfDgQoivduBIvYSgQEDxV0/gSyyxO+BNBZ7qcETMTBVwQ9F6xuBPfz1fwE+Mj41QRD9xYqBELgkHUE2Vb1dQRsAWDfBKiQFQsECy9MPwSdudMnBOTZUKEEtgXoDDYaAI4uBR4E/QTcBLsEmgR5BFgENwQWA/UD1AOzA5IDcQNQAy8DDgLtAswCqwKKAmkCSAInAhEB+wHoAdUBvwGpAZEBeQFmAVMBPQEnAREA+wDgAMIArwCZAIEAbgBYAAIlQzEZFEQxGEQ2GgE2GgI2GgM2GgQ2GgU2GgY2Ggc2Ggg2Ggk2Ggo2Ggs2Ggw2Gg02Gg5XAgA2Gg9JJVlLAYECWVJXAgA2Gg9JgQJZSwEVUlcCAIgIYyJDMRkURDEYRDYaAVcCAIgIQChMULAiQzEZFEQxGEQ2GgFXAgAoTFCwIkMxGRREMRhENhoBSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIAiAfuKExQsCJDMRkURDEYRDYaAVcCAChMULAiQzEZFEQxGEQ2GgFXAgCIB7dJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgE2GgKIB5ApJU8CVChMULAiQzEZFEQxGEQ2GgE2GgKIB10oTFCwIkMxGRREMRhENhoBVwIAiAcvKExQsCJDMRkURDEYRDYaAVcCAIgHCChMULAiQzEZFEQxGEQ2GgFXAgCIBuEoTFCwIkMxGRREMRhENhoBVwIAKExQsCJDMRkURDEYRDYaAVcCAChMULAiQzEZFEQxGEQ2GgFJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgCIBmQoTFCwIkMxGRREMRhENhoBVwIAiAY9KExQsCJDMRkURDEYRDYaAVcCAChMULAiQzEZFEQxGEQ2GgFXAgAoTFCwIkMxGRREMRhENhoBVwIAiAXwKExQsCJDMRkURDEYRDYaAVcCAIgFyShMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBZApJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBVQpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBRgpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBNopJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBJwpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBGApJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBCQpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIA+YpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIA6gpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIA2wpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAzApJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAvIpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIArQpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAngpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAjwpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAf4pJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAcApJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAYQpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAUgpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAQopJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAMwpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAJApJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAFQpJU8CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIABYpJU8CVChMULAiQzEZQPq8MRgURCJDigIBi/4VIw5EI6+L/ksBq4v/FSMORIv/TwKrqImKAgGL/hUkDkQkr4v+q4v/FSMORCOvi/+rqImKAgGL/hUjDkQjr4v+q4v/FSQORCSvi/+rqImKAgGL/hUkDkQkr4v+SwGri/8VJA5Ei/9PAquoiYoCAYv+FSMORCOvi/5LAauL/xUjDkSL/08Cq6mJigIBi/4VJA5EJK+L/quL/xUjDkQjr4v/q6mJigIBi/4VIw5EI6+L/quL/xUkDkQkr4v/q6mJigIBi/4VJA5EJK+L/ksBq4v/FSQORIv/TwKrqYmKAgGL/hUjDkQjr4v+SwGri/8VIw5Ei/9PAqukiYoCAYv+FSQORCSvi/6ri/8VIw5EI6+L/6ukiYoCAYv+FSMORCOvi/6ri/8VJA5EJK+L/6ukiYoCAYv+FSQORCSvi/5LAauL/xUkDkSL/08Cq6SJigIBi/4VIw5EI6+L/ksBq4v/FSMORIv/TwKrpomKAgGL/hUkDkQkr4v+q4v/FSMORCOvi/+rpomKAgGL/hUjDkQjr4v+q4v/FSQORCSvi/+rpomKAgGL/hUkDkQkr4v+SwGri/8VJA5Ei/9PAqumiYoCAYv+FSMORCOvi/5LAauL/xUjDkSL/08Cq6WJigIBi/4VJA5EJK+L/quL/xUjDkQjr4v/q6WJigIBi/4VIw5EI6+L/quL/xUkDkQkr4v/q6WJigIBi/4VJA5EJK+L/ksBq4v/FSQORIv/TwKrpYmKAgGL/hUjDkQjr4v+SwGri/8VIw5Ei/9PAquniYoCAYv+FSQORCSvi/6ri/8VIw5EI6+L/6uniYoCAYv+FSMORCOvi/6ri/8VJA5EJK+L/6uniYoCAYv+FSQORCSvi/5LAauL/xUkDkSL/08Cq6eJigEBi/8VgQQORIEEr4v/q4mKAQGL/xWBIA5EgSCvi/+riYoBAYv/VwQAi/9XAAQoEkSJigEBi/9XBACL/1cABCgSRImKAQGL/1cEAIv/VwAEKBJEiYoBAYv/VwQAi/9XAAQoEkSJigEBgAdIZWxsbywgi/9QSRUWVwYCTFCJigIBi/9XAgCL/kxQSVcCABUWVwYCXACJigIBi/6L/xKJigEBi/8VFlcGAov/UImKAQGL/1cEAIv/VwAEKBJEiYoBAYv/VwQAi/9XAAQoEkSJihAAi/iL+VCL+lCL+1CL/FCL/VCAAgBUUIv+FYFUSwEIFlcGAk8CTFCL/lCL/1CABGa7AzNMULCL8BWBrQEIgAIArYvxUIvyUEsBFlcGAlCL8xVPAghMi/RQi/VQSwEWVwYCUIv2FU8CCEkWVwYCTwJMUIv3FU8CCEyL+FCL+VCL+lCL+1CL/FCL/VBLARZXBgJQTE8CCBZXBgJQi/BQi/NQi/ZQi/dQi/5Qi/9QgATsMxm7TFBJsLCJ", + "approval": "CiAEAQhAACYCBBUffHUBADEbQQFtMRkURDEYRIIyBJbxQRYE7WZglgQsoDUrBIWQfUAELL7EWwQHZm/ZBDcLq9MEK2s+8AQznal8BHiY7ZcEHxMM7ATHSGZOBHpGDLEE3KsfAQSX2QZNBM4GwqAE3NvO4AR3pLaNBE9UBiYECVrtQQTjt+kYBFUzcAgEm7HNZgSBSE2dBJoD3xAE0/DkSwSYLbIzBK/73w4EKIr3bgSL2EoEBDArigoEM3riCwRuJZJwBHnjX3cEDxV0/gSyyxO+BNBZ7qcETMTBVwQ9F6xuBPfz1fwE+Mj41QRD9xYqBELgkHUE2Vb1dQRsAWDfBKiQFQsECy9MPwSdudMnBOTZUKEEtgXoDDYaAI4yAAkANwBlAJMAwQDvAR0BSwF5AacB1QIDAjECXwKNArsC6QMXA0UDcwOhA88D/QQrBFkEbwSFBJEEnQSxBMUE5gUEBRgFNAVFBVYFYgVuBYIFlgW1BdAF4gXzBf8GEwYkBjAGRAAxGRQxGBQQQzYaAVcCADYaAlcCAEsBFSMORCOvTwJLAatLAhUjDkROAquoKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUkDkQkr08Cq0sBFSMORCOvTwKrqCklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVIw5EI69PAqtLARUkDkQkr08Cq6gpJU8CVChMULAiQzYaAVcCADYaAlcCAEsBFSQORCSvTwJLAatLAhUkDkROAquoKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUjDkQjr08CSwGrSwIVIw5ETgKrqSklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVJA5EJK9PAqtLARUjDkQjr08Cq6kpJU8CVChMULAiQzYaAVcCADYaAlcCAEsBFSMORCOvTwKrSwEVJA5EJK9PAqupKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUkDkQkr08CSwGrSwIVJA5ETgKrqSklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVIw5EI69PAksBq0sCFSMORE4Cq6QpJU8CVChMULAiQzYaAVcCADYaAlcCAEsBFSQORCSvTwKrSwEVIw5EI69PAqukKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUjDkQjr08Cq0sBFSQORCSvTwKrpCklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVJA5EJK9PAksBq0sCFSQORE4Cq6QpJU8CVChMULAiQzYaAVcCADYaAlcCAEsBFSMORCOvTwJLAatLAhUjDkROAqumKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUkDkQkr08Cq0sBFSMORCOvTwKrpiklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVIw5EI69PAqtLARUkDkQkr08Cq6YpJU8CVChMULAiQzYaAVcCADYaAlcCAEsBFSQORCSvTwJLAatLAhUkDkROAqumKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUjDkQjr08CSwGrSwIVIw5ETgKrpSklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVJA5EJK9PAqtLARUjDkQjr08Cq6UpJU8CVChMULAiQzYaAVcCADYaAlcCAEsBFSMORCOvTwKrSwEVJA5EJK9PAqulKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUkDkQkr08CSwGrSwIVJA5ETgKrpSklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVIw5EI69PAksBq0sCFSMORE4Cq6cpJU8CVChMULAiQzYaAVcCADYaAlcCAEsBFSQORCSvTwKrSwEVIw5EI69PAqunKSVPAlQoTFCwIkM2GgFXAgA2GgJXAgBLARUjDkQjr08Cq0sBFSQORCSvTwKrpyklTwJUKExQsCJDNhoBVwIANhoCVwIASwEVJA5EJK9PAksBq0sCFSQORE4Cq6cpJU8CVChMULAiQzYaAVcCAEkVgQQORIEEr6soTFCwIkM2GgFXAgBJFYEgDkSBIK+rKExQsCJDNhoBVwIAKExQsCJDNhoBVwIAKExQsCJDNhoBSVcGAExXAgQoEkQoTFCwIkM2GgFJVwYATFcCBCgSRChMULAiQzYaAVcCAEkVgSAORIEgr6tJkyQOREkVIwkjWChMULAiQzYaAVcCAEkVgSAORIEgr6tJFSQORCSvqyhMULAiQzYaAVcCAEkVIw5EI6+rKExQsCJDNhoBVwIASRUjDkQjr6tJFSQORCSvqyhMULAiQzYaAUkVFlcGAkxQKExQsCJDNhoBSRUWVwYCTFAoTFCwIkM2GgFXAgAoTFCwIkM2GgFXAgAoTFCwIkM2GgFJVwYATFcCBCgSRChMULAiQzYaAUlXBgBMVwIEKBJEKExQsCJDNhoBVwIAgAdIZWxsbywgTFBJFRZXBgJMUChMULAiQzYaATYaAlcCAFBJVwIAFRZXBgJcAChMULAiQzYaATYaAhIpJU8CVChMULAiQzYaAUkVFlcGAkxQKExQsCJDNhoBVwIAKExQsCJDNhoBSVcGAExXAgQoEkQoTFCwIkM2GgFJFRZXBgJMUChMULAiQzYaAVcCAChMULAiQzYaAUlXBgBMVwIEKBJEKExQsCJDNhoBNhoCNhoDNhoENhoFNhoGNhoHNhoINhoJNhoKNhoLNhoMNhoNNhoOVwIANhoPSSVZSwGBAllSVwIANhoPSYECWUsBFVJXAgBLB0sHUEsGUEsFUEsEUEsDUIACAFRQSwIVgVRLAQgWVwYCTwJMUEsDUEsCUIAEZrsDM0xQsEsQFYGtAQiAAgCtTxFQTxBQSwEWVwYCUEsPFU8CCExPDlBPDVBLARZXBgJQSwwVTwIISRZXBgJPAkxQSwsVTwIITE8KUE8JUE8IUE8HUE8GUE8FUEsBFlcGAlBMTwIIFlcGAlBPBlBPBVBPBFBPA1BPAlBMUIAE7DMZu0xQSbCwIkM=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/Arrays/data/Contract.approval.teal b/tests/artifacts/Arrays/data/Contract.approval.teal index d93b261..ba7b526 100644 --- a/tests/artifacts/Arrays/data/Contract.approval.teal +++ b/tests/artifacts/Arrays/data/Contract.approval.teal @@ -3,183 +3,37 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 8 0 5 512 + intcblock 8 1 0 5 512 bytecblock 0x 0x000000000000000100000000000000020000000000000003 0x0000000000000000 0x0000000000000004 pushbytes 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff store 0 // tests/artifacts/Arrays/uint64.py:13 // class Contract(arc4.ARC4Contract): txn NumAppArgs - bz main_bare_routing@17 - pushbytess 0xa33be873 0xe0c378e9 0x366f509d 0x58351a50 0xfa99e984 0xa20e440f 0x179ac3f9 0x45dcc836 0xf17f6f0a 0x845e1b4e 0x7621cfd1 0x5661a67c // method "test_array()void", method "test_array_extend()void", method "test_array_multiple_append()void", method "overhead()void", method "test_array_too_long()void", method "test_array_copy_and_extend()void", method "test_array_evaluation_order()void", method "test_array_assignment_maximum_cursage()void", method "test_allocations(uint64)void", method "test_iteration()void", method "test_quicksort()void", method "test_unobserved_write()void" - txna ApplicationArgs 0 - match main_test_array_route@3 main_test_array_extend_route@4 main_test_array_multiple_append_route@5 main_overhead_route@6 main_test_array_too_long_route@7 main_test_array_copy_and_extend_route@8 main_test_array_evaluation_order_route@9 main_test_array_assignment_maximum_cursage_route@10 main_test_allocations_route@11 main_test_iteration_route@12 main_test_quicksort_route@13 main_test_unobserved_write_route@14 - -main_after_if_else@21: - // tests/artifacts/Arrays/uint64.py:13 - // class Contract(arc4.ARC4Contract): - intc_2 // 0 - return - -main_test_unobserved_write_route@14: - // tests/artifacts/Arrays/uint64.py:191 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_unobserved_write - intc_0 // 1 - return - -main_test_quicksort_route@13: - // tests/artifacts/Arrays/uint64.py:174 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_quicksort - intc_0 // 1 - return - -main_test_iteration_route@12: - // tests/artifacts/Arrays/uint64.py:140 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_iteration - intc_0 // 1 - return - -main_test_allocations_route@11: - // tests/artifacts/Arrays/uint64.py:134 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/uint64.py:13 - // class Contract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/uint64.py:134 - // @arc4.abimethod() - callsub test_allocations - intc_0 // 1 - return - -main_test_array_assignment_maximum_cursage_route@10: - // tests/artifacts/Arrays/uint64.py:125 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_array_assignment_maximum_cursage - intc_0 // 1 - return - -main_test_array_evaluation_order_route@9: - // tests/artifacts/Arrays/uint64.py:106 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_array_evaluation_order - intc_0 // 1 - return - -main_test_array_copy_and_extend_route@8: - // tests/artifacts/Arrays/uint64.py:84 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_array_copy_and_extend - intc_0 // 1 - return - -main_test_array_too_long_route@7: - // tests/artifacts/Arrays/uint64.py:75 - // @arc4.abimethod() + bz main___algopy_default_create@19 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - callsub test_array_too_long - intc_0 // 1 - return + assert + pushbytess 0xa33be873 0xe0c378e9 0x366f509d 0x58351a50 0xfa99e984 0xa20e440f 0x179ac3f9 0x45dcc836 0xf17f6f0a 0x845e1b4e 0x7621cfd1 0x5661a67c // method "test_array()void", method "test_array_extend()void", method "test_array_multiple_append()void", method "overhead()void", method "test_array_too_long()void", method "test_array_copy_and_extend()void", method "test_array_evaluation_order()void", method "test_array_assignment_maximum_cursage()void", method "test_allocations(uint64)void", method "test_iteration()void", method "test_quicksort()void", method "test_unobserved_write()void" + txna ApplicationArgs 0 + match test_array test_array_extend test_array_multiple_append main_overhead_route@7 test_array_too_long test_array_copy_and_extend test_array_evaluation_order test_array_assignment_maximum_cursage test_allocations test_iteration test_quicksort test_unobserved_write + err -main_overhead_route@6: +main_overhead_route@7: // tests/artifacts/Arrays/uint64.py:71 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - intc_0 // 1 - return - -main_test_array_multiple_append_route@5: - // tests/artifacts/Arrays/uint64.py:62 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_array_multiple_append - intc_0 // 1 - return - -main_test_array_extend_route@4: - // tests/artifacts/Arrays/uint64.py:50 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_array_extend - intc_0 // 1 + intc_1 // 1 return -main_test_array_route@3: - // tests/artifacts/Arrays/uint64.py:14 - // @arc4.abimethod() +main___algopy_default_create@19: txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_array - intc_0 // 1 - return - -main_bare_routing@17: - // tests/artifacts/Arrays/uint64.py:13 - // class Contract(arc4.ARC4Contract): - txn OnCompletion - bnz main_after_if_else@21 txn ApplicationID ! - assert // can only call when creating - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating // tests.artifacts.Arrays.uint64.quicksort_window(arr: uint64, window_left: uint64, window_right: uint64) -> void: @@ -191,7 +45,7 @@ quicksort_window: // ) -> None: proto 3 0 bytec_0 // "" - dupn 2 + dup // tests/artifacts/Arrays/uint64.py:207 // pivot = arr[(window_left + window_right) // 2] frame_dig -2 @@ -202,7 +56,7 @@ quicksort_window: frame_dig -3 loads swap - intc_1 // 8 + intc_0 // 8 * extract_uint64 frame_dig -1 @@ -214,21 +68,21 @@ quicksort_window_while_top@3: // while arr[left] < pivot: frame_dig -3 loads - frame_dig 5 - intc_1 // 8 + frame_dig 4 + intc_0 // 8 * dup frame_bury 0 extract_uint64 - frame_dig 3 + frame_dig 2 < bz quicksort_window_while_top@6 // tests/artifacts/Arrays/uint64.py:213 // left += 1 - frame_dig 5 - intc_0 // 1 + frame_dig 4 + intc_1 // 1 + - frame_bury 5 + frame_bury 4 b quicksort_window_while_top@3 quicksort_window_while_top@6: @@ -237,26 +91,26 @@ quicksort_window_while_top@6: // while pivot < arr[right]: frame_dig -3 loads - frame_dig 4 - intc_1 // 8 + frame_dig 3 + intc_0 // 8 * dup frame_bury 1 extract_uint64 - frame_dig 3 + frame_dig 2 > bz quicksort_window_after_while@10 // tests/artifacts/Arrays/uint64.py:216-217 // # break out of loop if right would go negative // if not right: - frame_dig 4 + frame_dig 3 bz quicksort_window_after_while@22 // tests/artifacts/Arrays/uint64.py:219 // right -= 1 - frame_dig 4 - intc_0 // 1 + frame_dig 3 + intc_1 // 1 - - frame_bury 4 + frame_bury 3 b quicksort_window_while_top@6 quicksort_window_after_while@22: @@ -264,28 +118,28 @@ quicksort_window_after_while@22: // # sort left half of window // if window_left < right: frame_dig -2 - frame_dig 4 + frame_dig 3 < bz quicksort_window_after_if_else@24 // tests/artifacts/Arrays/uint64.py:249 // quicksort_window(arr, window_left, right) frame_dig -3 frame_dig -2 - frame_dig 4 + frame_dig 3 callsub quicksort_window quicksort_window_after_if_else@24: // tests/artifacts/Arrays/uint64.py:250-251 // # sort right half of window // if left < window_right: - frame_dig 5 + frame_dig 4 frame_dig -1 < bz quicksort_window_after_if_else@26 // tests/artifacts/Arrays/uint64.py:252 // quicksort_window(arr, left, window_right) frame_dig -3 - frame_dig 5 + frame_dig 4 frame_dig -1 callsub quicksort_window @@ -296,8 +150,8 @@ quicksort_window_after_while@10: // tests/artifacts/Arrays/uint64.py:221-222 // # if window isn't empty then swap values and move window in // if left < right: - frame_dig 5 frame_dig 4 + frame_dig 3 < bz quicksort_window_after_if_else@16 // tests/artifacts/Arrays/uint64.py:223 @@ -308,43 +162,43 @@ quicksort_window_after_while@10: frame_dig 1 dup cover 3 - intc_1 // 8 + intc_0 // 8 extract3 // on error: index access is out of bounds dig 1 frame_dig 0 dup cover 3 - intc_1 // 8 + intc_0 // 8 extract3 // on error: index access is out of bounds cover 3 - replace3 + replace3 // on error: index access is out of bounds cover 2 - replace3 + replace3 // on error: index access is out of bounds frame_dig -3 swap stores // tests/artifacts/Arrays/uint64.py:224 // left += 1 - frame_dig 5 - intc_0 // 1 + frame_dig 4 + intc_1 // 1 + - frame_bury 5 + frame_bury 4 // tests/artifacts/Arrays/uint64.py:225-226 // # break out of loop if right would go negative // if not right: - frame_dig 4 + frame_dig 3 bz quicksort_window_after_while@22 // tests/artifacts/Arrays/uint64.py:228 // right -= 1 - frame_dig 4 - intc_0 // 1 + frame_dig 3 + intc_1 // 1 - dup - frame_bury 4 + frame_bury 3 // tests/artifacts/Arrays/uint64.py:229-230 // # explicit continue to avoid hitting outer break // if left <= right: - frame_dig 5 + frame_dig 4 >= bnz quicksort_window_while_top@3 b quicksort_window_after_while@22 @@ -353,37 +207,27 @@ quicksort_window_after_if_else@16: // tests/artifacts/Arrays/uint64.py:235-236 // # if window is just one item, don't bother swapping, but still adjust window // if left == right: - frame_dig 5 frame_dig 4 + frame_dig 3 == bz quicksort_window_after_while@22 // tests/artifacts/Arrays/uint64.py:237 // left += 1 - frame_dig 5 - intc_0 // 1 - + - frame_bury 5 frame_dig 4 - dup - frame_bury 2 + intc_1 // 1 + + + frame_bury 4 // tests/artifacts/Arrays/uint64.py:238-239 // # don't decrement right if it would go negative // if right: - bz quicksort_window_after_if_else@19 + frame_dig 3 + bz quicksort_window_after_while@22 // tests/artifacts/Arrays/uint64.py:240 // right -= 1 - frame_dig 4 - intc_0 // 1 + frame_dig 3 + intc_1 // 1 - - frame_bury 2 - -quicksort_window_after_if_else@19: - frame_dig 2 - frame_bury 4 - // tests/artifacts/Arrays/uint64.py:241-243 - // # loop always ends in this scenario - // # and an explict break consumes fewer ops - // break + frame_bury 3 b quicksort_window_after_while@22 @@ -423,7 +267,7 @@ create_array_for_header@1: stores // tests/artifacts/Arrays/uint64.py:258 // for i in urange(5): - intc_0 // 1 + intc_1 // 1 + frame_bury 1 b create_array_for_header@1 @@ -446,11 +290,11 @@ assert_last_is_zero: loads dup len - intc_1 // 8 + intc_0 // 8 / - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * extract_uint64 ! @@ -489,7 +333,7 @@ add_x_for_header@1: stores // tests/artifacts/Arrays/uint64.py:279 // for i in urange(x): - intc_0 // 1 + intc_1 // 1 + frame_bury 0 b add_x_for_header@1 @@ -510,7 +354,7 @@ append_length_and_return: loads dup len - intc_1 // 8 + intc_0 // 8 / itob concat // on error: max array length exceeded @@ -523,12 +367,8 @@ append_length_and_return: retsub -// tests.artifacts.Arrays.uint64.Contract.test_array() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_array[routing]() -> void: test_array: - // tests/artifacts/Arrays/uint64.py:14-15 - // @arc4.abimethod() - // def test_array(self) -> None: - proto 0 0 // tests/artifacts/Arrays/uint64.py:16 // arr = ReferenceArray[UInt64]() callsub _puya_lib.mem.new_slot @@ -550,7 +390,7 @@ test_array: loads dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 6 // 6 @@ -558,9 +398,9 @@ test_array: assert // tests/artifacts/Arrays/uint64.py:25 // assert arr[-1] == 4 - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * extract_uint64 pushint 4 // 4 @@ -576,7 +416,7 @@ test_array: test_array_for_header@2: // tests/artifacts/Arrays/uint64.py:285 // for _i in urange(x): - frame_dig 2 + dup // tests/artifacts/Arrays/uint64.py:27 // pop_x(arr, x=UInt64(3), expected=UInt64(4)) pushint 3 // 3 @@ -586,55 +426,54 @@ test_array_for_header@2: bz test_array_after_for@4 // tests/artifacts/Arrays/uint64.py:286 // popped = arr.pop() - frame_dig 0 + dig 2 dup loads dup len dup - intc_1 // 8 + intc_0 // 8 - dig 2 - dig 1 + intc_2 // 0 + dig 2 + extract3 uncover 3 - substring3 uncover 2 - intc_2 // 0 uncover 3 - extract3 - swap + substring3 btoi cover 2 stores // tests/artifacts/Arrays/uint64.py:287 // assert popped == expected - frame_dig 1 + dig 2 dup cover 2 == assert // tests/artifacts/Arrays/uint64.py:288 // expected -= 1 - intc_0 // 1 + intc_1 // 1 - - frame_bury 1 + bury 2 // tests/artifacts/Arrays/uint64.py:285 // for _i in urange(x): - frame_dig 2 - intc_0 // 1 + dup + intc_1 // 1 + - frame_bury 2 + bury 1 b test_array_for_header@2 test_array_after_for@4: // tests/artifacts/Arrays/uint64.py:28 // assert arr.length == 3 - frame_dig 0 + dig 2 dup loads dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 3 // 3 @@ -642,14 +481,14 @@ test_array_after_for@4: assert // tests/artifacts/Arrays/uint64.py:29 // assert arr[-1] == 1 - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * dig 1 swap extract_uint64 - intc_0 // 1 + intc_1 // 1 == assert // tests/artifacts/Arrays/uint64.py:31 @@ -663,7 +502,7 @@ test_array_after_for@4: // assert arr.length == 4 dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 4 // 4 @@ -671,9 +510,9 @@ test_array_after_for@4: assert // tests/artifacts/Arrays/uint64.py:33 // assert arr[-1] == 43 - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * dig 1 swap @@ -699,7 +538,7 @@ test_array_after_for@4: loads dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 14 // 14 @@ -707,9 +546,9 @@ test_array_after_for@4: assert // tests/artifacts/Arrays/uint64.py:38 // assert arr[-1] == 9 - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * dig 1 swap @@ -726,7 +565,7 @@ test_array_after_for@4: // assert arr.length == 15 dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 15 // 15 @@ -734,9 +573,9 @@ test_array_after_for@4: assert // tests/artifacts/Arrays/uint64.py:42 // assert arr[-1] == 44 - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * dig 1 swap @@ -762,7 +601,7 @@ test_array_after_for@4: pushint 2 // 2 + itob - replace2 0 + replace2 0 // on error: index access is out of bounds swap dig 1 stores @@ -770,7 +609,7 @@ test_array_after_for@4: // assert arr.length == 17 dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 17 // 17 @@ -789,7 +628,7 @@ test_array_after_for@4: dup pushint 2 // 2 - - intc_1 // 8 + intc_0 // 8 * dig 2 swap @@ -799,18 +638,19 @@ test_array_after_for@4: assert // tests/artifacts/Arrays/uint64.py:48 // assert arr[-1] == 100 - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * extract_uint64 pushint 100 // 100 == - assert - retsub + // tests/artifacts/Arrays/uint64.py:14 + // @arc4.abimethod() + return -// tests.artifacts.Arrays.uint64.Contract.test_array_extend() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_array_extend[routing]() -> void: test_array_extend: // tests/artifacts/Arrays/uint64.py:52 // arr = ReferenceArray[UInt64]() @@ -821,7 +661,7 @@ test_array_extend: // tests/artifacts/Arrays/uint64.py:53 // add_x(arr, UInt64(1)) dup - intc_0 // 1 + intc_1 // 1 callsub add_x // tests/artifacts/Arrays/uint64.py:57 // arr2.append(UInt64(3)) @@ -843,15 +683,16 @@ test_array_extend: // tests/artifacts/Arrays/uint64.py:60 // assert arr.length == 4 len - intc_1 // 8 + intc_0 // 8 / pushint 4 // 4 == - assert - retsub + // tests/artifacts/Arrays/uint64.py:50 + // @arc4.abimethod() + return -// tests.artifacts.Arrays.uint64.Contract.test_array_multiple_append() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_array_multiple_append[routing]() -> void: test_array_multiple_append: // tests/artifacts/Arrays/uint64.py:64 // arr = ReferenceArray[UInt64]() @@ -862,13 +703,13 @@ test_array_multiple_append: // tests/artifacts/Arrays/uint64.py:65 // add_x(arr, UInt64(1)) dup - intc_0 // 1 + intc_1 // 1 callsub add_x // tests/artifacts/Arrays/uint64.py:66 // arr.append(UInt64(1)) dup loads - intc_0 // 1 + intc_1 // 1 itob concat // on error: max array length exceeded // tests/artifacts/Arrays/uint64.py:67 @@ -887,20 +728,17 @@ test_array_multiple_append: // tests/artifacts/Arrays/uint64.py:69 // assert arr.length == 4 len - intc_1 // 8 + intc_0 // 8 / pushint 4 // 4 == - assert - retsub + // tests/artifacts/Arrays/uint64.py:62 + // @arc4.abimethod() + return -// tests.artifacts.Arrays.uint64.Contract.test_array_too_long() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_array_too_long[routing]() -> void: test_array_too_long: - // tests/artifacts/Arrays/uint64.py:75-76 - // @arc4.abimethod() - // def test_array_too_long(self) -> None: - proto 0 0 // tests/artifacts/Arrays/uint64.py:77 // array = ReferenceArray[UInt64]() bytec_0 // 0x @@ -908,36 +746,35 @@ test_array_too_long: // for i in urange(512): intc_2 // 0 -test_array_too_long_for_header@1: +test_array_too_long_for_header@2: // tests/artifacts/Arrays/uint64.py:78 // for i in urange(512): - frame_dig 1 + dup intc 4 // 512 < - bz test_array_too_long_after_for@4 - frame_dig 0 + bz test_array_too_long_after_for@5 // tests/artifacts/Arrays/uint64.py:79 // array.append(i) - frame_dig 1 + dup2 dup cover 2 itob concat // on error: max array length exceeded - frame_bury 0 + bury 3 // tests/artifacts/Arrays/uint64.py:78 // for i in urange(512): - intc_0 // 1 + intc_1 // 1 + - frame_bury 1 - b test_array_too_long_for_header@1 + bury 1 + b test_array_too_long_for_header@2 -test_array_too_long_after_for@4: - frame_dig 0 +test_array_too_long_after_for@5: + dig 1 // tests/artifacts/Arrays/uint64.py:80 // assert array.length == 512, "array is expected length" dup len - intc_1 // 8 + intc_0 // 8 / intc 4 // 512 == @@ -948,15 +785,14 @@ test_array_too_long_after_for@4: itob concat // on error: max array length exceeded pop - retsub + // tests/artifacts/Arrays/uint64.py:75 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.uint64.Contract.test_array_copy_and_extend() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_array_copy_and_extend[routing]() -> void: test_array_copy_and_extend: - // tests/artifacts/Arrays/uint64.py:84-85 - // @arc4.abimethod() - // def test_array_copy_and_extend(self) -> None: - proto 0 0 // tests/artifacts/Arrays/uint64.py:86 // array = ReferenceArray[UInt64]() bytec_0 // 0x @@ -964,31 +800,30 @@ test_array_copy_and_extend: // for i in urange(5): intc_2 // 0 -test_array_copy_and_extend_for_header@1: +test_array_copy_and_extend_for_header@2: // tests/artifacts/Arrays/uint64.py:87 // for i in urange(5): - frame_dig 1 + dup intc_3 // 5 < - bz test_array_copy_and_extend_after_for@4 - frame_dig 0 + bz test_array_copy_and_extend_after_for@5 // tests/artifacts/Arrays/uint64.py:88 // array.append(i) - frame_dig 1 + dup2 dup cover 2 itob concat // on error: max array length exceeded - frame_bury 0 + bury 3 // tests/artifacts/Arrays/uint64.py:87 // for i in urange(5): - intc_0 // 1 + intc_1 // 1 + - frame_bury 1 - b test_array_copy_and_extend_for_header@1 + bury 1 + b test_array_copy_and_extend_for_header@2 -test_array_copy_and_extend_after_for@4: - frame_dig 0 +test_array_copy_and_extend_after_for@5: + dig 1 dup // tests/artifacts/Arrays/uint64.py:91 // array.append(UInt64(5)) @@ -999,7 +834,7 @@ test_array_copy_and_extend_after_for@4: // assert array.length == 6 dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 6 // 6 @@ -1007,9 +842,9 @@ test_array_copy_and_extend_after_for@4: assert // tests/artifacts/Arrays/uint64.py:93 // assert array[-1] == 5, "expected 5" - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * dig 1 swap @@ -1022,7 +857,7 @@ test_array_copy_and_extend_after_for@4: // assert array2.length == 5 dup len - intc_1 // 8 + intc_0 // 8 / dup intc_3 // 5 @@ -1030,9 +865,9 @@ test_array_copy_and_extend_after_for@4: assert // tests/artifacts/Arrays/uint64.py:96 // assert array2[-1] == 4, "expected 4" - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * dig 1 swap @@ -1047,7 +882,7 @@ test_array_copy_and_extend_after_for@4: // assert array.length == 11 dup len - intc_1 // 8 + intc_0 // 8 / dup pushint 11 // 11 @@ -1057,16 +892,16 @@ test_array_copy_and_extend_after_for@4: // tests/artifacts/Arrays/uint64.py:100 // assert array2.length == 5 len - intc_1 // 8 + intc_0 // 8 / intc_3 // 5 == assert // tests/artifacts/Arrays/uint64.py:101 // assert array[-1] == 4, "expected 4" - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * dig 1 swap @@ -1095,11 +930,12 @@ test_array_copy_and_extend_after_for@4: pushint 48 // 48 extract_uint64 ! - assert // expected 4 - retsub + // tests/artifacts/Arrays/uint64.py:84 + // @arc4.abimethod() + return // on error: expected 4 -// tests.artifacts.Arrays.uint64.Contract.test_array_evaluation_order() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_array_evaluation_order[routing]() -> void: test_array_evaluation_order: // tests/artifacts/Arrays/uint64.py:108 // arr = ReferenceArray[UInt64]() @@ -1129,7 +965,7 @@ test_array_evaluation_order: loads dup len - intc_1 // 8 + intc_0 // 8 / pushint 6 // 6 == @@ -1145,9 +981,9 @@ test_array_evaluation_order: // tests/artifacts/Arrays/uint64.py:113 // assert arr[1] == 1 dup - intc_1 // 8 + intc_0 // 8 extract_uint64 - intc_0 // 1 + intc_1 // 1 == assert // tests/artifacts/Arrays/uint64.py:114 @@ -1171,7 +1007,7 @@ test_array_evaluation_order: dup pushint 32 // 32 extract_uint64 - intc_0 // 1 + intc_1 // 1 == assert // tests/artifacts/Arrays/uint64.py:117 @@ -1188,13 +1024,13 @@ test_array_evaluation_order: loads dup len - intc_1 // 8 + intc_0 // 8 / - intc_0 // 1 + intc_1 // 1 - - intc_1 // 8 + intc_0 // 8 * - intc_1 // 8 + intc_0 // 8 extract3 // on error: index access is out of bounds dig 1 callsub append_length_and_return @@ -1204,10 +1040,10 @@ test_array_evaluation_order: dig 2 loads swap - intc_1 // 8 + intc_0 // 8 * uncover 2 - replace3 + replace3 // on error: index access is out of bounds swap dig 1 stores @@ -1215,9 +1051,9 @@ test_array_evaluation_order: // assert arr.length == 8 dup len - intc_1 // 8 + intc_0 // 8 / - intc_1 // 8 + intc_0 // 8 == assert // tests/artifacts/Arrays/uint64.py:121 @@ -1242,11 +1078,12 @@ test_array_evaluation_order: extract_uint64 pushint 6 // 6 == - assert - retsub + // tests/artifacts/Arrays/uint64.py:106 + // @arc4.abimethod() + return -// tests.artifacts.Arrays.uint64.Contract.test_array_assignment_maximum_cursage() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_array_assignment_maximum_cursage[routing]() -> void: test_array_assignment_maximum_cursage: // tests/artifacts/Arrays/uint64.py:127 // arr = ReferenceArray[UInt64]() @@ -1267,14 +1104,14 @@ test_array_assignment_maximum_cursage: dig 1 loads swap - replace2 0 + replace2 0 // on error: index access is out of bounds stores // tests/artifacts/Arrays/uint64.py:130 // assert arr.length == 2 loads dup len - intc_1 // 8 + intc_0 // 8 / pushint 2 // 2 == @@ -1289,31 +1126,32 @@ test_array_assignment_maximum_cursage: assert // tests/artifacts/Arrays/uint64.py:132 // assert arr[1] == 1 - intc_1 // 8 + intc_0 // 8 extract_uint64 - intc_0 // 1 + intc_1 // 1 == - assert - retsub + // tests/artifacts/Arrays/uint64.py:125 + // @arc4.abimethod() + return -// tests.artifacts.Arrays.uint64.Contract.test_allocations(num: uint64) -> void: +// tests.artifacts.Arrays.uint64.Contract.test_allocations[routing]() -> void: test_allocations: - // tests/artifacts/Arrays/uint64.py:134-135 + // tests/artifacts/Arrays/uint64.py:134 // @arc4.abimethod() - // def test_allocations(self, num: UInt64) -> None: - proto 1 0 + txna ApplicationArgs 1 + btoi // tests/artifacts/Arrays/uint64.py:136 // for _i in urange(num): intc_2 // 0 -test_allocations_for_header@1: +test_allocations_for_header@2: // tests/artifacts/Arrays/uint64.py:136 // for _i in urange(num): - frame_dig 0 - frame_dig -1 + dup + dig 2 < - bz test_allocations_after_for@4 + bz test_allocations_after_for@5 // tests/artifacts/Arrays/uint64.py:137 // alloc_test = ReferenceArray[UInt64]() callsub _puya_lib.mem.new_slot @@ -1322,26 +1160,25 @@ test_allocations_for_header@1: stores // tests/artifacts/Arrays/uint64.py:138 // add_x(alloc_test, UInt64(1)) - intc_0 // 1 + intc_1 // 1 callsub add_x // tests/artifacts/Arrays/uint64.py:136 // for _i in urange(num): - frame_dig 0 - intc_0 // 1 + dup + intc_1 // 1 + - frame_bury 0 - b test_allocations_for_header@1 + bury 1 + b test_allocations_for_header@2 -test_allocations_after_for@4: - retsub +test_allocations_after_for@5: + // tests/artifacts/Arrays/uint64.py:134 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.uint64.Contract.test_iteration() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_iteration[routing]() -> void: test_iteration: - // tests/artifacts/Arrays/uint64.py:140-141 - // @arc4.abimethod() - // def test_iteration(self) -> None: - proto 0 0 intc_2 // 0 dup bytec_0 // "" @@ -1352,38 +1189,37 @@ test_iteration: // for val in urange(5): intc_2 // 0 -test_iteration_for_header@1: +test_iteration_for_header@2: // tests/artifacts/Arrays/uint64.py:143 // for val in urange(5): - frame_dig 10 + dup intc_3 // 5 < - bz test_iteration_after_for@4 - frame_dig 9 + bz test_iteration_after_for@5 // tests/artifacts/Arrays/uint64.py:144 // arr.append(val) - frame_dig 10 + dup2 dup cover 2 itob concat // on error: max array length exceeded - frame_bury 9 + bury 3 // tests/artifacts/Arrays/uint64.py:143 // for val in urange(5): - intc_0 // 1 + intc_1 // 1 + - frame_bury 10 - b test_iteration_for_header@1 + bury 1 + b test_iteration_for_header@2 -test_iteration_after_for@4: - frame_dig 9 +test_iteration_after_for@5: + dig 1 // tests/artifacts/Arrays/uint64.py:145 // assert arr.length == 5, "expected array of length 5" len - intc_1 // 8 + intc_0 // 8 / dup - frame_bury 2 + bury 10 intc_3 // 5 == assert // expected array of length 5 @@ -1391,62 +1227,62 @@ test_iteration_after_for@4: // # iterate // last = UInt64(0) intc_2 // 0 - frame_bury 7 + bury 4 intc_2 // 0 - frame_bury 6 + bury 5 -test_iteration_for_header@5: +test_iteration_for_header@6: // tests/artifacts/Arrays/uint64.py:149 // for value in arr: - frame_dig 6 - frame_dig 2 + dig 4 + dig 9 < - bz test_iteration_after_for@8 - frame_dig 9 - frame_dig 6 + bz test_iteration_after_for@9 + dig 1 + dig 5 dup cover 2 - intc_1 // 8 + intc_0 // 8 * extract_uint64 // tests/artifacts/Arrays/uint64.py:150 // assert value >= last, "array is not sorted" dup - frame_dig 7 + dig 6 >= assert // array is not sorted swap - intc_0 // 1 + intc_1 // 1 + - frame_bury 6 - frame_bury 7 - b test_iteration_for_header@5 + bury 6 + bury 4 + b test_iteration_for_header@6 -test_iteration_after_for@8: - frame_dig 9 +test_iteration_after_for@9: + dig 1 // tests/artifacts/Arrays/uint64.py:153-154 // # enumerate // for idx, value in uenumerate(arr): len - intc_1 // 8 + intc_0 // 8 / - frame_bury 3 + bury 8 intc_2 // 0 - frame_bury 5 + bury 6 -test_iteration_for_header@9: +test_iteration_for_header@10: // tests/artifacts/Arrays/uint64.py:153-154 // # enumerate // for idx, value in uenumerate(arr): - frame_dig 5 - frame_dig 3 + dig 5 + dig 8 < - bz test_iteration_after_for@12 - frame_dig 9 - frame_dig 5 + bz test_iteration_after_for@13 + dig 1 + dig 6 dup cover 2 - intc_1 // 8 + intc_0 // 8 * extract_uint64 // tests/artifacts/Arrays/uint64.py:155 @@ -1454,73 +1290,73 @@ test_iteration_for_header@9: dig 1 == assert // incorrect array value - intc_0 // 1 + intc_1 // 1 + - frame_bury 5 - b test_iteration_for_header@9 + bury 6 + b test_iteration_for_header@10 -test_iteration_after_for@12: - frame_dig 9 +test_iteration_after_for@13: + dig 1 // tests/artifacts/Arrays/uint64.py:157-158 // # reverse // for value in reversed(arr): len - intc_1 // 8 + intc_0 // 8 / - frame_bury 8 + bury 3 -test_iteration_for_header@13: +test_iteration_for_header@14: // tests/artifacts/Arrays/uint64.py:157-158 // # reverse // for value in reversed(arr): - frame_dig 8 - bz test_iteration_after_for@16 - frame_dig 8 - intc_0 // 1 + dig 2 + bz test_iteration_after_for@17 + dig 2 + intc_1 // 1 - dup - frame_bury 8 - frame_dig 9 + bury 4 + dig 2 swap - intc_1 // 8 + intc_0 // 8 * extract_uint64 // tests/artifacts/Arrays/uint64.py:159 // assert value <= last, "array is not sorted" dup - frame_dig 7 + dig 5 <= assert // array is not sorted - frame_bury 7 - b test_iteration_for_header@13 + bury 4 + b test_iteration_for_header@14 -test_iteration_after_for@16: +test_iteration_after_for@17: // tests/artifacts/Arrays/uint64.py:162 // arc4_arr = arc4.DynamicArray[arc4.UInt64]() pushbytes 0x0000 - frame_bury 0 + bury 11 // tests/artifacts/Arrays/uint64.py:142 // arr = ReferenceArray[UInt64]() bytec_0 // 0x - frame_bury 1 + bury 10 // tests/artifacts/Arrays/uint64.py:164 // for i in urange(5): intc_2 // 0 - frame_bury 4 + bury 7 -test_iteration_for_header@17: +test_iteration_for_header@18: // tests/artifacts/Arrays/uint64.py:164 // for i in urange(5): - frame_dig 4 + dig 6 intc_3 // 5 < - bz test_iteration_after_for@20 + bz test_iteration_after_for@21 // tests/artifacts/Arrays/uint64.py:165 // arc4_arr.append(arc4.UInt64(i)) - frame_dig 4 + dig 6 dup itob - frame_dig 0 + dig 12 dup cover 2 dig 1 @@ -1528,35 +1364,35 @@ test_iteration_for_header@17: uncover 2 intc_2 // 0 extract_uint16 - intc_0 // 1 + intc_1 // 1 + itob extract 6 2 replace2 0 - frame_bury 0 - frame_dig 1 + bury 13 + dig 11 // tests/artifacts/Arrays/uint64.py:166 // native_arr.append(arc4.UInt64(i)) swap concat // on error: max array length exceeded - frame_bury 1 + bury 11 // tests/artifacts/Arrays/uint64.py:164 // for i in urange(5): - intc_0 // 1 + intc_1 // 1 + - frame_bury 4 - b test_iteration_for_header@17 + bury 7 + b test_iteration_for_header@18 -test_iteration_after_for@20: +test_iteration_after_for@21: // tests/artifacts/Arrays/uint64.py:167 // combined_arr = arc4_arr + native_arr - frame_dig 0 - frame_dig 1 + dig 10 + dig 10 concat // on error: max array length exceeded dup extract 2 0 len - intc_1 // 8 + intc_0 // 8 / itob extract 6 2 @@ -1595,16 +1431,13 @@ test_iteration_after_for@20: extract 74 8 bytec_3 // 0x0000000000000004 b== - assert - retsub + // tests/artifacts/Arrays/uint64.py:140 + // @arc4.abimethod() + return -// tests.artifacts.Arrays.uint64.Contract.test_quicksort() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_quicksort[routing]() -> void: test_quicksort: - // tests/artifacts/Arrays/uint64.py:174-175 - // @arc4.abimethod() - // def test_quicksort(self) -> None: - proto 0 0 bytec_0 // "" dupn 2 // tests/artifacts/Arrays/uint64.py:176-177 @@ -1619,21 +1452,20 @@ test_quicksort: txn Sender intc_2 // 0 -test_quicksort_for_header@1: +test_quicksort_for_header@2: // tests/artifacts/Arrays/uint64.py:178 // for b in Txn.sender.bytes: - frame_dig 5 + dup pushint 32 // 32 < - bz test_quicksort_after_for@4 + bz test_quicksort_after_for@5 // tests/artifacts/Arrays/uint64.py:179 // rnd.append(op.btoi(b)) - frame_dig 4 - frame_dig 5 + dup2 dup cover 2 getbyte - frame_dig 3 + dig 4 dup cover 2 loads @@ -1641,19 +1473,19 @@ test_quicksort_for_header@1: itob concat // on error: max array length exceeded stores - intc_0 // 1 + intc_1 // 1 + - frame_bury 5 - b test_quicksort_for_header@1 + bury 1 + b test_quicksort_for_header@2 -test_quicksort_after_for@4: +test_quicksort_after_for@5: // tests/artifacts/Arrays/uint64.py:180 // assert rnd.length == 32, "expected array of length 32" - frame_dig 3 + dig 2 dup loads len - intc_1 // 8 + intc_0 // 8 / dup pushint 32 // 32 @@ -1662,7 +1494,7 @@ test_quicksort_after_for@4: // tests/artifacts/Arrays/uint64.py:182-183 // # sort the array // quicksort_window(rnd, UInt64(0), rnd.length - 1) - intc_0 // 1 + intc_1 // 1 - dig 1 intc_2 // 0 @@ -1672,50 +1504,53 @@ test_quicksort_after_for@4: // # array should now be in ascending order // last = UInt64(0) intc_2 // 0 - frame_bury 2 + bury 5 // tests/artifacts/Arrays/uint64.py:187 // for value in rnd: loads len - intc_1 // 8 + intc_0 // 8 / - frame_bury 0 + bury 6 intc_2 // 0 - frame_bury 1 + bury 5 -test_quicksort_for_header@5: +test_quicksort_for_header@6: // tests/artifacts/Arrays/uint64.py:187 // for value in rnd: - frame_dig 1 - frame_dig 0 + dig 4 + dig 6 < - bz test_quicksort_after_for@8 - frame_dig 3 + bz test_quicksort_after_for@9 + dig 2 loads - frame_dig 1 + dig 5 dup cover 2 - intc_1 // 8 + intc_0 // 8 * extract_uint64 // tests/artifacts/Arrays/uint64.py:188 // assert value >= last, "array is not sorted" dup - frame_dig 2 + dig 6 >= assert // array is not sorted swap - intc_0 // 1 + intc_1 // 1 + - frame_bury 1 - frame_bury 2 - b test_quicksort_for_header@5 + bury 6 + bury 4 + b test_quicksort_for_header@6 -test_quicksort_after_for@8: - retsub +test_quicksort_after_for@9: + // tests/artifacts/Arrays/uint64.py:174 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.uint64.Contract.test_unobserved_write() -> void: +// tests.artifacts.Arrays.uint64.Contract.test_unobserved_write[routing]() -> void: test_unobserved_write: // tests/artifacts/Arrays/uint64.py:193 // arr = create_array() @@ -1726,21 +1561,21 @@ test_unobserved_write: loads dup len - intc_1 // 8 + intc_0 // 8 / - intc_0 // 1 + intc_1 // 1 - // tests/artifacts/Arrays/uint64.py:195 // arr[last] = UInt64(0) # write intc_2 // 0 itob swap - intc_1 // 8 + intc_0 // 8 * uncover 2 dig 1 uncover 3 - replace3 + replace3 // on error: index access is out of bounds dig 2 swap stores @@ -1750,13 +1585,13 @@ test_unobserved_write: callsub assert_last_is_zero // tests/artifacts/Arrays/uint64.py:197 // arr[last] = UInt64(1) # write - intc_0 // 1 + intc_1 // 1 itob dig 2 loads dig 2 uncover 2 - replace3 + replace3 // on error: index access is out of bounds uncover 2 dig 1 stores @@ -1764,10 +1599,11 @@ test_unobserved_write: // assert arr[last] == 1 swap extract_uint64 - intc_0 // 1 + intc_1 // 1 == - assert - retsub + // tests/artifacts/Arrays/uint64.py:191 + // @arc4.abimethod() + return // _puya_lib.mem.new_slot() -> uint64: diff --git a/tests/artifacts/Arrays/data/Contract.arc32.json b/tests/artifacts/Arrays/data/Contract.arc32.json index 0493e55..e99e0e3 100644 --- a/tests/artifacts/Arrays/data/Contract.arc32.json +++ b/tests/artifacts/Arrays/data/Contract.arc32.json @@ -62,7 +62,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 8 0 5 512
    bytecblock 0x 0x000000000000000100000000000000020000000000000003 0x0000000000000000 0x0000000000000004
    pushbytes 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    store 0
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@17
    pushbytess 0xa33be873 0xe0c378e9 0x366f509d 0x58351a50 0xfa99e984 0xa20e440f 0x179ac3f9 0x45dcc836 0xf17f6f0a 0x845e1b4e 0x7621cfd1 0x5661a67c // method "test_array()void", method "test_array_extend()void", method "test_array_multiple_append()void", method "overhead()void", method "test_array_too_long()void", method "test_array_copy_and_extend()void", method "test_array_evaluation_order()void", method "test_array_assignment_maximum_cursage()void", method "test_allocations(uint64)void", method "test_iteration()void", method "test_quicksort()void", method "test_unobserved_write()void"
    txna ApplicationArgs 0
    match main_test_array_route@3 main_test_array_extend_route@4 main_test_array_multiple_append_route@5 main_overhead_route@6 main_test_array_too_long_route@7 main_test_array_copy_and_extend_route@8 main_test_array_evaluation_order_route@9 main_test_array_assignment_maximum_cursage_route@10 main_test_allocations_route@11 main_test_iteration_route@12 main_test_quicksort_route@13 main_test_unobserved_write_route@14

main_after_if_else@21:
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    intc_2 // 0
    return

main_test_unobserved_write_route@14:
    // tests/artifacts/Arrays/uint64.py:191
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_unobserved_write
    intc_0 // 1
    return

main_test_quicksort_route@13:
    // tests/artifacts/Arrays/uint64.py:174
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_quicksort
    intc_0 // 1
    return

main_test_iteration_route@12:
    // tests/artifacts/Arrays/uint64.py:140
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_iteration
    intc_0 // 1
    return

main_test_allocations_route@11:
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    callsub test_allocations
    intc_0 // 1
    return

main_test_array_assignment_maximum_cursage_route@10:
    // tests/artifacts/Arrays/uint64.py:125
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_assignment_maximum_cursage
    intc_0 // 1
    return

main_test_array_evaluation_order_route@9:
    // tests/artifacts/Arrays/uint64.py:106
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_evaluation_order
    intc_0 // 1
    return

main_test_array_copy_and_extend_route@8:
    // tests/artifacts/Arrays/uint64.py:84
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_copy_and_extend
    intc_0 // 1
    return

main_test_array_too_long_route@7:
    // tests/artifacts/Arrays/uint64.py:75
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_too_long
    intc_0 // 1
    return

main_overhead_route@6:
    // tests/artifacts/Arrays/uint64.py:71
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    intc_0 // 1
    return

main_test_array_multiple_append_route@5:
    // tests/artifacts/Arrays/uint64.py:62
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_multiple_append
    intc_0 // 1
    return

main_test_array_extend_route@4:
    // tests/artifacts/Arrays/uint64.py:50
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_extend
    intc_0 // 1
    return

main_test_array_route@3:
    // tests/artifacts/Arrays/uint64.py:14
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array
    intc_0 // 1
    return

main_bare_routing@17:
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@21
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.Arrays.uint64.quicksort_window(arr: uint64, window_left: uint64, window_right: uint64) -> void:
quicksort_window:
    // tests/artifacts/Arrays/uint64.py:201-204
    // @subroutine
    // def quicksort_window(
    //     arr: ReferenceArray[UInt64], window_left: UInt64, window_right: UInt64
    // ) -> None:
    proto 3 0
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/uint64.py:207
    // pivot = arr[(window_left + window_right) // 2]
    frame_dig -2
    frame_dig -1
    +
    pushint 2 // 2
    /
    frame_dig -3
    loads
    swap
    intc_1 // 8
    *
    extract_uint64
    frame_dig -1
    frame_dig -2

quicksort_window_while_top@3:
    // tests/artifacts/Arrays/uint64.py:211-212
    // # move left of window towards pivot
    // while arr[left] < pivot:
    frame_dig -3
    loads
    frame_dig 5
    intc_1 // 8
    *
    dup
    frame_bury 0
    extract_uint64
    frame_dig 3
    <
    bz quicksort_window_while_top@6
    // tests/artifacts/Arrays/uint64.py:213
    // left += 1
    frame_dig 5
    intc_0 // 1
    +
    frame_bury 5
    b quicksort_window_while_top@3

quicksort_window_while_top@6:
    // tests/artifacts/Arrays/uint64.py:214-215
    // # move right of window towards pivot
    // while pivot < arr[right]:
    frame_dig -3
    loads
    frame_dig 4
    intc_1 // 8
    *
    dup
    frame_bury 1
    extract_uint64
    frame_dig 3
    >
    bz quicksort_window_after_while@10
    // tests/artifacts/Arrays/uint64.py:216-217
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 4
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:219
    // right -= 1
    frame_dig 4
    intc_0 // 1
    -
    frame_bury 4
    b quicksort_window_while_top@6

quicksort_window_after_while@22:
    // tests/artifacts/Arrays/uint64.py:247-248
    // # sort left half of window
    // if window_left < right:
    frame_dig -2
    frame_dig 4
    <
    bz quicksort_window_after_if_else@24
    // tests/artifacts/Arrays/uint64.py:249
    // quicksort_window(arr, window_left, right)
    frame_dig -3
    frame_dig -2
    frame_dig 4
    callsub quicksort_window

quicksort_window_after_if_else@24:
    // tests/artifacts/Arrays/uint64.py:250-251
    // # sort right half of window
    // if left < window_right:
    frame_dig 5
    frame_dig -1
    <
    bz quicksort_window_after_if_else@26
    // tests/artifacts/Arrays/uint64.py:252
    // quicksort_window(arr, left, window_right)
    frame_dig -3
    frame_dig 5
    frame_dig -1
    callsub quicksort_window

quicksort_window_after_if_else@26:
    retsub

quicksort_window_after_while@10:
    // tests/artifacts/Arrays/uint64.py:221-222
    // # if window isn't empty then swap values and move window in
    // if left < right:
    frame_dig 5
    frame_dig 4
    <
    bz quicksort_window_after_if_else@16
    // tests/artifacts/Arrays/uint64.py:223
    // arr[left], arr[right] = arr[right], arr[left]
    frame_dig -3
    loads
    dup
    frame_dig 1
    dup
    cover 3
    intc_1 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    frame_dig 0
    dup
    cover 3
    intc_1 // 8
    extract3 // on error: index access is out of bounds
    cover 3
    replace3
    cover 2
    replace3
    frame_dig -3
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:224
    // left += 1
    frame_dig 5
    intc_0 // 1
    +
    frame_bury 5
    // tests/artifacts/Arrays/uint64.py:225-226
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 4
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:228
    // right -= 1
    frame_dig 4
    intc_0 // 1
    -
    dup
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:229-230
    // # explicit continue to avoid hitting outer break
    // if left <= right:
    frame_dig 5
    >=
    bnz quicksort_window_while_top@3
    b quicksort_window_after_while@22

quicksort_window_after_if_else@16:
    // tests/artifacts/Arrays/uint64.py:235-236
    // # if window is just one item, don't bother swapping, but still adjust window
    // if left == right:
    frame_dig 5
    frame_dig 4
    ==
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:237
    // left += 1
    frame_dig 5
    intc_0 // 1
    +
    frame_bury 5
    frame_dig 4
    dup
    frame_bury 2
    // tests/artifacts/Arrays/uint64.py:238-239
    // # don't decrement right if it would go negative
    // if right:
    bz quicksort_window_after_if_else@19
    // tests/artifacts/Arrays/uint64.py:240
    // right -= 1
    frame_dig 4
    intc_0 // 1
    -
    frame_bury 2

quicksort_window_after_if_else@19:
    frame_dig 2
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:241-243
    // # loop always ends in this scenario
    // # and an explict break consumes fewer ops
    // break
    b quicksort_window_after_while@22


// tests.artifacts.Arrays.uint64.create_array() -> uint64:
create_array:
    // tests/artifacts/Arrays/uint64.py:255-256
    // @subroutine(inline=False)
    // def create_array() -> ReferenceArray[UInt64]:
    proto 0 1
    // tests/artifacts/Arrays/uint64.py:257
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_2 // 0

create_array_for_header@1:
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    frame_dig 1
    intc_3 // 5
    <
    bz create_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:259
    // arr.append(i)
    frame_dig 0
    dup
    loads
    frame_dig 1
    dup
    cover 3
    itob
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_0 // 1
    +
    frame_bury 1
    b create_array_for_header@1

create_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:260
    // return arr
    retsub


// tests.artifacts.Arrays.uint64.assert_last_is_zero(arr: uint64) -> void:
assert_last_is_zero:
    // tests/artifacts/Arrays/uint64.py:263-264
    // @subroutine(inline=False)
    // def assert_last_is_zero(arr: ReferenceArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/uint64.py:265
    // assert arr[arr.length - 1] == 0
    frame_dig -1
    loads
    dup
    len
    intc_1 // 8
    /
    intc_0 // 1
    -
    intc_1 // 8
    *
    extract_uint64
    !
    assert
    retsub


// tests.artifacts.Arrays.uint64.add_x(arr: uint64, x: uint64) -> void:
add_x:
    // tests/artifacts/Arrays/uint64.py:277-278
    // @subroutine
    // def add_x(arr: ReferenceArray[UInt64], x: UInt64) -> None:
    proto 2 0
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_2 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/uint64.py:280
    // arr.append(i)
    frame_dig -2
    loads
    frame_dig 0
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_dig -2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_0 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    retsub


// tests.artifacts.Arrays.uint64.append_length_and_return(arr: uint64) -> uint64:
append_length_and_return:
    // tests/artifacts/Arrays/uint64.py:291-292
    // @subroutine
    // def append_length_and_return(arr: ReferenceArray[UInt64]) -> ReferenceArray[UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/uint64.py:293
    // arr.append(arr.length)
    frame_dig -1
    loads
    dup
    len
    intc_1 // 8
    /
    itob
    concat // on error: max array length exceeded
    frame_dig -1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:294
    // return arr
    frame_dig -1
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array() -> void:
test_array:
    // tests/artifacts/Arrays/uint64.py:14-15
    // @arc4.abimethod()
    // def test_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/uint64.py:16
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    // tests/artifacts/Arrays/uint64.py:19
    // arr.append(UInt64(42))
    pushint 42 // 42
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:23
    // add_x(arr, UInt64(5))
    dup
    intc_3 // 5
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:24
    // assert arr.length == 6
    loads
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:25
    // assert arr[-1] == 4
    intc_0 // 1
    -
    intc_1 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 4 // 4
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    intc_2 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    frame_dig 2
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 3 // 3
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    <
    bz test_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:286
    // popped = arr.pop()
    frame_dig 0
    dup
    loads
    dup
    len
    dup
    intc_1 // 8
    -
    dig 2
    dig 1
    uncover 3
    substring3
    uncover 2
    intc_2 // 0
    uncover 3
    extract3
    swap
    btoi
    cover 2
    stores
    // tests/artifacts/Arrays/uint64.py:287
    // assert popped == expected
    frame_dig 1
    dup
    cover 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:288
    // expected -= 1
    intc_0 // 1
    -
    frame_bury 1
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    frame_dig 2
    intc_0 // 1
    +
    frame_bury 2
    b test_array_for_header@2

test_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:28
    // assert arr.length == 3
    frame_dig 0
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:29
    // assert arr[-1] == 1
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:31
    // arr.append(UInt64(43))
    pushint 43 // 43
    itob
    concat // on error: max array length exceeded
    dup2
    stores
    // tests/artifacts/Arrays/uint64.py:32
    // assert arr.length == 4
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:33
    // assert arr[-1] == 43
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 43 // 43
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:34
    // assert arr[0] == 42
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:36
    // add_x(arr, UInt64(10))
    dup
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:37
    // assert arr.length == 14
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:38
    // assert arr[-1] == 9
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:40
    // arr.append(UInt64(44))
    pushint 44 // 44
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:41
    // assert arr.length == 15
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:42
    // assert arr[-1] == 44
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:272
    // arr.append(UInt64(99))
    pushint 99 // 99
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:273
    // arr2.append(UInt64(100))
    pushint 100 // 100
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:44
    // return_ref(arr, arr)[0] += 2
    dup
    intc_2 // 0
    extract_uint64
    pushint 2 // 2
    +
    itob
    replace2 0
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:45
    // assert arr.length == 17
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 17 // 17
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:46
    // assert arr[0] == 44
    dig 1
    intc_2 // 0
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:47
    // assert arr[-2] == 99
    dup
    pushint 2 // 2
    -
    intc_1 // 8
    *
    dig 2
    swap
    extract_uint64
    pushint 99 // 99
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:48
    // assert arr[-1] == 100
    intc_0 // 1
    -
    intc_1 // 8
    *
    extract_uint64
    pushint 100 // 100
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_extend() -> void:
test_array_extend:
    // tests/artifacts/Arrays/uint64.py:52
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:53
    // add_x(arr, UInt64(1))
    dup
    intc_0 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    pop
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    dup
    loads
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:60
    // assert arr.length == 4
    len
    intc_1 // 8
    /
    pushint 4 // 4
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_multiple_append() -> void:
test_array_multiple_append:
    // tests/artifacts/Arrays/uint64.py:64
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:65
    // add_x(arr, UInt64(1))
    dup
    intc_0 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:66
    // arr.append(UInt64(1))
    dup
    loads
    intc_0 // 1
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:67
    // arr.append(UInt64(2))
    pushint 2 // 2
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:68
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:69
    // assert arr.length == 4
    len
    intc_1 // 8
    /
    pushint 4 // 4
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_too_long() -> void:
test_array_too_long:
    // tests/artifacts/Arrays/uint64.py:75-76
    // @arc4.abimethod()
    // def test_array_too_long(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/uint64.py:77
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_2 // 0

test_array_too_long_for_header@1:
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    frame_dig 1
    intc 4 // 512
    <
    bz test_array_too_long_after_for@4
    frame_dig 0
    // tests/artifacts/Arrays/uint64.py:79
    // array.append(i)
    frame_dig 1
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_bury 0
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_0 // 1
    +
    frame_bury 1
    b test_array_too_long_for_header@1

test_array_too_long_after_for@4:
    frame_dig 0
    // tests/artifacts/Arrays/uint64.py:80
    // assert array.length == 512, "array is expected length"
    dup
    len
    intc_1 // 8
    /
    intc 4 // 512
    ==
    assert // array is expected length
    // tests/artifacts/Arrays/uint64.py:82
    // array.append(UInt64(512))  # this will fail
    intc 4 // 512
    itob
    concat // on error: max array length exceeded
    pop
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_copy_and_extend() -> void:
test_array_copy_and_extend:
    // tests/artifacts/Arrays/uint64.py:84-85
    // @arc4.abimethod()
    // def test_array_copy_and_extend(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/uint64.py:86
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_2 // 0

test_array_copy_and_extend_for_header@1:
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    frame_dig 1
    intc_3 // 5
    <
    bz test_array_copy_and_extend_after_for@4
    frame_dig 0
    // tests/artifacts/Arrays/uint64.py:88
    // array.append(i)
    frame_dig 1
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_bury 0
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_0 // 1
    +
    frame_bury 1
    b test_array_copy_and_extend_for_header@1

test_array_copy_and_extend_after_for@4:
    frame_dig 0
    dup
    // tests/artifacts/Arrays/uint64.py:91
    // array.append(UInt64(5))
    intc_3 // 5
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:92
    // assert array.length == 6
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:93
    // assert array[-1] == 5, "expected 5"
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 5
    dig 1
    // tests/artifacts/Arrays/uint64.py:95
    // assert array2.length == 5
    dup
    len
    intc_1 // 8
    /
    dup
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:96
    // assert array2[-1] == 4, "expected 4"
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:98
    // array.extend(array2)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:99
    // assert array.length == 11
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 11 // 11
    ==
    assert
    uncover 2
    // tests/artifacts/Arrays/uint64.py:100
    // assert array2.length == 5
    len
    intc_1 // 8
    /
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:101
    // assert array[-1] == 4, "expected 4"
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:102
    // assert array[4] == 4, "expected 4"
    dup
    pushint 32 // 32
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:103
    // assert array[5] == 5, "expected 4"
    dup
    pushint 40 // 40
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:104
    // assert array[6] == 0, "expected 4"
    pushint 48 // 48
    extract_uint64
    !
    assert // expected 4
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_evaluation_order() -> void:
test_array_evaluation_order:
    // tests/artifacts/Arrays/uint64.py:108
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:109
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:110
    // append_length_and_return(arr).extend(append_length_and_return(arr))
    dup
    callsub append_length_and_return
    dig 1
    callsub append_length_and_return
    loads
    dig 1
    loads
    swap
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:111
    // assert arr.length == 6
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:112
    // assert arr[0] == 3
    dup
    intc_2 // 0
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:113
    // assert arr[1] == 1
    dup
    intc_1 // 8
    extract_uint64
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:114
    // assert arr[2] == 2
    dup
    pushint 16 // 16
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:115
    // assert arr[3] == 3
    dup
    pushint 24 // 24
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:116
    // assert arr[4] == 1
    dup
    pushint 32 // 32
    extract_uint64
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:117
    // assert arr[5] == 2
    pushint 40 // 40
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:119
    // arr[append_length_and_return(arr)[0]] = append_length_and_return(arr)[-1]
    dup
    callsub append_length_and_return
    loads
    dup
    len
    intc_1 // 8
    /
    intc_0 // 1
    -
    intc_1 // 8
    *
    intc_1 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    callsub append_length_and_return
    loads
    intc_2 // 0
    extract_uint64
    dig 2
    loads
    swap
    intc_1 // 8
    *
    uncover 2
    replace3
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:120
    // assert arr.length == 8
    dup
    len
    intc_1 // 8
    /
    intc_1 // 8
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:121
    // assert arr[6] == 6
    dup
    pushint 48 // 48
    extract_uint64
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:122
    // assert arr[7] == 7
    dup
    pushint 56 // 56
    extract_uint64
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:123
    // assert arr[3] == 6
    pushint 24 // 24
    extract_uint64
    pushint 6 // 6
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_assignment_maximum_cursage() -> void:
test_array_assignment_maximum_cursage:
    // tests/artifacts/Arrays/uint64.py:127
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:128
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:129
    // append_length_and_return(arr)[0] = UInt64(42)
    dup
    callsub append_length_and_return
    pushint 42 // 42
    itob
    dig 1
    loads
    swap
    replace2 0
    stores
    // tests/artifacts/Arrays/uint64.py:130
    // assert arr.length == 2
    loads
    dup
    len
    intc_1 // 8
    /
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:131
    // assert arr[0] == 42
    dup
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:132
    // assert arr[1] == 1
    intc_1 // 8
    extract_uint64
    intc_0 // 1
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_allocations(num: uint64) -> void:
test_allocations:
    // tests/artifacts/Arrays/uint64.py:134-135
    // @arc4.abimethod()
    // def test_allocations(self, num: UInt64) -> None:
    proto 1 0
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    intc_2 // 0

test_allocations_for_header@1:
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    frame_dig 0
    frame_dig -1
    <
    bz test_allocations_after_for@4
    // tests/artifacts/Arrays/uint64.py:137
    // alloc_test = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:138
    // add_x(alloc_test, UInt64(1))
    intc_0 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    frame_dig 0
    intc_0 // 1
    +
    frame_bury 0
    b test_allocations_for_header@1

test_allocations_after_for@4:
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_iteration() -> void:
test_iteration:
    // tests/artifacts/Arrays/uint64.py:140-141
    // @arc4.abimethod()
    // def test_iteration(self) -> None:
    proto 0 0
    intc_2 // 0
    dup
    bytec_0 // ""
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    dupn 7
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_2 // 0

test_iteration_for_header@1:
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    frame_dig 10
    intc_3 // 5
    <
    bz test_iteration_after_for@4
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:144
    // arr.append(val)
    frame_dig 10
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_bury 9
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_0 // 1
    +
    frame_bury 10
    b test_iteration_for_header@1

test_iteration_after_for@4:
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:145
    // assert arr.length == 5, "expected array of length 5"
    len
    intc_1 // 8
    /
    dup
    frame_bury 2
    intc_3 // 5
    ==
    assert // expected array of length 5
    // tests/artifacts/Arrays/uint64.py:147-148
    // # iterate
    // last = UInt64(0)
    intc_2 // 0
    frame_bury 7
    intc_2 // 0
    frame_bury 6

test_iteration_for_header@5:
    // tests/artifacts/Arrays/uint64.py:149
    // for value in arr:
    frame_dig 6
    frame_dig 2
    <
    bz test_iteration_after_for@8
    frame_dig 9
    frame_dig 6
    dup
    cover 2
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:150
    // assert value >= last, "array is not sorted"
    dup
    frame_dig 7
    >=
    assert // array is not sorted
    swap
    intc_0 // 1
    +
    frame_bury 6
    frame_bury 7
    b test_iteration_for_header@5

test_iteration_after_for@8:
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    len
    intc_1 // 8
    /
    frame_bury 3
    intc_2 // 0
    frame_bury 5

test_iteration_for_header@9:
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    frame_dig 5
    frame_dig 3
    <
    bz test_iteration_after_for@12
    frame_dig 9
    frame_dig 5
    dup
    cover 2
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:155
    // assert value == idx, "incorrect array value"
    dig 1
    ==
    assert // incorrect array value
    intc_0 // 1
    +
    frame_bury 5
    b test_iteration_for_header@9

test_iteration_after_for@12:
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    len
    intc_1 // 8
    /
    frame_bury 8

test_iteration_for_header@13:
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    frame_dig 8
    bz test_iteration_after_for@16
    frame_dig 8
    intc_0 // 1
    -
    dup
    frame_bury 8
    frame_dig 9
    swap
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:159
    // assert value <= last, "array is not sorted"
    dup
    frame_dig 7
    <=
    assert // array is not sorted
    frame_bury 7
    b test_iteration_for_header@13

test_iteration_after_for@16:
    // tests/artifacts/Arrays/uint64.py:162
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    pushbytes 0x0000
    frame_bury 0
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    bytec_0 // 0x
    frame_bury 1
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_2 // 0
    frame_bury 4

test_iteration_for_header@17:
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    frame_dig 4
    intc_3 // 5
    <
    bz test_iteration_after_for@20
    // tests/artifacts/Arrays/uint64.py:165
    // arc4_arr.append(arc4.UInt64(i))
    frame_dig 4
    dup
    itob
    frame_dig 0
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_2 // 0
    extract_uint16
    intc_0 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    frame_dig 1
    // tests/artifacts/Arrays/uint64.py:166
    // native_arr.append(arc4.UInt64(i))
    swap
    concat // on error: max array length exceeded
    frame_bury 1
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_0 // 1
    +
    frame_bury 4
    b test_iteration_for_header@17

test_iteration_after_for@20:
    // tests/artifacts/Arrays/uint64.py:167
    // combined_arr = arc4_arr + native_arr
    frame_dig 0
    frame_dig 1
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_1 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/uint64.py:168
    // assert combined_arr.length == 10
    dup
    intc_2 // 0
    extract_uint16
    pushint 10 // 10
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:169
    // assert combined_arr[0] == 0
    dup
    extract 2 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:170
    // assert combined_arr[4] == 4
    dup
    extract 34 8
    bytec_3 // 0x0000000000000004
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:171
    // assert combined_arr[5] == 0
    dup
    extract 42 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:172
    // assert combined_arr[9] == 4
    extract 74 8
    bytec_3 // 0x0000000000000004
    b==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_quicksort() -> void:
test_quicksort:
    // tests/artifacts/Arrays/uint64.py:174-175
    // @arc4.abimethod()
    // def test_quicksort(self) -> None:
    proto 0 0
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/uint64.py:176-177
    // # create pseudo random array from sender address
    // rnd = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    txn Sender
    intc_2 // 0

test_quicksort_for_header@1:
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    frame_dig 5
    pushint 32 // 32
    <
    bz test_quicksort_after_for@4
    // tests/artifacts/Arrays/uint64.py:179
    // rnd.append(op.btoi(b))
    frame_dig 4
    frame_dig 5
    dup
    cover 2
    getbyte
    frame_dig 3
    dup
    cover 2
    loads
    swap
    itob
    concat // on error: max array length exceeded
    stores
    intc_0 // 1
    +
    frame_bury 5
    b test_quicksort_for_header@1

test_quicksort_after_for@4:
    // tests/artifacts/Arrays/uint64.py:180
    // assert rnd.length == 32, "expected array of length 32"
    frame_dig 3
    dup
    loads
    len
    intc_1 // 8
    /
    dup
    pushint 32 // 32
    ==
    assert // expected array of length 32
    // tests/artifacts/Arrays/uint64.py:182-183
    // # sort the array
    // quicksort_window(rnd, UInt64(0), rnd.length - 1)
    intc_0 // 1
    -
    dig 1
    intc_2 // 0
    uncover 2
    callsub quicksort_window
    // tests/artifacts/Arrays/uint64.py:185-186
    // # array should now be in ascending order
    // last = UInt64(0)
    intc_2 // 0
    frame_bury 2
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    loads
    len
    intc_1 // 8
    /
    frame_bury 0
    intc_2 // 0
    frame_bury 1

test_quicksort_for_header@5:
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    frame_dig 1
    frame_dig 0
    <
    bz test_quicksort_after_for@8
    frame_dig 3
    loads
    frame_dig 1
    dup
    cover 2
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:188
    // assert value >= last, "array is not sorted"
    dup
    frame_dig 2
    >=
    assert // array is not sorted
    swap
    intc_0 // 1
    +
    frame_bury 1
    frame_bury 2
    b test_quicksort_for_header@5

test_quicksort_after_for@8:
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_unobserved_write() -> void:
test_unobserved_write:
    // tests/artifacts/Arrays/uint64.py:193
    // arr = create_array()
    callsub create_array
    // tests/artifacts/Arrays/uint64.py:194
    // last = arr.length - 1
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    intc_0 // 1
    -
    // tests/artifacts/Arrays/uint64.py:195
    // arr[last] = UInt64(0)  # write
    intc_2 // 0
    itob
    swap
    intc_1 // 8
    *
    uncover 2
    dig 1
    uncover 3
    replace3
    dig 2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:196
    // assert_last_is_zero(arr)
    dig 1
    callsub assert_last_is_zero
    // tests/artifacts/Arrays/uint64.py:197
    // arr[last] = UInt64(1)  # write
    intc_0 // 1
    itob
    dig 2
    loads
    dig 2
    uncover 2
    replace3
    uncover 2
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:198
    // assert arr[last] == 1
    swap
    extract_uint64
    intc_0 // 1
    ==
    assert
    retsub


// _puya_lib.mem.new_slot() -> uint64:
_puya_lib.mem.new_slot:
    load 0
    bitlen
    load 0
    pushint 256 // 256
    dig 2
    -
    intc_2 // 0
    setbit // on error: no available slots
    store 0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 8 1 0 5 512
    bytecblock 0x 0x000000000000000100000000000000020000000000000003 0x0000000000000000 0x0000000000000004
    pushbytes 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    store 0
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@19
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xa33be873 0xe0c378e9 0x366f509d 0x58351a50 0xfa99e984 0xa20e440f 0x179ac3f9 0x45dcc836 0xf17f6f0a 0x845e1b4e 0x7621cfd1 0x5661a67c // method "test_array()void", method "test_array_extend()void", method "test_array_multiple_append()void", method "overhead()void", method "test_array_too_long()void", method "test_array_copy_and_extend()void", method "test_array_evaluation_order()void", method "test_array_assignment_maximum_cursage()void", method "test_allocations(uint64)void", method "test_iteration()void", method "test_quicksort()void", method "test_unobserved_write()void"
    txna ApplicationArgs 0
    match test_array test_array_extend test_array_multiple_append main_overhead_route@7 test_array_too_long test_array_copy_and_extend test_array_evaluation_order test_array_assignment_maximum_cursage test_allocations test_iteration test_quicksort test_unobserved_write
    err

main_overhead_route@7:
    // tests/artifacts/Arrays/uint64.py:71
    // @arc4.abimethod()
    intc_1 // 1
    return

main___algopy_default_create@19:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.Arrays.uint64.quicksort_window(arr: uint64, window_left: uint64, window_right: uint64) -> void:
quicksort_window:
    // tests/artifacts/Arrays/uint64.py:201-204
    // @subroutine
    // def quicksort_window(
    //     arr: ReferenceArray[UInt64], window_left: UInt64, window_right: UInt64
    // ) -> None:
    proto 3 0
    bytec_0 // ""
    dup
    // tests/artifacts/Arrays/uint64.py:207
    // pivot = arr[(window_left + window_right) // 2]
    frame_dig -2
    frame_dig -1
    +
    pushint 2 // 2
    /
    frame_dig -3
    loads
    swap
    intc_0 // 8
    *
    extract_uint64
    frame_dig -1
    frame_dig -2

quicksort_window_while_top@3:
    // tests/artifacts/Arrays/uint64.py:211-212
    // # move left of window towards pivot
    // while arr[left] < pivot:
    frame_dig -3
    loads
    frame_dig 4
    intc_0 // 8
    *
    dup
    frame_bury 0
    extract_uint64
    frame_dig 2
    <
    bz quicksort_window_while_top@6
    // tests/artifacts/Arrays/uint64.py:213
    // left += 1
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    b quicksort_window_while_top@3

quicksort_window_while_top@6:
    // tests/artifacts/Arrays/uint64.py:214-215
    // # move right of window towards pivot
    // while pivot < arr[right]:
    frame_dig -3
    loads
    frame_dig 3
    intc_0 // 8
    *
    dup
    frame_bury 1
    extract_uint64
    frame_dig 2
    >
    bz quicksort_window_after_while@10
    // tests/artifacts/Arrays/uint64.py:216-217
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 3
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:219
    // right -= 1
    frame_dig 3
    intc_1 // 1
    -
    frame_bury 3
    b quicksort_window_while_top@6

quicksort_window_after_while@22:
    // tests/artifacts/Arrays/uint64.py:247-248
    // # sort left half of window
    // if window_left < right:
    frame_dig -2
    frame_dig 3
    <
    bz quicksort_window_after_if_else@24
    // tests/artifacts/Arrays/uint64.py:249
    // quicksort_window(arr, window_left, right)
    frame_dig -3
    frame_dig -2
    frame_dig 3
    callsub quicksort_window

quicksort_window_after_if_else@24:
    // tests/artifacts/Arrays/uint64.py:250-251
    // # sort right half of window
    // if left < window_right:
    frame_dig 4
    frame_dig -1
    <
    bz quicksort_window_after_if_else@26
    // tests/artifacts/Arrays/uint64.py:252
    // quicksort_window(arr, left, window_right)
    frame_dig -3
    frame_dig 4
    frame_dig -1
    callsub quicksort_window

quicksort_window_after_if_else@26:
    retsub

quicksort_window_after_while@10:
    // tests/artifacts/Arrays/uint64.py:221-222
    // # if window isn't empty then swap values and move window in
    // if left < right:
    frame_dig 4
    frame_dig 3
    <
    bz quicksort_window_after_if_else@16
    // tests/artifacts/Arrays/uint64.py:223
    // arr[left], arr[right] = arr[right], arr[left]
    frame_dig -3
    loads
    dup
    frame_dig 1
    dup
    cover 3
    intc_0 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    frame_dig 0
    dup
    cover 3
    intc_0 // 8
    extract3 // on error: index access is out of bounds
    cover 3
    replace3 // on error: index access is out of bounds
    cover 2
    replace3 // on error: index access is out of bounds
    frame_dig -3
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:224
    // left += 1
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:225-226
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 3
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:228
    // right -= 1
    frame_dig 3
    intc_1 // 1
    -
    dup
    frame_bury 3
    // tests/artifacts/Arrays/uint64.py:229-230
    // # explicit continue to avoid hitting outer break
    // if left <= right:
    frame_dig 4
    >=
    bnz quicksort_window_while_top@3
    b quicksort_window_after_while@22

quicksort_window_after_if_else@16:
    // tests/artifacts/Arrays/uint64.py:235-236
    // # if window is just one item, don't bother swapping, but still adjust window
    // if left == right:
    frame_dig 4
    frame_dig 3
    ==
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:237
    // left += 1
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:238-239
    // # don't decrement right if it would go negative
    // if right:
    frame_dig 3
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:240
    // right -= 1
    frame_dig 3
    intc_1 // 1
    -
    frame_bury 3
    b quicksort_window_after_while@22


// tests.artifacts.Arrays.uint64.create_array() -> uint64:
create_array:
    // tests/artifacts/Arrays/uint64.py:255-256
    // @subroutine(inline=False)
    // def create_array() -> ReferenceArray[UInt64]:
    proto 0 1
    // tests/artifacts/Arrays/uint64.py:257
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_2 // 0

create_array_for_header@1:
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    frame_dig 1
    intc_3 // 5
    <
    bz create_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:259
    // arr.append(i)
    frame_dig 0
    dup
    loads
    frame_dig 1
    dup
    cover 3
    itob
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_1 // 1
    +
    frame_bury 1
    b create_array_for_header@1

create_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:260
    // return arr
    retsub


// tests.artifacts.Arrays.uint64.assert_last_is_zero(arr: uint64) -> void:
assert_last_is_zero:
    // tests/artifacts/Arrays/uint64.py:263-264
    // @subroutine(inline=False)
    // def assert_last_is_zero(arr: ReferenceArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/uint64.py:265
    // assert arr[arr.length - 1] == 0
    frame_dig -1
    loads
    dup
    len
    intc_0 // 8
    /
    intc_1 // 1
    -
    intc_0 // 8
    *
    extract_uint64
    !
    assert
    retsub


// tests.artifacts.Arrays.uint64.add_x(arr: uint64, x: uint64) -> void:
add_x:
    // tests/artifacts/Arrays/uint64.py:277-278
    // @subroutine
    // def add_x(arr: ReferenceArray[UInt64], x: UInt64) -> None:
    proto 2 0
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_2 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/uint64.py:280
    // arr.append(i)
    frame_dig -2
    loads
    frame_dig 0
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_dig -2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    retsub


// tests.artifacts.Arrays.uint64.append_length_and_return(arr: uint64) -> uint64:
append_length_and_return:
    // tests/artifacts/Arrays/uint64.py:291-292
    // @subroutine
    // def append_length_and_return(arr: ReferenceArray[UInt64]) -> ReferenceArray[UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/uint64.py:293
    // arr.append(arr.length)
    frame_dig -1
    loads
    dup
    len
    intc_0 // 8
    /
    itob
    concat // on error: max array length exceeded
    frame_dig -1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:294
    // return arr
    frame_dig -1
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array[routing]() -> void:
test_array:
    // tests/artifacts/Arrays/uint64.py:16
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    // tests/artifacts/Arrays/uint64.py:19
    // arr.append(UInt64(42))
    pushint 42 // 42
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:23
    // add_x(arr, UInt64(5))
    dup
    intc_3 // 5
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:24
    // assert arr.length == 6
    loads
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:25
    // assert arr[-1] == 4
    intc_1 // 1
    -
    intc_0 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 4 // 4
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    intc_2 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    dup
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 3 // 3
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    <
    bz test_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:286
    // popped = arr.pop()
    dig 2
    dup
    loads
    dup
    len
    dup
    intc_0 // 8
    -
    dig 2
    intc_2 // 0
    dig 2
    extract3
    uncover 3
    uncover 2
    uncover 3
    substring3
    btoi
    cover 2
    stores
    // tests/artifacts/Arrays/uint64.py:287
    // assert popped == expected
    dig 2
    dup
    cover 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:288
    // expected -= 1
    intc_1 // 1
    -
    bury 2
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    dup
    intc_1 // 1
    +
    bury 1
    b test_array_for_header@2

test_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:28
    // assert arr.length == 3
    dig 2
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:29
    // assert arr[-1] == 1
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:31
    // arr.append(UInt64(43))
    pushint 43 // 43
    itob
    concat // on error: max array length exceeded
    dup2
    stores
    // tests/artifacts/Arrays/uint64.py:32
    // assert arr.length == 4
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:33
    // assert arr[-1] == 43
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 43 // 43
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:34
    // assert arr[0] == 42
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:36
    // add_x(arr, UInt64(10))
    dup
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:37
    // assert arr.length == 14
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:38
    // assert arr[-1] == 9
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:40
    // arr.append(UInt64(44))
    pushint 44 // 44
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:41
    // assert arr.length == 15
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:42
    // assert arr[-1] == 44
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:272
    // arr.append(UInt64(99))
    pushint 99 // 99
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:273
    // arr2.append(UInt64(100))
    pushint 100 // 100
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:44
    // return_ref(arr, arr)[0] += 2
    dup
    intc_2 // 0
    extract_uint64
    pushint 2 // 2
    +
    itob
    replace2 0 // on error: index access is out of bounds
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:45
    // assert arr.length == 17
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 17 // 17
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:46
    // assert arr[0] == 44
    dig 1
    intc_2 // 0
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:47
    // assert arr[-2] == 99
    dup
    pushint 2 // 2
    -
    intc_0 // 8
    *
    dig 2
    swap
    extract_uint64
    pushint 99 // 99
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:48
    // assert arr[-1] == 100
    intc_1 // 1
    -
    intc_0 // 8
    *
    extract_uint64
    pushint 100 // 100
    ==
    // tests/artifacts/Arrays/uint64.py:14
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_extend[routing]() -> void:
test_array_extend:
    // tests/artifacts/Arrays/uint64.py:52
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:53
    // add_x(arr, UInt64(1))
    dup
    intc_1 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    pop
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    dup
    loads
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:60
    // assert arr.length == 4
    len
    intc_0 // 8
    /
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/uint64.py:50
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_multiple_append[routing]() -> void:
test_array_multiple_append:
    // tests/artifacts/Arrays/uint64.py:64
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:65
    // add_x(arr, UInt64(1))
    dup
    intc_1 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:66
    // arr.append(UInt64(1))
    dup
    loads
    intc_1 // 1
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:67
    // arr.append(UInt64(2))
    pushint 2 // 2
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:68
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:69
    // assert arr.length == 4
    len
    intc_0 // 8
    /
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/uint64.py:62
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_too_long[routing]() -> void:
test_array_too_long:
    // tests/artifacts/Arrays/uint64.py:77
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_2 // 0

test_array_too_long_for_header@2:
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    dup
    intc 4 // 512
    <
    bz test_array_too_long_after_for@5
    // tests/artifacts/Arrays/uint64.py:79
    // array.append(i)
    dup2
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_1 // 1
    +
    bury 1
    b test_array_too_long_for_header@2

test_array_too_long_after_for@5:
    dig 1
    // tests/artifacts/Arrays/uint64.py:80
    // assert array.length == 512, "array is expected length"
    dup
    len
    intc_0 // 8
    /
    intc 4 // 512
    ==
    assert // array is expected length
    // tests/artifacts/Arrays/uint64.py:82
    // array.append(UInt64(512))  # this will fail
    intc 4 // 512
    itob
    concat // on error: max array length exceeded
    pop
    // tests/artifacts/Arrays/uint64.py:75
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_copy_and_extend[routing]() -> void:
test_array_copy_and_extend:
    // tests/artifacts/Arrays/uint64.py:86
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_2 // 0

test_array_copy_and_extend_for_header@2:
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    dup
    intc_3 // 5
    <
    bz test_array_copy_and_extend_after_for@5
    // tests/artifacts/Arrays/uint64.py:88
    // array.append(i)
    dup2
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_1 // 1
    +
    bury 1
    b test_array_copy_and_extend_for_header@2

test_array_copy_and_extend_after_for@5:
    dig 1
    dup
    // tests/artifacts/Arrays/uint64.py:91
    // array.append(UInt64(5))
    intc_3 // 5
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:92
    // assert array.length == 6
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:93
    // assert array[-1] == 5, "expected 5"
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 5
    dig 1
    // tests/artifacts/Arrays/uint64.py:95
    // assert array2.length == 5
    dup
    len
    intc_0 // 8
    /
    dup
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:96
    // assert array2[-1] == 4, "expected 4"
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:98
    // array.extend(array2)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:99
    // assert array.length == 11
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 11 // 11
    ==
    assert
    uncover 2
    // tests/artifacts/Arrays/uint64.py:100
    // assert array2.length == 5
    len
    intc_0 // 8
    /
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:101
    // assert array[-1] == 4, "expected 4"
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:102
    // assert array[4] == 4, "expected 4"
    dup
    pushint 32 // 32
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:103
    // assert array[5] == 5, "expected 4"
    dup
    pushint 40 // 40
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:104
    // assert array[6] == 0, "expected 4"
    pushint 48 // 48
    extract_uint64
    !
    // tests/artifacts/Arrays/uint64.py:84
    // @arc4.abimethod()
    return // on error: expected 4


// tests.artifacts.Arrays.uint64.Contract.test_array_evaluation_order[routing]() -> void:
test_array_evaluation_order:
    // tests/artifacts/Arrays/uint64.py:108
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:109
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:110
    // append_length_and_return(arr).extend(append_length_and_return(arr))
    dup
    callsub append_length_and_return
    dig 1
    callsub append_length_and_return
    loads
    dig 1
    loads
    swap
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:111
    // assert arr.length == 6
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:112
    // assert arr[0] == 3
    dup
    intc_2 // 0
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:113
    // assert arr[1] == 1
    dup
    intc_0 // 8
    extract_uint64
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:114
    // assert arr[2] == 2
    dup
    pushint 16 // 16
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:115
    // assert arr[3] == 3
    dup
    pushint 24 // 24
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:116
    // assert arr[4] == 1
    dup
    pushint 32 // 32
    extract_uint64
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:117
    // assert arr[5] == 2
    pushint 40 // 40
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:119
    // arr[append_length_and_return(arr)[0]] = append_length_and_return(arr)[-1]
    dup
    callsub append_length_and_return
    loads
    dup
    len
    intc_0 // 8
    /
    intc_1 // 1
    -
    intc_0 // 8
    *
    intc_0 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    callsub append_length_and_return
    loads
    intc_2 // 0
    extract_uint64
    dig 2
    loads
    swap
    intc_0 // 8
    *
    uncover 2
    replace3 // on error: index access is out of bounds
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:120
    // assert arr.length == 8
    dup
    len
    intc_0 // 8
    /
    intc_0 // 8
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:121
    // assert arr[6] == 6
    dup
    pushint 48 // 48
    extract_uint64
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:122
    // assert arr[7] == 7
    dup
    pushint 56 // 56
    extract_uint64
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:123
    // assert arr[3] == 6
    pushint 24 // 24
    extract_uint64
    pushint 6 // 6
    ==
    // tests/artifacts/Arrays/uint64.py:106
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_assignment_maximum_cursage[routing]() -> void:
test_array_assignment_maximum_cursage:
    // tests/artifacts/Arrays/uint64.py:127
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:128
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:129
    // append_length_and_return(arr)[0] = UInt64(42)
    dup
    callsub append_length_and_return
    pushint 42 // 42
    itob
    dig 1
    loads
    swap
    replace2 0 // on error: index access is out of bounds
    stores
    // tests/artifacts/Arrays/uint64.py:130
    // assert arr.length == 2
    loads
    dup
    len
    intc_0 // 8
    /
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:131
    // assert arr[0] == 42
    dup
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:132
    // assert arr[1] == 1
    intc_0 // 8
    extract_uint64
    intc_1 // 1
    ==
    // tests/artifacts/Arrays/uint64.py:125
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_allocations[routing]() -> void:
test_allocations:
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    intc_2 // 0

test_allocations_for_header@2:
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    dup
    dig 2
    <
    bz test_allocations_after_for@5
    // tests/artifacts/Arrays/uint64.py:137
    // alloc_test = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:138
    // add_x(alloc_test, UInt64(1))
    intc_1 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    dup
    intc_1 // 1
    +
    bury 1
    b test_allocations_for_header@2

test_allocations_after_for@5:
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.uint64.Contract.test_iteration[routing]() -> void:
test_iteration:
    intc_2 // 0
    dup
    bytec_0 // ""
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    dupn 7
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_2 // 0

test_iteration_for_header@2:
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    dup
    intc_3 // 5
    <
    bz test_iteration_after_for@5
    // tests/artifacts/Arrays/uint64.py:144
    // arr.append(val)
    dup2
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_1 // 1
    +
    bury 1
    b test_iteration_for_header@2

test_iteration_after_for@5:
    dig 1
    // tests/artifacts/Arrays/uint64.py:145
    // assert arr.length == 5, "expected array of length 5"
    len
    intc_0 // 8
    /
    dup
    bury 10
    intc_3 // 5
    ==
    assert // expected array of length 5
    // tests/artifacts/Arrays/uint64.py:147-148
    // # iterate
    // last = UInt64(0)
    intc_2 // 0
    bury 4
    intc_2 // 0
    bury 5

test_iteration_for_header@6:
    // tests/artifacts/Arrays/uint64.py:149
    // for value in arr:
    dig 4
    dig 9
    <
    bz test_iteration_after_for@9
    dig 1
    dig 5
    dup
    cover 2
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:150
    // assert value >= last, "array is not sorted"
    dup
    dig 6
    >=
    assert // array is not sorted
    swap
    intc_1 // 1
    +
    bury 6
    bury 4
    b test_iteration_for_header@6

test_iteration_after_for@9:
    dig 1
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    len
    intc_0 // 8
    /
    bury 8
    intc_2 // 0
    bury 6

test_iteration_for_header@10:
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    dig 5
    dig 8
    <
    bz test_iteration_after_for@13
    dig 1
    dig 6
    dup
    cover 2
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:155
    // assert value == idx, "incorrect array value"
    dig 1
    ==
    assert // incorrect array value
    intc_1 // 1
    +
    bury 6
    b test_iteration_for_header@10

test_iteration_after_for@13:
    dig 1
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    len
    intc_0 // 8
    /
    bury 3

test_iteration_for_header@14:
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    dig 2
    bz test_iteration_after_for@17
    dig 2
    intc_1 // 1
    -
    dup
    bury 4
    dig 2
    swap
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:159
    // assert value <= last, "array is not sorted"
    dup
    dig 5
    <=
    assert // array is not sorted
    bury 4
    b test_iteration_for_header@14

test_iteration_after_for@17:
    // tests/artifacts/Arrays/uint64.py:162
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    pushbytes 0x0000
    bury 11
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    bytec_0 // 0x
    bury 10
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_2 // 0
    bury 7

test_iteration_for_header@18:
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    dig 6
    intc_3 // 5
    <
    bz test_iteration_after_for@21
    // tests/artifacts/Arrays/uint64.py:165
    // arc4_arr.append(arc4.UInt64(i))
    dig 6
    dup
    itob
    dig 12
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_2 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 13
    dig 11
    // tests/artifacts/Arrays/uint64.py:166
    // native_arr.append(arc4.UInt64(i))
    swap
    concat // on error: max array length exceeded
    bury 11
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_1 // 1
    +
    bury 7
    b test_iteration_for_header@18

test_iteration_after_for@21:
    // tests/artifacts/Arrays/uint64.py:167
    // combined_arr = arc4_arr + native_arr
    dig 10
    dig 10
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_0 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/uint64.py:168
    // assert combined_arr.length == 10
    dup
    intc_2 // 0
    extract_uint16
    pushint 10 // 10
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:169
    // assert combined_arr[0] == 0
    dup
    extract 2 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:170
    // assert combined_arr[4] == 4
    dup
    extract 34 8
    bytec_3 // 0x0000000000000004
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:171
    // assert combined_arr[5] == 0
    dup
    extract 42 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:172
    // assert combined_arr[9] == 4
    extract 74 8
    bytec_3 // 0x0000000000000004
    b==
    // tests/artifacts/Arrays/uint64.py:140
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_quicksort[routing]() -> void:
test_quicksort:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/uint64.py:176-177
    // # create pseudo random array from sender address
    // rnd = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    txn Sender
    intc_2 // 0

test_quicksort_for_header@2:
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    dup
    pushint 32 // 32
    <
    bz test_quicksort_after_for@5
    // tests/artifacts/Arrays/uint64.py:179
    // rnd.append(op.btoi(b))
    dup2
    dup
    cover 2
    getbyte
    dig 4
    dup
    cover 2
    loads
    swap
    itob
    concat // on error: max array length exceeded
    stores
    intc_1 // 1
    +
    bury 1
    b test_quicksort_for_header@2

test_quicksort_after_for@5:
    // tests/artifacts/Arrays/uint64.py:180
    // assert rnd.length == 32, "expected array of length 32"
    dig 2
    dup
    loads
    len
    intc_0 // 8
    /
    dup
    pushint 32 // 32
    ==
    assert // expected array of length 32
    // tests/artifacts/Arrays/uint64.py:182-183
    // # sort the array
    // quicksort_window(rnd, UInt64(0), rnd.length - 1)
    intc_1 // 1
    -
    dig 1
    intc_2 // 0
    uncover 2
    callsub quicksort_window
    // tests/artifacts/Arrays/uint64.py:185-186
    // # array should now be in ascending order
    // last = UInt64(0)
    intc_2 // 0
    bury 5
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    loads
    len
    intc_0 // 8
    /
    bury 6
    intc_2 // 0
    bury 5

test_quicksort_for_header@6:
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    dig 4
    dig 6
    <
    bz test_quicksort_after_for@9
    dig 2
    loads
    dig 5
    dup
    cover 2
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:188
    // assert value >= last, "array is not sorted"
    dup
    dig 6
    >=
    assert // array is not sorted
    swap
    intc_1 // 1
    +
    bury 6
    bury 4
    b test_quicksort_for_header@6

test_quicksort_after_for@9:
    // tests/artifacts/Arrays/uint64.py:174
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.uint64.Contract.test_unobserved_write[routing]() -> void:
test_unobserved_write:
    // tests/artifacts/Arrays/uint64.py:193
    // arr = create_array()
    callsub create_array
    // tests/artifacts/Arrays/uint64.py:194
    // last = arr.length - 1
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    intc_1 // 1
    -
    // tests/artifacts/Arrays/uint64.py:195
    // arr[last] = UInt64(0)  # write
    intc_2 // 0
    itob
    swap
    intc_0 // 8
    *
    uncover 2
    dig 1
    uncover 3
    replace3 // on error: index access is out of bounds
    dig 2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:196
    // assert_last_is_zero(arr)
    dig 1
    callsub assert_last_is_zero
    // tests/artifacts/Arrays/uint64.py:197
    // arr[last] = UInt64(1)  # write
    intc_1 // 1
    itob
    dig 2
    loads
    dig 2
    uncover 2
    replace3 // on error: index access is out of bounds
    uncover 2
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:198
    // assert arr[last] == 1
    swap
    extract_uint64
    intc_1 // 1
    ==
    // tests/artifacts/Arrays/uint64.py:191
    // @arc4.abimethod()
    return


// _puya_lib.mem.new_slot() -> uint64:
_puya_lib.mem.new_slot:
    load 0
    bitlen
    load 0
    pushint 256 // 256
    dig 2
    -
    intc_2 // 0
    setbit // on error: no available slots
    store 0
    retsub
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/Arrays/data/Contract.arc56.json b/tests/artifacts/Arrays/data/Contract.arc56.json index 1a2ddf3..c5f5a48 100644 --- a/tests/artifacts/Arrays/data/Contract.arc56.json +++ b/tests/artifacts/Arrays/data/Contract.arc56.json @@ -238,130 +238,109 @@ "sourceInfo": [ { "pc": [ - 192, - 204, - 216, - 228, - 244, - 256, - 268, - 280, - 292, - 301, - 313, - 325 + 99 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 1044 + 204 ], - "errorMessage": "array is expected length" - }, - { - "pc": [ - 1477, - 1556, - 1778 - ], - "errorMessage": "array is not sorted" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 342 + 880 ], - "errorMessage": "can only call when creating" + "errorMessage": "array is expected length" }, { "pc": [ - 195, - 207, - 219, - 231, - 247, - 259, - 271, - 283, - 295, - 304, - 316, - 328 + 1297, + 1376, + 1590 ], - "errorMessage": "can only call when not creating" + "errorMessage": "array is not sorted" }, { "pc": [ - 1128, - 1158, - 1166, - 1173, - 1178 + 958, + 988, + 996, + 1003, + 1008 ], "errorMessage": "expected 4" }, { "pc": [ - 1106 + 936 ], "errorMessage": "expected 5" }, { "pc": [ - 1732 + 1544 ], "errorMessage": "expected array of length 32" }, { "pc": [ - 1448 + 1268 ], "errorMessage": "expected array of length 5" }, { "pc": [ - 1519 + 1339 ], "errorMessage": "incorrect array value" }, { "pc": [ - 480, - 489, - 1273 + 339, + 348, + 351, + 354, + 738, + 1102, + 1119, + 1175, + 1625, + 1644 ], "errorMessage": "index access is out of bounds" }, { "pc": [ - 589, - 638, - 662, - 793, - 855, - 880, + 441, + 490, + 514, + 639, + 701, + 726, + 730, + 800, + 827, + 831, + 835, + 861, 884, - 955, - 983, - 987, - 991, - 1025, - 1048, - 1071, - 1086, - 1129, - 1204, - 1428, - 1592, - 1610, - 1624, - 1712 + 901, + 916, + 959, + 1033, + 1248, + 1412, + 1430, + 1444, + 1524 ], "errorMessage": "max array length exceeded" }, { "pc": [ - 1855 + 1667 ], "errorMessage": "no available slots" } @@ -374,18 +353,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 8 0 5 512
    bytecblock 0x 0x000000000000000100000000000000020000000000000003 0x0000000000000000 0x0000000000000004
    pushbytes 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    store 0
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@17
    pushbytess 0xa33be873 0xe0c378e9 0x366f509d 0x58351a50 0xfa99e984 0xa20e440f 0x179ac3f9 0x45dcc836 0xf17f6f0a 0x845e1b4e 0x7621cfd1 0x5661a67c // method "test_array()void", method "test_array_extend()void", method "test_array_multiple_append()void", method "overhead()void", method "test_array_too_long()void", method "test_array_copy_and_extend()void", method "test_array_evaluation_order()void", method "test_array_assignment_maximum_cursage()void", method "test_allocations(uint64)void", method "test_iteration()void", method "test_quicksort()void", method "test_unobserved_write()void"
    txna ApplicationArgs 0
    match main_test_array_route@3 main_test_array_extend_route@4 main_test_array_multiple_append_route@5 main_overhead_route@6 main_test_array_too_long_route@7 main_test_array_copy_and_extend_route@8 main_test_array_evaluation_order_route@9 main_test_array_assignment_maximum_cursage_route@10 main_test_allocations_route@11 main_test_iteration_route@12 main_test_quicksort_route@13 main_test_unobserved_write_route@14

main_after_if_else@21:
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    intc_2 // 0
    return

main_test_unobserved_write_route@14:
    // tests/artifacts/Arrays/uint64.py:191
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_unobserved_write
    intc_0 // 1
    return

main_test_quicksort_route@13:
    // tests/artifacts/Arrays/uint64.py:174
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_quicksort
    intc_0 // 1
    return

main_test_iteration_route@12:
    // tests/artifacts/Arrays/uint64.py:140
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_iteration
    intc_0 // 1
    return

main_test_allocations_route@11:
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    callsub test_allocations
    intc_0 // 1
    return

main_test_array_assignment_maximum_cursage_route@10:
    // tests/artifacts/Arrays/uint64.py:125
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_assignment_maximum_cursage
    intc_0 // 1
    return

main_test_array_evaluation_order_route@9:
    // tests/artifacts/Arrays/uint64.py:106
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_evaluation_order
    intc_0 // 1
    return

main_test_array_copy_and_extend_route@8:
    // tests/artifacts/Arrays/uint64.py:84
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_copy_and_extend
    intc_0 // 1
    return

main_test_array_too_long_route@7:
    // tests/artifacts/Arrays/uint64.py:75
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_too_long
    intc_0 // 1
    return

main_overhead_route@6:
    // tests/artifacts/Arrays/uint64.py:71
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    intc_0 // 1
    return

main_test_array_multiple_append_route@5:
    // tests/artifacts/Arrays/uint64.py:62
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_multiple_append
    intc_0 // 1
    return

main_test_array_extend_route@4:
    // tests/artifacts/Arrays/uint64.py:50
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array_extend
    intc_0 // 1
    return

main_test_array_route@3:
    // tests/artifacts/Arrays/uint64.py:14
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_array
    intc_0 // 1
    return

main_bare_routing@17:
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@21
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.Arrays.uint64.quicksort_window(arr: uint64, window_left: uint64, window_right: uint64) -> void:
quicksort_window:
    // tests/artifacts/Arrays/uint64.py:201-204
    // @subroutine
    // def quicksort_window(
    //     arr: ReferenceArray[UInt64], window_left: UInt64, window_right: UInt64
    // ) -> None:
    proto 3 0
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/uint64.py:207
    // pivot = arr[(window_left + window_right) // 2]
    frame_dig -2
    frame_dig -1
    +
    pushint 2 // 2
    /
    frame_dig -3
    loads
    swap
    intc_1 // 8
    *
    extract_uint64
    frame_dig -1
    frame_dig -2

quicksort_window_while_top@3:
    // tests/artifacts/Arrays/uint64.py:211-212
    // # move left of window towards pivot
    // while arr[left] < pivot:
    frame_dig -3
    loads
    frame_dig 5
    intc_1 // 8
    *
    dup
    frame_bury 0
    extract_uint64
    frame_dig 3
    <
    bz quicksort_window_while_top@6
    // tests/artifacts/Arrays/uint64.py:213
    // left += 1
    frame_dig 5
    intc_0 // 1
    +
    frame_bury 5
    b quicksort_window_while_top@3

quicksort_window_while_top@6:
    // tests/artifacts/Arrays/uint64.py:214-215
    // # move right of window towards pivot
    // while pivot < arr[right]:
    frame_dig -3
    loads
    frame_dig 4
    intc_1 // 8
    *
    dup
    frame_bury 1
    extract_uint64
    frame_dig 3
    >
    bz quicksort_window_after_while@10
    // tests/artifacts/Arrays/uint64.py:216-217
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 4
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:219
    // right -= 1
    frame_dig 4
    intc_0 // 1
    -
    frame_bury 4
    b quicksort_window_while_top@6

quicksort_window_after_while@22:
    // tests/artifacts/Arrays/uint64.py:247-248
    // # sort left half of window
    // if window_left < right:
    frame_dig -2
    frame_dig 4
    <
    bz quicksort_window_after_if_else@24
    // tests/artifacts/Arrays/uint64.py:249
    // quicksort_window(arr, window_left, right)
    frame_dig -3
    frame_dig -2
    frame_dig 4
    callsub quicksort_window

quicksort_window_after_if_else@24:
    // tests/artifacts/Arrays/uint64.py:250-251
    // # sort right half of window
    // if left < window_right:
    frame_dig 5
    frame_dig -1
    <
    bz quicksort_window_after_if_else@26
    // tests/artifacts/Arrays/uint64.py:252
    // quicksort_window(arr, left, window_right)
    frame_dig -3
    frame_dig 5
    frame_dig -1
    callsub quicksort_window

quicksort_window_after_if_else@26:
    retsub

quicksort_window_after_while@10:
    // tests/artifacts/Arrays/uint64.py:221-222
    // # if window isn't empty then swap values and move window in
    // if left < right:
    frame_dig 5
    frame_dig 4
    <
    bz quicksort_window_after_if_else@16
    // tests/artifacts/Arrays/uint64.py:223
    // arr[left], arr[right] = arr[right], arr[left]
    frame_dig -3
    loads
    dup
    frame_dig 1
    dup
    cover 3
    intc_1 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    frame_dig 0
    dup
    cover 3
    intc_1 // 8
    extract3 // on error: index access is out of bounds
    cover 3
    replace3
    cover 2
    replace3
    frame_dig -3
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:224
    // left += 1
    frame_dig 5
    intc_0 // 1
    +
    frame_bury 5
    // tests/artifacts/Arrays/uint64.py:225-226
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 4
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:228
    // right -= 1
    frame_dig 4
    intc_0 // 1
    -
    dup
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:229-230
    // # explicit continue to avoid hitting outer break
    // if left <= right:
    frame_dig 5
    >=
    bnz quicksort_window_while_top@3
    b quicksort_window_after_while@22

quicksort_window_after_if_else@16:
    // tests/artifacts/Arrays/uint64.py:235-236
    // # if window is just one item, don't bother swapping, but still adjust window
    // if left == right:
    frame_dig 5
    frame_dig 4
    ==
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:237
    // left += 1
    frame_dig 5
    intc_0 // 1
    +
    frame_bury 5
    frame_dig 4
    dup
    frame_bury 2
    // tests/artifacts/Arrays/uint64.py:238-239
    // # don't decrement right if it would go negative
    // if right:
    bz quicksort_window_after_if_else@19
    // tests/artifacts/Arrays/uint64.py:240
    // right -= 1
    frame_dig 4
    intc_0 // 1
    -
    frame_bury 2

quicksort_window_after_if_else@19:
    frame_dig 2
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:241-243
    // # loop always ends in this scenario
    // # and an explict break consumes fewer ops
    // break
    b quicksort_window_after_while@22


// tests.artifacts.Arrays.uint64.create_array() -> uint64:
create_array:
    // tests/artifacts/Arrays/uint64.py:255-256
    // @subroutine(inline=False)
    // def create_array() -> ReferenceArray[UInt64]:
    proto 0 1
    // tests/artifacts/Arrays/uint64.py:257
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_2 // 0

create_array_for_header@1:
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    frame_dig 1
    intc_3 // 5
    <
    bz create_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:259
    // arr.append(i)
    frame_dig 0
    dup
    loads
    frame_dig 1
    dup
    cover 3
    itob
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_0 // 1
    +
    frame_bury 1
    b create_array_for_header@1

create_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:260
    // return arr
    retsub


// tests.artifacts.Arrays.uint64.assert_last_is_zero(arr: uint64) -> void:
assert_last_is_zero:
    // tests/artifacts/Arrays/uint64.py:263-264
    // @subroutine(inline=False)
    // def assert_last_is_zero(arr: ReferenceArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/uint64.py:265
    // assert arr[arr.length - 1] == 0
    frame_dig -1
    loads
    dup
    len
    intc_1 // 8
    /
    intc_0 // 1
    -
    intc_1 // 8
    *
    extract_uint64
    !
    assert
    retsub


// tests.artifacts.Arrays.uint64.add_x(arr: uint64, x: uint64) -> void:
add_x:
    // tests/artifacts/Arrays/uint64.py:277-278
    // @subroutine
    // def add_x(arr: ReferenceArray[UInt64], x: UInt64) -> None:
    proto 2 0
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_2 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/uint64.py:280
    // arr.append(i)
    frame_dig -2
    loads
    frame_dig 0
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_dig -2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_0 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    retsub


// tests.artifacts.Arrays.uint64.append_length_and_return(arr: uint64) -> uint64:
append_length_and_return:
    // tests/artifacts/Arrays/uint64.py:291-292
    // @subroutine
    // def append_length_and_return(arr: ReferenceArray[UInt64]) -> ReferenceArray[UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/uint64.py:293
    // arr.append(arr.length)
    frame_dig -1
    loads
    dup
    len
    intc_1 // 8
    /
    itob
    concat // on error: max array length exceeded
    frame_dig -1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:294
    // return arr
    frame_dig -1
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array() -> void:
test_array:
    // tests/artifacts/Arrays/uint64.py:14-15
    // @arc4.abimethod()
    // def test_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/uint64.py:16
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    // tests/artifacts/Arrays/uint64.py:19
    // arr.append(UInt64(42))
    pushint 42 // 42
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:23
    // add_x(arr, UInt64(5))
    dup
    intc_3 // 5
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:24
    // assert arr.length == 6
    loads
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:25
    // assert arr[-1] == 4
    intc_0 // 1
    -
    intc_1 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 4 // 4
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    intc_2 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    frame_dig 2
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 3 // 3
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    <
    bz test_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:286
    // popped = arr.pop()
    frame_dig 0
    dup
    loads
    dup
    len
    dup
    intc_1 // 8
    -
    dig 2
    dig 1
    uncover 3
    substring3
    uncover 2
    intc_2 // 0
    uncover 3
    extract3
    swap
    btoi
    cover 2
    stores
    // tests/artifacts/Arrays/uint64.py:287
    // assert popped == expected
    frame_dig 1
    dup
    cover 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:288
    // expected -= 1
    intc_0 // 1
    -
    frame_bury 1
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    frame_dig 2
    intc_0 // 1
    +
    frame_bury 2
    b test_array_for_header@2

test_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:28
    // assert arr.length == 3
    frame_dig 0
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:29
    // assert arr[-1] == 1
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:31
    // arr.append(UInt64(43))
    pushint 43 // 43
    itob
    concat // on error: max array length exceeded
    dup2
    stores
    // tests/artifacts/Arrays/uint64.py:32
    // assert arr.length == 4
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:33
    // assert arr[-1] == 43
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 43 // 43
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:34
    // assert arr[0] == 42
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:36
    // add_x(arr, UInt64(10))
    dup
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:37
    // assert arr.length == 14
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:38
    // assert arr[-1] == 9
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:40
    // arr.append(UInt64(44))
    pushint 44 // 44
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:41
    // assert arr.length == 15
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:42
    // assert arr[-1] == 44
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:272
    // arr.append(UInt64(99))
    pushint 99 // 99
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:273
    // arr2.append(UInt64(100))
    pushint 100 // 100
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:44
    // return_ref(arr, arr)[0] += 2
    dup
    intc_2 // 0
    extract_uint64
    pushint 2 // 2
    +
    itob
    replace2 0
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:45
    // assert arr.length == 17
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 17 // 17
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:46
    // assert arr[0] == 44
    dig 1
    intc_2 // 0
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:47
    // assert arr[-2] == 99
    dup
    pushint 2 // 2
    -
    intc_1 // 8
    *
    dig 2
    swap
    extract_uint64
    pushint 99 // 99
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:48
    // assert arr[-1] == 100
    intc_0 // 1
    -
    intc_1 // 8
    *
    extract_uint64
    pushint 100 // 100
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_extend() -> void:
test_array_extend:
    // tests/artifacts/Arrays/uint64.py:52
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:53
    // add_x(arr, UInt64(1))
    dup
    intc_0 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    pop
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    dup
    loads
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:60
    // assert arr.length == 4
    len
    intc_1 // 8
    /
    pushint 4 // 4
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_multiple_append() -> void:
test_array_multiple_append:
    // tests/artifacts/Arrays/uint64.py:64
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:65
    // add_x(arr, UInt64(1))
    dup
    intc_0 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:66
    // arr.append(UInt64(1))
    dup
    loads
    intc_0 // 1
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:67
    // arr.append(UInt64(2))
    pushint 2 // 2
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:68
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:69
    // assert arr.length == 4
    len
    intc_1 // 8
    /
    pushint 4 // 4
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_too_long() -> void:
test_array_too_long:
    // tests/artifacts/Arrays/uint64.py:75-76
    // @arc4.abimethod()
    // def test_array_too_long(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/uint64.py:77
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_2 // 0

test_array_too_long_for_header@1:
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    frame_dig 1
    intc 4 // 512
    <
    bz test_array_too_long_after_for@4
    frame_dig 0
    // tests/artifacts/Arrays/uint64.py:79
    // array.append(i)
    frame_dig 1
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_bury 0
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_0 // 1
    +
    frame_bury 1
    b test_array_too_long_for_header@1

test_array_too_long_after_for@4:
    frame_dig 0
    // tests/artifacts/Arrays/uint64.py:80
    // assert array.length == 512, "array is expected length"
    dup
    len
    intc_1 // 8
    /
    intc 4 // 512
    ==
    assert // array is expected length
    // tests/artifacts/Arrays/uint64.py:82
    // array.append(UInt64(512))  # this will fail
    intc 4 // 512
    itob
    concat // on error: max array length exceeded
    pop
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_copy_and_extend() -> void:
test_array_copy_and_extend:
    // tests/artifacts/Arrays/uint64.py:84-85
    // @arc4.abimethod()
    // def test_array_copy_and_extend(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/uint64.py:86
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_2 // 0

test_array_copy_and_extend_for_header@1:
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    frame_dig 1
    intc_3 // 5
    <
    bz test_array_copy_and_extend_after_for@4
    frame_dig 0
    // tests/artifacts/Arrays/uint64.py:88
    // array.append(i)
    frame_dig 1
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_bury 0
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_0 // 1
    +
    frame_bury 1
    b test_array_copy_and_extend_for_header@1

test_array_copy_and_extend_after_for@4:
    frame_dig 0
    dup
    // tests/artifacts/Arrays/uint64.py:91
    // array.append(UInt64(5))
    intc_3 // 5
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:92
    // assert array.length == 6
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:93
    // assert array[-1] == 5, "expected 5"
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 5
    dig 1
    // tests/artifacts/Arrays/uint64.py:95
    // assert array2.length == 5
    dup
    len
    intc_1 // 8
    /
    dup
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:96
    // assert array2[-1] == 4, "expected 4"
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:98
    // array.extend(array2)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:99
    // assert array.length == 11
    dup
    len
    intc_1 // 8
    /
    dup
    pushint 11 // 11
    ==
    assert
    uncover 2
    // tests/artifacts/Arrays/uint64.py:100
    // assert array2.length == 5
    len
    intc_1 // 8
    /
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:101
    // assert array[-1] == 4, "expected 4"
    intc_0 // 1
    -
    intc_1 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:102
    // assert array[4] == 4, "expected 4"
    dup
    pushint 32 // 32
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:103
    // assert array[5] == 5, "expected 4"
    dup
    pushint 40 // 40
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:104
    // assert array[6] == 0, "expected 4"
    pushint 48 // 48
    extract_uint64
    !
    assert // expected 4
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_evaluation_order() -> void:
test_array_evaluation_order:
    // tests/artifacts/Arrays/uint64.py:108
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:109
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:110
    // append_length_and_return(arr).extend(append_length_and_return(arr))
    dup
    callsub append_length_and_return
    dig 1
    callsub append_length_and_return
    loads
    dig 1
    loads
    swap
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:111
    // assert arr.length == 6
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:112
    // assert arr[0] == 3
    dup
    intc_2 // 0
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:113
    // assert arr[1] == 1
    dup
    intc_1 // 8
    extract_uint64
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:114
    // assert arr[2] == 2
    dup
    pushint 16 // 16
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:115
    // assert arr[3] == 3
    dup
    pushint 24 // 24
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:116
    // assert arr[4] == 1
    dup
    pushint 32 // 32
    extract_uint64
    intc_0 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:117
    // assert arr[5] == 2
    pushint 40 // 40
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:119
    // arr[append_length_and_return(arr)[0]] = append_length_and_return(arr)[-1]
    dup
    callsub append_length_and_return
    loads
    dup
    len
    intc_1 // 8
    /
    intc_0 // 1
    -
    intc_1 // 8
    *
    intc_1 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    callsub append_length_and_return
    loads
    intc_2 // 0
    extract_uint64
    dig 2
    loads
    swap
    intc_1 // 8
    *
    uncover 2
    replace3
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:120
    // assert arr.length == 8
    dup
    len
    intc_1 // 8
    /
    intc_1 // 8
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:121
    // assert arr[6] == 6
    dup
    pushint 48 // 48
    extract_uint64
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:122
    // assert arr[7] == 7
    dup
    pushint 56 // 56
    extract_uint64
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:123
    // assert arr[3] == 6
    pushint 24 // 24
    extract_uint64
    pushint 6 // 6
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array_assignment_maximum_cursage() -> void:
test_array_assignment_maximum_cursage:
    // tests/artifacts/Arrays/uint64.py:127
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:128
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:129
    // append_length_and_return(arr)[0] = UInt64(42)
    dup
    callsub append_length_and_return
    pushint 42 // 42
    itob
    dig 1
    loads
    swap
    replace2 0
    stores
    // tests/artifacts/Arrays/uint64.py:130
    // assert arr.length == 2
    loads
    dup
    len
    intc_1 // 8
    /
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:131
    // assert arr[0] == 42
    dup
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:132
    // assert arr[1] == 1
    intc_1 // 8
    extract_uint64
    intc_0 // 1
    ==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_allocations(num: uint64) -> void:
test_allocations:
    // tests/artifacts/Arrays/uint64.py:134-135
    // @arc4.abimethod()
    // def test_allocations(self, num: UInt64) -> None:
    proto 1 0
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    intc_2 // 0

test_allocations_for_header@1:
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    frame_dig 0
    frame_dig -1
    <
    bz test_allocations_after_for@4
    // tests/artifacts/Arrays/uint64.py:137
    // alloc_test = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:138
    // add_x(alloc_test, UInt64(1))
    intc_0 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    frame_dig 0
    intc_0 // 1
    +
    frame_bury 0
    b test_allocations_for_header@1

test_allocations_after_for@4:
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_iteration() -> void:
test_iteration:
    // tests/artifacts/Arrays/uint64.py:140-141
    // @arc4.abimethod()
    // def test_iteration(self) -> None:
    proto 0 0
    intc_2 // 0
    dup
    bytec_0 // ""
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    dupn 7
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_2 // 0

test_iteration_for_header@1:
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    frame_dig 10
    intc_3 // 5
    <
    bz test_iteration_after_for@4
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:144
    // arr.append(val)
    frame_dig 10
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_bury 9
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_0 // 1
    +
    frame_bury 10
    b test_iteration_for_header@1

test_iteration_after_for@4:
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:145
    // assert arr.length == 5, "expected array of length 5"
    len
    intc_1 // 8
    /
    dup
    frame_bury 2
    intc_3 // 5
    ==
    assert // expected array of length 5
    // tests/artifacts/Arrays/uint64.py:147-148
    // # iterate
    // last = UInt64(0)
    intc_2 // 0
    frame_bury 7
    intc_2 // 0
    frame_bury 6

test_iteration_for_header@5:
    // tests/artifacts/Arrays/uint64.py:149
    // for value in arr:
    frame_dig 6
    frame_dig 2
    <
    bz test_iteration_after_for@8
    frame_dig 9
    frame_dig 6
    dup
    cover 2
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:150
    // assert value >= last, "array is not sorted"
    dup
    frame_dig 7
    >=
    assert // array is not sorted
    swap
    intc_0 // 1
    +
    frame_bury 6
    frame_bury 7
    b test_iteration_for_header@5

test_iteration_after_for@8:
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    len
    intc_1 // 8
    /
    frame_bury 3
    intc_2 // 0
    frame_bury 5

test_iteration_for_header@9:
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    frame_dig 5
    frame_dig 3
    <
    bz test_iteration_after_for@12
    frame_dig 9
    frame_dig 5
    dup
    cover 2
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:155
    // assert value == idx, "incorrect array value"
    dig 1
    ==
    assert // incorrect array value
    intc_0 // 1
    +
    frame_bury 5
    b test_iteration_for_header@9

test_iteration_after_for@12:
    frame_dig 9
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    len
    intc_1 // 8
    /
    frame_bury 8

test_iteration_for_header@13:
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    frame_dig 8
    bz test_iteration_after_for@16
    frame_dig 8
    intc_0 // 1
    -
    dup
    frame_bury 8
    frame_dig 9
    swap
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:159
    // assert value <= last, "array is not sorted"
    dup
    frame_dig 7
    <=
    assert // array is not sorted
    frame_bury 7
    b test_iteration_for_header@13

test_iteration_after_for@16:
    // tests/artifacts/Arrays/uint64.py:162
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    pushbytes 0x0000
    frame_bury 0
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    bytec_0 // 0x
    frame_bury 1
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_2 // 0
    frame_bury 4

test_iteration_for_header@17:
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    frame_dig 4
    intc_3 // 5
    <
    bz test_iteration_after_for@20
    // tests/artifacts/Arrays/uint64.py:165
    // arc4_arr.append(arc4.UInt64(i))
    frame_dig 4
    dup
    itob
    frame_dig 0
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_2 // 0
    extract_uint16
    intc_0 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    frame_dig 1
    // tests/artifacts/Arrays/uint64.py:166
    // native_arr.append(arc4.UInt64(i))
    swap
    concat // on error: max array length exceeded
    frame_bury 1
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_0 // 1
    +
    frame_bury 4
    b test_iteration_for_header@17

test_iteration_after_for@20:
    // tests/artifacts/Arrays/uint64.py:167
    // combined_arr = arc4_arr + native_arr
    frame_dig 0
    frame_dig 1
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_1 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/uint64.py:168
    // assert combined_arr.length == 10
    dup
    intc_2 // 0
    extract_uint16
    pushint 10 // 10
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:169
    // assert combined_arr[0] == 0
    dup
    extract 2 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:170
    // assert combined_arr[4] == 4
    dup
    extract 34 8
    bytec_3 // 0x0000000000000004
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:171
    // assert combined_arr[5] == 0
    dup
    extract 42 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:172
    // assert combined_arr[9] == 4
    extract 74 8
    bytec_3 // 0x0000000000000004
    b==
    assert
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_quicksort() -> void:
test_quicksort:
    // tests/artifacts/Arrays/uint64.py:174-175
    // @arc4.abimethod()
    // def test_quicksort(self) -> None:
    proto 0 0
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/uint64.py:176-177
    // # create pseudo random array from sender address
    // rnd = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    txn Sender
    intc_2 // 0

test_quicksort_for_header@1:
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    frame_dig 5
    pushint 32 // 32
    <
    bz test_quicksort_after_for@4
    // tests/artifacts/Arrays/uint64.py:179
    // rnd.append(op.btoi(b))
    frame_dig 4
    frame_dig 5
    dup
    cover 2
    getbyte
    frame_dig 3
    dup
    cover 2
    loads
    swap
    itob
    concat // on error: max array length exceeded
    stores
    intc_0 // 1
    +
    frame_bury 5
    b test_quicksort_for_header@1

test_quicksort_after_for@4:
    // tests/artifacts/Arrays/uint64.py:180
    // assert rnd.length == 32, "expected array of length 32"
    frame_dig 3
    dup
    loads
    len
    intc_1 // 8
    /
    dup
    pushint 32 // 32
    ==
    assert // expected array of length 32
    // tests/artifacts/Arrays/uint64.py:182-183
    // # sort the array
    // quicksort_window(rnd, UInt64(0), rnd.length - 1)
    intc_0 // 1
    -
    dig 1
    intc_2 // 0
    uncover 2
    callsub quicksort_window
    // tests/artifacts/Arrays/uint64.py:185-186
    // # array should now be in ascending order
    // last = UInt64(0)
    intc_2 // 0
    frame_bury 2
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    loads
    len
    intc_1 // 8
    /
    frame_bury 0
    intc_2 // 0
    frame_bury 1

test_quicksort_for_header@5:
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    frame_dig 1
    frame_dig 0
    <
    bz test_quicksort_after_for@8
    frame_dig 3
    loads
    frame_dig 1
    dup
    cover 2
    intc_1 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:188
    // assert value >= last, "array is not sorted"
    dup
    frame_dig 2
    >=
    assert // array is not sorted
    swap
    intc_0 // 1
    +
    frame_bury 1
    frame_bury 2
    b test_quicksort_for_header@5

test_quicksort_after_for@8:
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_unobserved_write() -> void:
test_unobserved_write:
    // tests/artifacts/Arrays/uint64.py:193
    // arr = create_array()
    callsub create_array
    // tests/artifacts/Arrays/uint64.py:194
    // last = arr.length - 1
    dup
    loads
    dup
    len
    intc_1 // 8
    /
    intc_0 // 1
    -
    // tests/artifacts/Arrays/uint64.py:195
    // arr[last] = UInt64(0)  # write
    intc_2 // 0
    itob
    swap
    intc_1 // 8
    *
    uncover 2
    dig 1
    uncover 3
    replace3
    dig 2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:196
    // assert_last_is_zero(arr)
    dig 1
    callsub assert_last_is_zero
    // tests/artifacts/Arrays/uint64.py:197
    // arr[last] = UInt64(1)  # write
    intc_0 // 1
    itob
    dig 2
    loads
    dig 2
    uncover 2
    replace3
    uncover 2
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:198
    // assert arr[last] == 1
    swap
    extract_uint64
    intc_0 // 1
    ==
    assert
    retsub


// _puya_lib.mem.new_slot() -> uint64:
_puya_lib.mem.new_slot:
    load 0
    bitlen
    load 0
    pushint 256 // 256
    dig 2
    -
    intc_2 // 0
    setbit // on error: no available slots
    store 0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 8 1 0 5 512
    bytecblock 0x 0x000000000000000100000000000000020000000000000003 0x0000000000000000 0x0000000000000004
    pushbytes 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    store 0
    // tests/artifacts/Arrays/uint64.py:13
    // class Contract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@19
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xa33be873 0xe0c378e9 0x366f509d 0x58351a50 0xfa99e984 0xa20e440f 0x179ac3f9 0x45dcc836 0xf17f6f0a 0x845e1b4e 0x7621cfd1 0x5661a67c // method "test_array()void", method "test_array_extend()void", method "test_array_multiple_append()void", method "overhead()void", method "test_array_too_long()void", method "test_array_copy_and_extend()void", method "test_array_evaluation_order()void", method "test_array_assignment_maximum_cursage()void", method "test_allocations(uint64)void", method "test_iteration()void", method "test_quicksort()void", method "test_unobserved_write()void"
    txna ApplicationArgs 0
    match test_array test_array_extend test_array_multiple_append main_overhead_route@7 test_array_too_long test_array_copy_and_extend test_array_evaluation_order test_array_assignment_maximum_cursage test_allocations test_iteration test_quicksort test_unobserved_write
    err

main_overhead_route@7:
    // tests/artifacts/Arrays/uint64.py:71
    // @arc4.abimethod()
    intc_1 // 1
    return

main___algopy_default_create@19:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.Arrays.uint64.quicksort_window(arr: uint64, window_left: uint64, window_right: uint64) -> void:
quicksort_window:
    // tests/artifacts/Arrays/uint64.py:201-204
    // @subroutine
    // def quicksort_window(
    //     arr: ReferenceArray[UInt64], window_left: UInt64, window_right: UInt64
    // ) -> None:
    proto 3 0
    bytec_0 // ""
    dup
    // tests/artifacts/Arrays/uint64.py:207
    // pivot = arr[(window_left + window_right) // 2]
    frame_dig -2
    frame_dig -1
    +
    pushint 2 // 2
    /
    frame_dig -3
    loads
    swap
    intc_0 // 8
    *
    extract_uint64
    frame_dig -1
    frame_dig -2

quicksort_window_while_top@3:
    // tests/artifacts/Arrays/uint64.py:211-212
    // # move left of window towards pivot
    // while arr[left] < pivot:
    frame_dig -3
    loads
    frame_dig 4
    intc_0 // 8
    *
    dup
    frame_bury 0
    extract_uint64
    frame_dig 2
    <
    bz quicksort_window_while_top@6
    // tests/artifacts/Arrays/uint64.py:213
    // left += 1
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    b quicksort_window_while_top@3

quicksort_window_while_top@6:
    // tests/artifacts/Arrays/uint64.py:214-215
    // # move right of window towards pivot
    // while pivot < arr[right]:
    frame_dig -3
    loads
    frame_dig 3
    intc_0 // 8
    *
    dup
    frame_bury 1
    extract_uint64
    frame_dig 2
    >
    bz quicksort_window_after_while@10
    // tests/artifacts/Arrays/uint64.py:216-217
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 3
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:219
    // right -= 1
    frame_dig 3
    intc_1 // 1
    -
    frame_bury 3
    b quicksort_window_while_top@6

quicksort_window_after_while@22:
    // tests/artifacts/Arrays/uint64.py:247-248
    // # sort left half of window
    // if window_left < right:
    frame_dig -2
    frame_dig 3
    <
    bz quicksort_window_after_if_else@24
    // tests/artifacts/Arrays/uint64.py:249
    // quicksort_window(arr, window_left, right)
    frame_dig -3
    frame_dig -2
    frame_dig 3
    callsub quicksort_window

quicksort_window_after_if_else@24:
    // tests/artifacts/Arrays/uint64.py:250-251
    // # sort right half of window
    // if left < window_right:
    frame_dig 4
    frame_dig -1
    <
    bz quicksort_window_after_if_else@26
    // tests/artifacts/Arrays/uint64.py:252
    // quicksort_window(arr, left, window_right)
    frame_dig -3
    frame_dig 4
    frame_dig -1
    callsub quicksort_window

quicksort_window_after_if_else@26:
    retsub

quicksort_window_after_while@10:
    // tests/artifacts/Arrays/uint64.py:221-222
    // # if window isn't empty then swap values and move window in
    // if left < right:
    frame_dig 4
    frame_dig 3
    <
    bz quicksort_window_after_if_else@16
    // tests/artifacts/Arrays/uint64.py:223
    // arr[left], arr[right] = arr[right], arr[left]
    frame_dig -3
    loads
    dup
    frame_dig 1
    dup
    cover 3
    intc_0 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    frame_dig 0
    dup
    cover 3
    intc_0 // 8
    extract3 // on error: index access is out of bounds
    cover 3
    replace3 // on error: index access is out of bounds
    cover 2
    replace3 // on error: index access is out of bounds
    frame_dig -3
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:224
    // left += 1
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:225-226
    // # break out of loop if right would go negative
    // if not right:
    frame_dig 3
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:228
    // right -= 1
    frame_dig 3
    intc_1 // 1
    -
    dup
    frame_bury 3
    // tests/artifacts/Arrays/uint64.py:229-230
    // # explicit continue to avoid hitting outer break
    // if left <= right:
    frame_dig 4
    >=
    bnz quicksort_window_while_top@3
    b quicksort_window_after_while@22

quicksort_window_after_if_else@16:
    // tests/artifacts/Arrays/uint64.py:235-236
    // # if window is just one item, don't bother swapping, but still adjust window
    // if left == right:
    frame_dig 4
    frame_dig 3
    ==
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:237
    // left += 1
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    // tests/artifacts/Arrays/uint64.py:238-239
    // # don't decrement right if it would go negative
    // if right:
    frame_dig 3
    bz quicksort_window_after_while@22
    // tests/artifacts/Arrays/uint64.py:240
    // right -= 1
    frame_dig 3
    intc_1 // 1
    -
    frame_bury 3
    b quicksort_window_after_while@22


// tests.artifacts.Arrays.uint64.create_array() -> uint64:
create_array:
    // tests/artifacts/Arrays/uint64.py:255-256
    // @subroutine(inline=False)
    // def create_array() -> ReferenceArray[UInt64]:
    proto 0 1
    // tests/artifacts/Arrays/uint64.py:257
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_2 // 0

create_array_for_header@1:
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    frame_dig 1
    intc_3 // 5
    <
    bz create_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:259
    // arr.append(i)
    frame_dig 0
    dup
    loads
    frame_dig 1
    dup
    cover 3
    itob
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:258
    // for i in urange(5):
    intc_1 // 1
    +
    frame_bury 1
    b create_array_for_header@1

create_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:260
    // return arr
    retsub


// tests.artifacts.Arrays.uint64.assert_last_is_zero(arr: uint64) -> void:
assert_last_is_zero:
    // tests/artifacts/Arrays/uint64.py:263-264
    // @subroutine(inline=False)
    // def assert_last_is_zero(arr: ReferenceArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/uint64.py:265
    // assert arr[arr.length - 1] == 0
    frame_dig -1
    loads
    dup
    len
    intc_0 // 8
    /
    intc_1 // 1
    -
    intc_0 // 8
    *
    extract_uint64
    !
    assert
    retsub


// tests.artifacts.Arrays.uint64.add_x(arr: uint64, x: uint64) -> void:
add_x:
    // tests/artifacts/Arrays/uint64.py:277-278
    // @subroutine
    // def add_x(arr: ReferenceArray[UInt64], x: UInt64) -> None:
    proto 2 0
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_2 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/uint64.py:280
    // arr.append(i)
    frame_dig -2
    loads
    frame_dig 0
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    frame_dig -2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:279
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    retsub


// tests.artifacts.Arrays.uint64.append_length_and_return(arr: uint64) -> uint64:
append_length_and_return:
    // tests/artifacts/Arrays/uint64.py:291-292
    // @subroutine
    // def append_length_and_return(arr: ReferenceArray[UInt64]) -> ReferenceArray[UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/uint64.py:293
    // arr.append(arr.length)
    frame_dig -1
    loads
    dup
    len
    intc_0 // 8
    /
    itob
    concat // on error: max array length exceeded
    frame_dig -1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:294
    // return arr
    frame_dig -1
    retsub


// tests.artifacts.Arrays.uint64.Contract.test_array[routing]() -> void:
test_array:
    // tests/artifacts/Arrays/uint64.py:16
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    // tests/artifacts/Arrays/uint64.py:19
    // arr.append(UInt64(42))
    pushint 42 // 42
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:23
    // add_x(arr, UInt64(5))
    dup
    intc_3 // 5
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:24
    // assert arr.length == 6
    loads
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:25
    // assert arr[-1] == 4
    intc_1 // 1
    -
    intc_0 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 4 // 4
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    intc_2 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    dup
    // tests/artifacts/Arrays/uint64.py:27
    // pop_x(arr, x=UInt64(3), expected=UInt64(4))
    pushint 3 // 3
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    <
    bz test_array_after_for@4
    // tests/artifacts/Arrays/uint64.py:286
    // popped = arr.pop()
    dig 2
    dup
    loads
    dup
    len
    dup
    intc_0 // 8
    -
    dig 2
    intc_2 // 0
    dig 2
    extract3
    uncover 3
    uncover 2
    uncover 3
    substring3
    btoi
    cover 2
    stores
    // tests/artifacts/Arrays/uint64.py:287
    // assert popped == expected
    dig 2
    dup
    cover 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:288
    // expected -= 1
    intc_1 // 1
    -
    bury 2
    // tests/artifacts/Arrays/uint64.py:285
    // for _i in urange(x):
    dup
    intc_1 // 1
    +
    bury 1
    b test_array_for_header@2

test_array_after_for@4:
    // tests/artifacts/Arrays/uint64.py:28
    // assert arr.length == 3
    dig 2
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:29
    // assert arr[-1] == 1
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:31
    // arr.append(UInt64(43))
    pushint 43 // 43
    itob
    concat // on error: max array length exceeded
    dup2
    stores
    // tests/artifacts/Arrays/uint64.py:32
    // assert arr.length == 4
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:33
    // assert arr[-1] == 43
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 43 // 43
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:34
    // assert arr[0] == 42
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:36
    // add_x(arr, UInt64(10))
    dup
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:37
    // assert arr.length == 14
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:38
    // assert arr[-1] == 9
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:40
    // arr.append(UInt64(44))
    pushint 44 // 44
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:41
    // assert arr.length == 15
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:42
    // assert arr[-1] == 44
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:272
    // arr.append(UInt64(99))
    pushint 99 // 99
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:273
    // arr2.append(UInt64(100))
    pushint 100 // 100
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:44
    // return_ref(arr, arr)[0] += 2
    dup
    intc_2 // 0
    extract_uint64
    pushint 2 // 2
    +
    itob
    replace2 0 // on error: index access is out of bounds
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:45
    // assert arr.length == 17
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 17 // 17
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:46
    // assert arr[0] == 44
    dig 1
    intc_2 // 0
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:47
    // assert arr[-2] == 99
    dup
    pushint 2 // 2
    -
    intc_0 // 8
    *
    dig 2
    swap
    extract_uint64
    pushint 99 // 99
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:48
    // assert arr[-1] == 100
    intc_1 // 1
    -
    intc_0 // 8
    *
    extract_uint64
    pushint 100 // 100
    ==
    // tests/artifacts/Arrays/uint64.py:14
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_extend[routing]() -> void:
test_array_extend:
    // tests/artifacts/Arrays/uint64.py:52
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:53
    // add_x(arr, UInt64(1))
    dup
    intc_1 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    pop
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    dup
    loads
    // tests/artifacts/Arrays/uint64.py:57
    // arr2.append(UInt64(3))
    bytec_1 // 0x000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/uint64.py:59
    // arr.extend(arr2)
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:60
    // assert arr.length == 4
    len
    intc_0 // 8
    /
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/uint64.py:50
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_multiple_append[routing]() -> void:
test_array_multiple_append:
    // tests/artifacts/Arrays/uint64.py:64
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:65
    // add_x(arr, UInt64(1))
    dup
    intc_1 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:66
    // arr.append(UInt64(1))
    dup
    loads
    intc_1 // 1
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:67
    // arr.append(UInt64(2))
    pushint 2 // 2
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:68
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    concat // on error: max array length exceeded
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:69
    // assert arr.length == 4
    len
    intc_0 // 8
    /
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/uint64.py:62
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_too_long[routing]() -> void:
test_array_too_long:
    // tests/artifacts/Arrays/uint64.py:77
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_2 // 0

test_array_too_long_for_header@2:
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    dup
    intc 4 // 512
    <
    bz test_array_too_long_after_for@5
    // tests/artifacts/Arrays/uint64.py:79
    // array.append(i)
    dup2
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/uint64.py:78
    // for i in urange(512):
    intc_1 // 1
    +
    bury 1
    b test_array_too_long_for_header@2

test_array_too_long_after_for@5:
    dig 1
    // tests/artifacts/Arrays/uint64.py:80
    // assert array.length == 512, "array is expected length"
    dup
    len
    intc_0 // 8
    /
    intc 4 // 512
    ==
    assert // array is expected length
    // tests/artifacts/Arrays/uint64.py:82
    // array.append(UInt64(512))  # this will fail
    intc 4 // 512
    itob
    concat // on error: max array length exceeded
    pop
    // tests/artifacts/Arrays/uint64.py:75
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_copy_and_extend[routing]() -> void:
test_array_copy_and_extend:
    // tests/artifacts/Arrays/uint64.py:86
    // array = ReferenceArray[UInt64]()
    bytec_0 // 0x
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_2 // 0

test_array_copy_and_extend_for_header@2:
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    dup
    intc_3 // 5
    <
    bz test_array_copy_and_extend_after_for@5
    // tests/artifacts/Arrays/uint64.py:88
    // array.append(i)
    dup2
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/uint64.py:87
    // for i in urange(5):
    intc_1 // 1
    +
    bury 1
    b test_array_copy_and_extend_for_header@2

test_array_copy_and_extend_after_for@5:
    dig 1
    dup
    // tests/artifacts/Arrays/uint64.py:91
    // array.append(UInt64(5))
    intc_3 // 5
    itob
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:92
    // assert array.length == 6
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:93
    // assert array[-1] == 5, "expected 5"
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 5
    dig 1
    // tests/artifacts/Arrays/uint64.py:95
    // assert array2.length == 5
    dup
    len
    intc_0 // 8
    /
    dup
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:96
    // assert array2[-1] == 4, "expected 4"
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:98
    // array.extend(array2)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/uint64.py:99
    // assert array.length == 11
    dup
    len
    intc_0 // 8
    /
    dup
    pushint 11 // 11
    ==
    assert
    uncover 2
    // tests/artifacts/Arrays/uint64.py:100
    // assert array2.length == 5
    len
    intc_0 // 8
    /
    intc_3 // 5
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:101
    // assert array[-1] == 4, "expected 4"
    intc_1 // 1
    -
    intc_0 // 8
    *
    dig 1
    swap
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:102
    // assert array[4] == 4, "expected 4"
    dup
    pushint 32 // 32
    extract_uint64
    pushint 4 // 4
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:103
    // assert array[5] == 5, "expected 4"
    dup
    pushint 40 // 40
    extract_uint64
    intc_3 // 5
    ==
    assert // expected 4
    // tests/artifacts/Arrays/uint64.py:104
    // assert array[6] == 0, "expected 4"
    pushint 48 // 48
    extract_uint64
    !
    // tests/artifacts/Arrays/uint64.py:84
    // @arc4.abimethod()
    return // on error: expected 4


// tests.artifacts.Arrays.uint64.Contract.test_array_evaluation_order[routing]() -> void:
test_array_evaluation_order:
    // tests/artifacts/Arrays/uint64.py:108
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:109
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:110
    // append_length_and_return(arr).extend(append_length_and_return(arr))
    dup
    callsub append_length_and_return
    dig 1
    callsub append_length_and_return
    loads
    dig 1
    loads
    swap
    concat // on error: max array length exceeded
    stores
    // tests/artifacts/Arrays/uint64.py:111
    // assert arr.length == 6
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:112
    // assert arr[0] == 3
    dup
    intc_2 // 0
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:113
    // assert arr[1] == 1
    dup
    intc_0 // 8
    extract_uint64
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:114
    // assert arr[2] == 2
    dup
    pushint 16 // 16
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:115
    // assert arr[3] == 3
    dup
    pushint 24 // 24
    extract_uint64
    pushint 3 // 3
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:116
    // assert arr[4] == 1
    dup
    pushint 32 // 32
    extract_uint64
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:117
    // assert arr[5] == 2
    pushint 40 // 40
    extract_uint64
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:119
    // arr[append_length_and_return(arr)[0]] = append_length_and_return(arr)[-1]
    dup
    callsub append_length_and_return
    loads
    dup
    len
    intc_0 // 8
    /
    intc_1 // 1
    -
    intc_0 // 8
    *
    intc_0 // 8
    extract3 // on error: index access is out of bounds
    dig 1
    callsub append_length_and_return
    loads
    intc_2 // 0
    extract_uint64
    dig 2
    loads
    swap
    intc_0 // 8
    *
    uncover 2
    replace3 // on error: index access is out of bounds
    swap
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:120
    // assert arr.length == 8
    dup
    len
    intc_0 // 8
    /
    intc_0 // 8
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:121
    // assert arr[6] == 6
    dup
    pushint 48 // 48
    extract_uint64
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:122
    // assert arr[7] == 7
    dup
    pushint 56 // 56
    extract_uint64
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:123
    // assert arr[3] == 6
    pushint 24 // 24
    extract_uint64
    pushint 6 // 6
    ==
    // tests/artifacts/Arrays/uint64.py:106
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_array_assignment_maximum_cursage[routing]() -> void:
test_array_assignment_maximum_cursage:
    // tests/artifacts/Arrays/uint64.py:127
    // arr = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    // tests/artifacts/Arrays/uint64.py:128
    // arr.append(UInt64(3))
    pushint 3 // 3
    itob
    dig 1
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:129
    // append_length_and_return(arr)[0] = UInt64(42)
    dup
    callsub append_length_and_return
    pushint 42 // 42
    itob
    dig 1
    loads
    swap
    replace2 0 // on error: index access is out of bounds
    stores
    // tests/artifacts/Arrays/uint64.py:130
    // assert arr.length == 2
    loads
    dup
    len
    intc_0 // 8
    /
    pushint 2 // 2
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:131
    // assert arr[0] == 42
    dup
    intc_2 // 0
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:132
    // assert arr[1] == 1
    intc_0 // 8
    extract_uint64
    intc_1 // 1
    ==
    // tests/artifacts/Arrays/uint64.py:125
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_allocations[routing]() -> void:
test_allocations:
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    intc_2 // 0

test_allocations_for_header@2:
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    dup
    dig 2
    <
    bz test_allocations_after_for@5
    // tests/artifacts/Arrays/uint64.py:137
    // alloc_test = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:138
    // add_x(alloc_test, UInt64(1))
    intc_1 // 1
    callsub add_x
    // tests/artifacts/Arrays/uint64.py:136
    // for _i in urange(num):
    dup
    intc_1 // 1
    +
    bury 1
    b test_allocations_for_header@2

test_allocations_after_for@5:
    // tests/artifacts/Arrays/uint64.py:134
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.uint64.Contract.test_iteration[routing]() -> void:
test_iteration:
    intc_2 // 0
    dup
    bytec_0 // ""
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    dupn 7
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_2 // 0

test_iteration_for_header@2:
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    dup
    intc_3 // 5
    <
    bz test_iteration_after_for@5
    // tests/artifacts/Arrays/uint64.py:144
    // arr.append(val)
    dup2
    dup
    cover 2
    itob
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/uint64.py:143
    // for val in urange(5):
    intc_1 // 1
    +
    bury 1
    b test_iteration_for_header@2

test_iteration_after_for@5:
    dig 1
    // tests/artifacts/Arrays/uint64.py:145
    // assert arr.length == 5, "expected array of length 5"
    len
    intc_0 // 8
    /
    dup
    bury 10
    intc_3 // 5
    ==
    assert // expected array of length 5
    // tests/artifacts/Arrays/uint64.py:147-148
    // # iterate
    // last = UInt64(0)
    intc_2 // 0
    bury 4
    intc_2 // 0
    bury 5

test_iteration_for_header@6:
    // tests/artifacts/Arrays/uint64.py:149
    // for value in arr:
    dig 4
    dig 9
    <
    bz test_iteration_after_for@9
    dig 1
    dig 5
    dup
    cover 2
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:150
    // assert value >= last, "array is not sorted"
    dup
    dig 6
    >=
    assert // array is not sorted
    swap
    intc_1 // 1
    +
    bury 6
    bury 4
    b test_iteration_for_header@6

test_iteration_after_for@9:
    dig 1
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    len
    intc_0 // 8
    /
    bury 8
    intc_2 // 0
    bury 6

test_iteration_for_header@10:
    // tests/artifacts/Arrays/uint64.py:153-154
    // # enumerate
    // for idx, value in uenumerate(arr):
    dig 5
    dig 8
    <
    bz test_iteration_after_for@13
    dig 1
    dig 6
    dup
    cover 2
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:155
    // assert value == idx, "incorrect array value"
    dig 1
    ==
    assert // incorrect array value
    intc_1 // 1
    +
    bury 6
    b test_iteration_for_header@10

test_iteration_after_for@13:
    dig 1
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    len
    intc_0 // 8
    /
    bury 3

test_iteration_for_header@14:
    // tests/artifacts/Arrays/uint64.py:157-158
    // # reverse
    // for value in reversed(arr):
    dig 2
    bz test_iteration_after_for@17
    dig 2
    intc_1 // 1
    -
    dup
    bury 4
    dig 2
    swap
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:159
    // assert value <= last, "array is not sorted"
    dup
    dig 5
    <=
    assert // array is not sorted
    bury 4
    b test_iteration_for_header@14

test_iteration_after_for@17:
    // tests/artifacts/Arrays/uint64.py:162
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    pushbytes 0x0000
    bury 11
    // tests/artifacts/Arrays/uint64.py:142
    // arr = ReferenceArray[UInt64]()
    bytec_0 // 0x
    bury 10
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_2 // 0
    bury 7

test_iteration_for_header@18:
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    dig 6
    intc_3 // 5
    <
    bz test_iteration_after_for@21
    // tests/artifacts/Arrays/uint64.py:165
    // arc4_arr.append(arc4.UInt64(i))
    dig 6
    dup
    itob
    dig 12
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_2 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 13
    dig 11
    // tests/artifacts/Arrays/uint64.py:166
    // native_arr.append(arc4.UInt64(i))
    swap
    concat // on error: max array length exceeded
    bury 11
    // tests/artifacts/Arrays/uint64.py:164
    // for i in urange(5):
    intc_1 // 1
    +
    bury 7
    b test_iteration_for_header@18

test_iteration_after_for@21:
    // tests/artifacts/Arrays/uint64.py:167
    // combined_arr = arc4_arr + native_arr
    dig 10
    dig 10
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_0 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/uint64.py:168
    // assert combined_arr.length == 10
    dup
    intc_2 // 0
    extract_uint16
    pushint 10 // 10
    ==
    assert
    // tests/artifacts/Arrays/uint64.py:169
    // assert combined_arr[0] == 0
    dup
    extract 2 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:170
    // assert combined_arr[4] == 4
    dup
    extract 34 8
    bytec_3 // 0x0000000000000004
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:171
    // assert combined_arr[5] == 0
    dup
    extract 42 8
    bytec_2 // 0x0000000000000000
    b==
    assert
    // tests/artifacts/Arrays/uint64.py:172
    // assert combined_arr[9] == 4
    extract 74 8
    bytec_3 // 0x0000000000000004
    b==
    // tests/artifacts/Arrays/uint64.py:140
    // @arc4.abimethod()
    return


// tests.artifacts.Arrays.uint64.Contract.test_quicksort[routing]() -> void:
test_quicksort:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/uint64.py:176-177
    // # create pseudo random array from sender address
    // rnd = ReferenceArray[UInt64]()
    callsub _puya_lib.mem.new_slot
    dup
    bytec_0 // 0x
    stores
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    txn Sender
    intc_2 // 0

test_quicksort_for_header@2:
    // tests/artifacts/Arrays/uint64.py:178
    // for b in Txn.sender.bytes:
    dup
    pushint 32 // 32
    <
    bz test_quicksort_after_for@5
    // tests/artifacts/Arrays/uint64.py:179
    // rnd.append(op.btoi(b))
    dup2
    dup
    cover 2
    getbyte
    dig 4
    dup
    cover 2
    loads
    swap
    itob
    concat // on error: max array length exceeded
    stores
    intc_1 // 1
    +
    bury 1
    b test_quicksort_for_header@2

test_quicksort_after_for@5:
    // tests/artifacts/Arrays/uint64.py:180
    // assert rnd.length == 32, "expected array of length 32"
    dig 2
    dup
    loads
    len
    intc_0 // 8
    /
    dup
    pushint 32 // 32
    ==
    assert // expected array of length 32
    // tests/artifacts/Arrays/uint64.py:182-183
    // # sort the array
    // quicksort_window(rnd, UInt64(0), rnd.length - 1)
    intc_1 // 1
    -
    dig 1
    intc_2 // 0
    uncover 2
    callsub quicksort_window
    // tests/artifacts/Arrays/uint64.py:185-186
    // # array should now be in ascending order
    // last = UInt64(0)
    intc_2 // 0
    bury 5
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    loads
    len
    intc_0 // 8
    /
    bury 6
    intc_2 // 0
    bury 5

test_quicksort_for_header@6:
    // tests/artifacts/Arrays/uint64.py:187
    // for value in rnd:
    dig 4
    dig 6
    <
    bz test_quicksort_after_for@9
    dig 2
    loads
    dig 5
    dup
    cover 2
    intc_0 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/uint64.py:188
    // assert value >= last, "array is not sorted"
    dup
    dig 6
    >=
    assert // array is not sorted
    swap
    intc_1 // 1
    +
    bury 6
    bury 4
    b test_quicksort_for_header@6

test_quicksort_after_for@9:
    // tests/artifacts/Arrays/uint64.py:174
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.uint64.Contract.test_unobserved_write[routing]() -> void:
test_unobserved_write:
    // tests/artifacts/Arrays/uint64.py:193
    // arr = create_array()
    callsub create_array
    // tests/artifacts/Arrays/uint64.py:194
    // last = arr.length - 1
    dup
    loads
    dup
    len
    intc_0 // 8
    /
    intc_1 // 1
    -
    // tests/artifacts/Arrays/uint64.py:195
    // arr[last] = UInt64(0)  # write
    intc_2 // 0
    itob
    swap
    intc_0 // 8
    *
    uncover 2
    dig 1
    uncover 3
    replace3 // on error: index access is out of bounds
    dig 2
    swap
    stores
    // tests/artifacts/Arrays/uint64.py:196
    // assert_last_is_zero(arr)
    dig 1
    callsub assert_last_is_zero
    // tests/artifacts/Arrays/uint64.py:197
    // arr[last] = UInt64(1)  # write
    intc_1 // 1
    itob
    dig 2
    loads
    dig 2
    uncover 2
    replace3 // on error: index access is out of bounds
    uncover 2
    dig 1
    stores
    // tests/artifacts/Arrays/uint64.py:198
    // assert arr[last] == 1
    swap
    extract_uint64
    intc_1 // 1
    ==
    // tests/artifacts/Arrays/uint64.py:191
    // @arc4.abimethod()
    return


// _puya_lib.mem.new_slot() -> uint64:
_puya_lib.mem.new_slot:
    load 0
    bitlen
    load 0
    pushint 256 // 256
    dig 2
    -
    intc_2 // 0
    setbit // on error: no available slots
    store 0
    retsub
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAFAQgABYAEJgQAGAAAAAAAAAABAAAAAAAAAAIAAAAAAAAAAwgAAAAAAAAAAAgAAAAAAAAABIAgf/////////////////////////////////////////81ADEbQQDuggwEozvocwTgw3jpBDZvUJ0EWDUaUAT6memEBKIORA8EF5rD+QRF3Mg2BPF/bwoEhF4bTgR2Ic/RBFZhpnw2GgCODACHAHsAbwBmAFoATgBCADYAJgAaAA4AAiRDMRkURDEYRIgGNyJDMRkURDEYRIgFtiJDMRkURDEYRIgEnSJDMRkURDEYRDYaAReIBG0iQzEZFEQxGESIBDMiQzEZFEQxGESIA5UiQzEZFEQxGESIAwgiQzEZFEQxGESIAs0iQzEZFEQxGEQiQzEZFEQxGESIApQiQzEZFEQxGESIAmsiQzEZFEQxGESIAVIiQzEZQP9oMRgURCJDigMAKEcCi/6L/wiBAgqL/T5MIwtbi/+L/ov9PosFIwtJjABbiwMMQQAJiwUiCIwFQv/mi/0+iwQjC0mMAVuLAw1BADGLBEEACYsEIgmMBEL/4Yv+iwQMQQAJi/2L/osEiP+diwWL/wxBAAmL/YsFi/+I/4yJiwWLBAxBADmL/T5JiwFJTgMjWEsBiwBJTgMjWE4DXU4CXYv9TD+LBSIIjAWLBEH/rIsEIglJjASLBQ9A/2ZC/5yLBYsEEkH/lIsFIgiMBYsESYwCQQAGiwQiCYwCiwKMBEL/eYoAAYgE+0koPySLASUMQQATiwBJPosBSU4DFlA/IgiMAUL/5omKAQCL/z5JFSMKIgkjC1sURImKAgAkiwCL/wxBABWL/j6LAElOAhZQi/5MPyIIjABC/+OJigEBi/8+SRUjChZQi/9MP4v/iYoAAIgEj0mBKhZLAUw/SSWI/7g+SRUjCkmBBhJEIgkjC1uBBBJEgQQkiwKBAwxBAC+LAEk+SRVJIwlLAksBTwNSTwIkTwNYTBdOAj+LAUlOAhJEIgmMAYsCIgiMAkL/yYsAST5JFSMKSYEDEkQiCSMLSwFMWyISRIErFlBKP0kVIwpJgQQSRCIJIwtLAUxbgSsSRCRbgSoSREmBCoj/LEk+SRUjCkmBDhJEIgkjC0sBTFuBCRJEgSwWUEkVIwpJgQ8SRCIJIwtLAUxbgSwSRIFjFlCBZBZQSSRbgQIIFlwATEsBP0kVIwpJgRESREsBJFuBLBJESYECCSMLSwJMW4FjEkQiCSMLW4FkEkSJiAOFSSg/SSKI/rMpSEk+KVBMSwE/FSMKgQQSRImIA2hJKD9JIoj+lkk+IhZQgQIWUIEDFlBMSwE/FSMKgQQSRImKAAAoJIsBIQQMQQASiwCLAUlOAhZQjAAiCIwBQv/miwBJFSMKIQQSRCEEFlBIiYoAACgkiwElDEEAEosAiwFJTgIWUIwAIgiMAUL/54sASSUWUEkVIwpJgQYSRCIJIwtLAUxbJRJESwFJFSMKSSUSRCIJIwtLAUxbgQQSRFBJFSMKSYELEkRPAhUjCiUSRCIJIwtLAUxbgQQSREmBIFuBBBJESYEoWyUSRIEwWxREiYgClIEDFksBTD9JiP3hSwGI/dw+SwE+TFA/ST5JFSMKgQYSREkkW4EDEkRJI1siEkRJgRBbgQISREmBGFuBAxJESYEgWyISRIEoW4ECEkRJiP2cPkkVIwoiCSMLI1hLAYj9jD4kW0sCPkwjC08CXUxLAT9JFSMKIxJESYEwW4EGEkRJgThbgQcSRIEYW4EGEkSJiAICgQMWSwFMP0mI/U+BKhZLAT5MXAA/PkkVIwqBAhJESSRbgSoSRCNbIhJEiYoBACSLAIv/DEEAE4gByEkoPyKI/PeLACIIjABC/+WJigAAJEkoRwckiwolDEEAEosJiwpJTgIWUIwJIgiMCkL/54sJFSMKSYwCJRJEJIwHJIwGiwaLAgxBABmLCYsGSU4CIwtbSYsHD0RMIgiMBowHQv/fiwkVIwqMAySMBYsFiwMMQQAViwmLBUlOAiMLW0sBEkQiCIwFQv/jiwkVIwqMCIsIQQAXiwgiCUmMCIsJTCMLW0mLBw5EjAdC/+SAAgAAjAAojAEkjASLBCUMQQAniwRJFosASU4CSwFQTwIkWSIIFlcGAlwAjACLAUxQjAEiCIwEQv/SiwCLAVBJVwIAFSMKFlcGAlwASSRZgQoSRElXAggqqERJVyIIK6hESVcqCCqoRFdKCCuoRImKAAAoRwKIAKFJKD8xACSLBYEgDEEAGYsEiwVJTgJViwNJTgI+TBZQPyIIjAVC/9+LA0k+FSMKSYEgEkQiCUsBJE8CiPqKJIwCPhUjCowAJIwBiwGLAAxBABqLAz6LAUlOAiMLW0mLAg9ETCIIjAGMAkL/3omI+zFJPkkVIwoiCSQWTCMLTwJLAU8DXUsCTD9LAYj7OSIWSwI+SwJPAl1PAksBP0xbIhJEiTQAkzQAgYACSwIJJFQ1AIk=", + "approval": "CiAFCAEABYAEJgQAGAAAAAAAAAABAAAAAAAAAAIAAAAAAAAAAwgAAAAAAAAAAAgAAAAAAAAABIAgf/////////////////////////////////////////81ADEbQQBlMRkURDEYRIIMBKM76HME4MN46QQ2b1CdBFg1GlAE+pnphASiDkQPBBeaw/kERdzINgTxf28KBIReG04EdiHP0QRWYaZ8NhoAjgwBSAJOAmoAAQKNArYDLwPAA+0EDQUSBYEAI0MxGRQxGBQQQ4oDAChJi/6L/wiBAgqL/T5MIgtbi/+L/ov9PosEIgtJjABbiwIMQQAJiwQjCIwEQv/mi/0+iwMiC0mMAVuLAg1BADGLA0EACYsDIwmMA0L/4Yv+iwMMQQAJi/2L/osDiP+eiwSL/wxBAAmL/YsEi/+I/42JiwSLAwxBADmL/T5JiwFJTgMiWEsBiwBJTgMiWE4DXU4CXYv9TD+LBCMIjASLA0H/rIsDIwlJjAOLBA9A/2ZC/5yLBIsDEkH/lIsEIwiMBIsDQf+JiwMjCYwDQv+AigABiATTSSg/JIsBJQxBABOLAEk+iwFJTgMWUD8jCIwBQv/miYoBAIv/PkkVIgojCSILWxREiYoCACSLAIv/DEEAFYv+PosASU4CFlCL/kw/IwiMAEL/44mKAQGL/z5JFSIKFlCL/0w/i/+JiARqSYEqFksBTD9JJYj/uz5JFSIKSYEGEkQjCSILW4EEEkSBBCRJgQMMQQAtSwJJPkkVSSIJSwIkSwJYTwNPAk8DUhdOAj9LAklOAhJEIwlFAkkjCEUBQv/MSwJJPkkVIgpJgQMSRCMJIgtLAUxbIxJEgSsWUEo/SRUiCkmBBBJEIwkiC0sBTFuBKxJEJFuBKhJESYEKiP8yST5JFSIKSYEOEkQjCSILSwFMW4EJEkSBLBZQSRUiCkmBDxJEIwkiC0sBTFuBLBJEgWMWUIFkFlBJJFuBAggWXABMSwE/SRUiCkmBERJESwEkW4EsEkRJgQIJIgtLAkxbgWMSRCMJIgtbgWQSQ4gDZEkoP0kjiP66KUhJPilQTEsBPxUiCoEEEkOIA0hJKD9JI4j+nkk+IxZQgQIWUIEDFlBMSwE/FSIKgQQSQygkSSEEDEEAD0pJTgIWUEUDIwhFAUL/6ksBSRUiCiEEEkQhBBZQSCNDKCRJJQxBAA9KSU4CFlBFAyMIRQFC/+tLAUklFlBJFSIKSYEGEkQjCSILSwFMWyUSREsBSRUiCkklEkQjCSILSwFMW4EEEkRQSRUiCkmBCxJETwIVIgolEkQjCSILSwFMW4EEEkRJgSBbgQQSREmBKFslEkSBMFsUQ4gCg4EDFksBTD9JiP34SwGI/fM+SwE+TFA/ST5JFSIKgQYSREkkW4EDEkRJIlsjEkRJgRBbgQISREmBGFuBAxJESYEgWyMSRIEoW4ECEkRJiP2zPkkVIgojCSILIlhLAYj9oz4kW0sCPkwiC08CXUxLAT9JFSIKIhJESYEwW4EGEkRJgThbgQcSRIEYW4EGEkOIAfKBAxZLAUw/SYj9Z4EqFksBPkxcAD8+SRUiCoECEkRJJFuBKhJEIlsjEkM2GgEXJElLAgxBABKIAblJKD8jiP0QSSMIRQFC/+cjQyRJKEcHJEklDEEAD0pJTgIWUEUDIwhFAUL/60sBFSIKSUUKJRJEJEUEJEUFSwRLCQxBABlLAUsFSU4CIgtbSUsGD0RMIwhFBkUEQv/fSwEVIgpFCCRFBksFSwgMQQAVSwFLBklOAiILW0sBEkQjCEUGQv/jSwEVIgpFA0sCQQAXSwIjCUlFBEsCTCILW0lLBQ5ERQRC/+SAAgAARQsoRQokRQdLBiUMQQAnSwZJFksMSU4CSwFQTwIkWSMIFlcGAlwARQ1LC0xQRQsjCEUHQv/SSwpLClBJVwIAFSIKFlcGAlwASSRZgQoSRElXAggqqERJVyIIK6hESVcqCCqoRFdKCCuoQyhHAogAnUkoPzEAJEmBIAxBABZKSU4CVUsESU4CPkwWUD8jCEUBQv/jSwJJPhUiCkmBIBJEIwlLASRPAoj6uiRFBT4VIgpFBiRFBUsESwYMQQAaSwI+SwVJTgIiC1tJSwYPREwjCEUGRQRC/94jQ4j7WEk+SRUiCiMJJBZMIgtPAksBTwNdSwJMP0sBiPtgIxZLAj5LAk8CXU8CSwE/TFsjEkM0AJM0AIGAAksCCSRUNQCJ", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/Arrays/data/ImmutableArrayContract.approval.teal b/tests/artifacts/Arrays/data/ImmutableArrayContract.approval.teal index 43ddf9c..e5f4e47 100644 --- a/tests/artifacts/Arrays/data/ImmutableArrayContract.approval.teal +++ b/tests/artifacts/Arrays/data/ImmutableArrayContract.approval.teal @@ -4,499 +4,28 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: intcblock 0 1 2 8 - bytecblock 0x151f7c75 0x 0x0000 0x00 0x0002 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 0x000a 0x62696775696e74 0x000200000000000000010000000000000002 0x000200040007000161000162 "imm_fixed_arr" + bytecblock 0x 0x151f7c75 0x0000 0x00 0x0002 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 0x000a 0x62696775696e74 0x000200000000000000010000000000000002 0x000200040007000161000162 "imm_fixed_arr" // tests/artifacts/Arrays/immutable.py:93 // class ImmutableArrayContract(arc4.ARC4Contract): txn NumAppArgs - bz main_bare_routing@29 - pushbytess 0x44d42f99 0xb7eaa60b 0x743d70ed 0x1c7e0494 0xa2d5860b 0xe05fc564 0x1e092b83 0x01310262 0xc8654a98 0x89d196f8 0x6cb7c991 0x9898bf02 0xf6b61ee8 0x60b86a7b 0x73ad283f 0x529dfae9 0x206d514f 0xe06465e2 0xec0300a2 0xecdf14af 0x511aca64 0x29852e4f 0x6d4aa358 0xb7cb96bd // method "test_uint64_array()void", method "test_biguint_array()void", method "test_bool_array(uint64)void", method "test_fixed_size_tuple_array()void", method "test_fixed_size_named_tuple_array()void", method "test_dynamic_sized_tuple_array()void", method "test_dynamic_sized_named_tuple_array()void", method "test_implicit_conversion_log(uint64[])void", method "test_implicit_conversion_emit(uint64[])void", method "test_nested_array(uint64,uint64[][])uint64[]", method "test_bit_packed_tuples()void", method "sum_uints_and_lengths_and_trues(uint64[],bool[],(uint64,bool,bool)[],(uint64,string)[])(uint64,uint64,uint64,uint64)", method "test_uint64_return(uint64)uint64[]", method "test_bool_return(uint64)bool[]", method "test_tuple_return(uint64)(uint64,bool,bool)[]", method "test_dynamic_tuple_return(uint64)(uint64,string)[]", method "test_convert_to_array_and_back((uint64,bool,bool)[],uint64)(uint64,bool,bool)[]", method "test_concat_with_arc4_tuple((uint64,uint64))uint64[]", method "test_concat_with_native_tuple((uint64,uint64))uint64[]", method "test_dynamic_concat_with_arc4_tuple((string,string))string[]", method "test_dynamic_concat_with_native_tuple((string,string))string[]", method "test_concat_immutable_dynamic((uint64,string)[],(uint64,string)[])(uint64,string)[]", method "test_immutable_arc4((uint64,uint64)[])(uint64,uint64)[]", method "test_imm_fixed_arr()(uint64,uint64)[3]" - txna ApplicationArgs 0 - match main_test_uint64_array_route@3 main_test_biguint_array_route@4 main_test_bool_array_route@5 main_test_fixed_size_tuple_array_route@6 main_test_fixed_size_named_tuple_array_route@7 main_test_dynamic_sized_tuple_array_route@8 main_test_dynamic_sized_named_tuple_array_route@9 main_test_implicit_conversion_log_route@10 main_test_implicit_conversion_emit_route@11 main_test_nested_array_route@12 main_test_bit_packed_tuples_route@13 main_sum_uints_and_lengths_and_trues_route@14 main_test_uint64_return_route@15 main_test_bool_return_route@16 main_test_tuple_return_route@17 main_test_dynamic_tuple_return_route@18 main_test_convert_to_array_and_back_route@19 main_test_concat_with_arc4_tuple_route@20 main_test_concat_with_native_tuple_route@21 main_test_dynamic_concat_with_arc4_tuple_route@22 main_test_dynamic_concat_with_native_tuple_route@23 main_test_concat_immutable_dynamic_route@24 main_test_immutable_arc4_route@25 main_test_imm_fixed_arr_route@26 - -main_after_if_else@33: - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - intc_0 // 0 - return - -main_test_imm_fixed_arr_route@26: - // tests/artifacts/Arrays/immutable.py:450 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_imm_fixed_arr - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_immutable_arc4_route@25: - // tests/artifacts/Arrays/immutable.py:444 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arrays/immutable.py:444 - // @arc4.abimethod() - callsub test_immutable_arc4 - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_concat_immutable_dynamic_route@24: - // tests/artifacts/Arrays/immutable.py:438 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - // tests/artifacts/Arrays/immutable.py:438 - // @arc4.abimethod() - callsub test_concat_immutable_dynamic - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_dynamic_concat_with_native_tuple_route@23: - // tests/artifacts/Arrays/immutable.py:430 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - dup - intc_0 // 0 - extract_uint16 - dig 1 - intc_2 // 2 - extract_uint16 - dig 2 - uncover 2 - dig 2 - substring3 - dig 2 - len - uncover 3 - uncover 3 - uncover 2 - substring3 - // tests/artifacts/Arrays/immutable.py:430 - // @arc4.abimethod() - callsub test_dynamic_concat_with_native_tuple - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_dynamic_concat_with_arc4_tuple_route@22: - // tests/artifacts/Arrays/immutable.py:422 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arrays/immutable.py:422 - // @arc4.abimethod() - callsub test_dynamic_concat_with_arc4_tuple - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_concat_with_native_tuple_route@21: - // tests/artifacts/Arrays/immutable.py:414 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - dup - extract 0 8 - swap - extract 8 8 - // tests/artifacts/Arrays/immutable.py:414 - // @arc4.abimethod() - callsub test_concat_with_native_tuple - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_concat_with_arc4_tuple_route@20: - // tests/artifacts/Arrays/immutable.py:406 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arrays/immutable.py:406 - // @arc4.abimethod() - callsub test_concat_with_arc4_tuple - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_convert_to_array_and_back_route@19: - // tests/artifacts/Arrays/immutable.py:396 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - btoi - // tests/artifacts/Arrays/immutable.py:396 - // @arc4.abimethod() - callsub test_convert_to_array_and_back - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_dynamic_tuple_return_route@18: - // tests/artifacts/Arrays/immutable.py:389 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/immutable.py:389 - // @arc4.abimethod() - callsub test_dynamic_tuple_return - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_tuple_return_route@17: - // tests/artifacts/Arrays/immutable.py:382 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/immutable.py:382 - // @arc4.abimethod() - callsub test_tuple_return - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_bool_return_route@16: - // tests/artifacts/Arrays/immutable.py:375 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/immutable.py:375 - // @arc4.abimethod() - callsub test_bool_return - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_uint64_return_route@15: - // tests/artifacts/Arrays/immutable.py:368 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/immutable.py:368 - // @arc4.abimethod() - callsub test_uint64_return - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_sum_uints_and_lengths_and_trues_route@14: - // tests/artifacts/Arrays/immutable.py:341 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - txna ApplicationArgs 3 - txna ApplicationArgs 4 - // tests/artifacts/Arrays/immutable.py:341 - // @arc4.abimethod() - callsub sum_uints_and_lengths_and_trues - uncover 3 - itob - uncover 3 - itob - concat - uncover 2 - itob - concat - swap - itob - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_bit_packed_tuples_route@13: - // tests/artifacts/Arrays/immutable.py:276 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_bit_packed_tuples - intc_1 // 1 - return - -main_test_nested_array_route@12: - // tests/artifacts/Arrays/immutable.py:258 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - // tests/artifacts/Arrays/immutable.py:258 - // @arc4.abimethod() - callsub test_nested_array - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_implicit_conversion_emit_route@11: - // tests/artifacts/Arrays/immutable.py:254 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arrays/immutable.py:254 - // @arc4.abimethod() - callsub test_implicit_conversion_emit - intc_1 // 1 - return - -main_test_implicit_conversion_log_route@10: - // tests/artifacts/Arrays/immutable.py:250 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arrays/immutable.py:250 - // @arc4.abimethod() - callsub test_implicit_conversion_log - intc_1 // 1 - return - -main_test_dynamic_sized_named_tuple_array_route@9: - // tests/artifacts/Arrays/immutable.py:231 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_dynamic_sized_named_tuple_array - intc_1 // 1 - return - -main_test_dynamic_sized_tuple_array_route@8: - // tests/artifacts/Arrays/immutable.py:212 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_dynamic_sized_tuple_array - intc_1 // 1 - return - -main_test_fixed_size_named_tuple_array_route@7: - // tests/artifacts/Arrays/immutable.py:197 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_fixed_size_named_tuple_array - intc_1 // 1 - return - -main_test_fixed_size_tuple_array_route@6: - // tests/artifacts/Arrays/immutable.py:179 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_fixed_size_tuple_array - intc_1 // 1 - return - -main_test_bool_array_route@5: - // tests/artifacts/Arrays/immutable.py:155 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/immutable.py:155 - // @arc4.abimethod() - callsub test_bool_array - intc_1 // 1 - return - -main_test_biguint_array_route@4: - // tests/artifacts/Arrays/immutable.py:130 - // @arc4.abimethod() + bz main___algopy_default_create@31 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - callsub test_biguint_array - intc_1 // 1 - return + assert + pushbytess 0x44d42f99 0xb7eaa60b 0x743d70ed 0x1c7e0494 0xa2d5860b 0xe05fc564 0x1e092b83 0x01310262 0xc8654a98 0x89d196f8 0x6cb7c991 0x9898bf02 0xf6b61ee8 0x60b86a7b 0x73ad283f 0x529dfae9 0x206d514f 0xe06465e2 0xec0300a2 0xecdf14af 0x511aca64 0x29852e4f 0x6d4aa358 0xb7cb96bd // method "test_uint64_array()void", method "test_biguint_array()void", method "test_bool_array(uint64)void", method "test_fixed_size_tuple_array()void", method "test_fixed_size_named_tuple_array()void", method "test_dynamic_sized_tuple_array()void", method "test_dynamic_sized_named_tuple_array()void", method "test_implicit_conversion_log(uint64[])void", method "test_implicit_conversion_emit(uint64[])void", method "test_nested_array(uint64,uint64[][])uint64[]", method "test_bit_packed_tuples()void", method "sum_uints_and_lengths_and_trues(uint64[],bool[],(uint64,bool,bool)[],(uint64,string)[])(uint64,uint64,uint64,uint64)", method "test_uint64_return(uint64)uint64[]", method "test_bool_return(uint64)bool[]", method "test_tuple_return(uint64)(uint64,bool,bool)[]", method "test_dynamic_tuple_return(uint64)(uint64,string)[]", method "test_convert_to_array_and_back((uint64,bool,bool)[],uint64)(uint64,bool,bool)[]", method "test_concat_with_arc4_tuple((uint64,uint64))uint64[]", method "test_concat_with_native_tuple((uint64,uint64))uint64[]", method "test_dynamic_concat_with_arc4_tuple((string,string))string[]", method "test_dynamic_concat_with_native_tuple((string,string))string[]", method "test_concat_immutable_dynamic((uint64,string)[],(uint64,string)[])(uint64,string)[]", method "test_immutable_arc4((uint64,uint64)[])(uint64,uint64)[]", method "test_imm_fixed_arr()(uint64,uint64)[3]" + txna ApplicationArgs 0 + match test_uint64_array test_biguint_array test_bool_array test_fixed_size_tuple_array test_fixed_size_named_tuple_array test_dynamic_sized_tuple_array test_dynamic_sized_named_tuple_array test_implicit_conversion_log test_implicit_conversion_emit test_nested_array test_bit_packed_tuples sum_uints_and_lengths_and_trues test_uint64_return test_bool_return test_tuple_return test_dynamic_tuple_return test_convert_to_array_and_back test_concat_with_arc4_tuple test_concat_with_native_tuple test_dynamic_concat_with_arc4_tuple test_dynamic_concat_with_native_tuple test_concat_immutable_dynamic test_immutable_arc4 test_imm_fixed_arr + err -main_test_uint64_array_route@3: - // tests/artifacts/Arrays/immutable.py:94 - // @arc4.abimethod() +main___algopy_default_create@31: txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_uint64_array - intc_1 // 1 - return - -main_bare_routing@29: - // tests/artifacts/Arrays/immutable.py:93 - // class ImmutableArrayContract(arc4.ARC4Contract): - txn OnCompletion - bnz main_after_if_else@33 txn ApplicationID ! - assert // can only call when creating - intc_1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating // _puya_lib.arc4.dynamic_array_pop_fixed_size(array: bytes, fixed_byte_size: uint64) -> bytes, bytes: @@ -552,7 +81,7 @@ dynamic_array_pop_dynamic_element: swap cover 2 substring3 - bytec_1 // 0x + bytec_0 // 0x intc_0 // 0 dynamic_array_pop_dynamic_element_for_header@1: @@ -601,7 +130,7 @@ dynamic_array_pop_dynamic_element_after_for@4: // _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes: dynamic_array_concat_bits: proto 4 1 - bytec_1 // "" + bytec_0 // "" dupn 2 frame_dig -4 intc_0 // 0 @@ -615,22 +144,20 @@ dynamic_array_concat_bits: frame_dig -4 swap replace2 0 - dup - uncover 2 - uncover 3 + cover 2 + swap pushint 7 // 7 + intc_3 // 8 / dup - cover 3 - swap + uncover 2 pushint 7 // 7 + intc_3 // 8 / dup - cover 3 + cover 2 < bz dynamic_array_concat_bits_after_if_else@2 frame_dig 6 @@ -640,11 +167,9 @@ dynamic_array_concat_bits: frame_dig 4 swap concat - frame_bury 7 + frame_bury 4 dynamic_array_concat_bits_after_if_else@2: - frame_dig 7 - frame_bury 4 intc_0 // 0 frame_bury 0 frame_dig 3 @@ -769,7 +294,7 @@ dynamic_array_concat_byte_length_head_after_for@4: // _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes: dynamic_array_concat_dynamic_element: proto 4 1 - bytec_1 // "" + bytec_0 // "" dup frame_dig -2 intc_2 // 2 @@ -923,7 +448,7 @@ times: proto 1 1 // tests/artifacts/Arrays/immutable.py:490 // result = String() - bytec_1 // "" + bytec_0 // "" // tests/artifacts/Arrays/immutable.py:491 // for _i in urange(n): intc_0 // 0 @@ -1004,12 +529,8 @@ add_x_after_for@4: retsub -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_array() -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_array[routing]() -> void: test_uint64_array: - // tests/artifacts/Arrays/immutable.py:94-95 - // @arc4.abimethod() - // def test_uint64_array(self) -> None: - proto 0 0 // tests/artifacts/Arrays/immutable.py:99 // arr = arr.append(UInt64(42)) pushbytes 0x0001000000000000002a @@ -1089,7 +610,7 @@ test_uint64_array: test_uint64_array_for_header@2: // tests/artifacts/Arrays/immutable.py:505 // for _i in urange(x): - frame_dig 1 + dup // tests/artifacts/Arrays/immutable.py:112 // arr = pop_x(arr, UInt64(3)) pushint 3 // 3 @@ -1099,23 +620,23 @@ test_uint64_array_for_header@2: bz test_uint64_array_after_for@4 // tests/artifacts/Arrays/immutable.py:506 // arr = arr.pop() - frame_dig 0 + dig 1 intc_3 // 8 callsub dynamic_array_pop_fixed_size - frame_bury 0 + bury 3 pop // tests/artifacts/Arrays/immutable.py:505 // for _i in urange(x): - frame_dig 1 + dup intc_1 // 1 + - frame_bury 1 + bury 1 b test_uint64_array_for_header@2 test_uint64_array_after_for@4: // tests/artifacts/Arrays/immutable.py:113 // assert arr.length == 4 - frame_dig 0 + dig 1 dup intc_0 // 0 extract_uint16 @@ -1202,7 +723,7 @@ test_uint64_array_after_for@4: // arr = arr.replace(2, UInt64(23)) pushint 23 // 23 itob - replace2 18 + replace2 18 // on error: index access is out of bounds // tests/artifacts/Arrays/immutable.py:125 // assert arr.length == 15 dup @@ -1224,15 +745,14 @@ test_uint64_array_after_for@4: pushbytes "a" swap app_global_put - retsub + // tests/artifacts/Arrays/immutable.py:94 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_biguint_array() -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_biguint_array[routing]() -> void: test_biguint_array: - // tests/artifacts/Arrays/immutable.py:130-131 - // @arc4.abimethod() - // def test_biguint_array(self) -> None: - proto 0 0 // tests/artifacts/Arrays/immutable.py:135 // arr = arr.append(BigUInt(Txn.num_app_args - 1)) txn NumAppArgs @@ -1273,7 +793,7 @@ test_biguint_array: * pushint 64 // 64 extract3 // on error: index access is out of bounds - bytec_1 // 0x + bytec_0 // 0x b== assert // tests/artifacts/Arrays/immutable.py:512 @@ -1283,7 +803,7 @@ test_biguint_array: test_biguint_array_for_header@2: // tests/artifacts/Arrays/immutable.py:512 // for i in urange(x): - frame_dig 2 + dup // tests/artifacts/Arrays/immutable.py:139 // arr = add_xb(arr, UInt64(5)) pushint 5 // 5 @@ -1293,12 +813,11 @@ test_biguint_array_for_header@2: bz test_biguint_array_after_for@4 // tests/artifacts/Arrays/immutable.py:513 // arr = arr.append(BigUInt(i)) - frame_dig 2 - dup + dupn 2 itob - frame_dig 0 + dig 4 b| - frame_dig 1 + dig 3 dup uncover 2 concat // on error: max array length exceeded @@ -1310,18 +829,18 @@ test_biguint_array_for_header@2: itob extract 6 2 replace2 0 - frame_bury 1 + bury 3 // tests/artifacts/Arrays/immutable.py:512 // for i in urange(x): intc_1 // 1 + - frame_bury 2 + bury 1 b test_biguint_array_for_header@2 test_biguint_array_after_for@4: // tests/artifacts/Arrays/immutable.py:140 // assert arr.length == 6 - frame_dig 1 + dig 1 dup intc_0 // 0 extract_uint16 @@ -1356,7 +875,7 @@ test_biguint_array_after_for@4: pushint 64 // 64 <= assert // overflow - frame_dig 0 + dig 5 b| uncover 2 swap @@ -1395,7 +914,7 @@ test_biguint_array_after_for@4: // assert arr[0] == 0 dig 1 extract 2 64 - bytec_1 // 0x + bytec_0 // 0x b== assert // tests/artifacts/Arrays/immutable.py:148 @@ -1436,7 +955,7 @@ test_biguint_array_after_for@4: // assert arr[0] == 0 dup extract 2 64 - bytec_1 // 0x + bytec_0 // 0x b== assert // tests/artifacts/Arrays/immutable.py:153 @@ -1447,16 +966,19 @@ test_biguint_array_after_for@4: bytec 7 // 0x62696775696e74 swap box_put - retsub + // tests/artifacts/Arrays/immutable.py:130 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_array(length: uint64) -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_array[routing]() -> void: test_bool_array: - // tests/artifacts/Arrays/immutable.py:155-156 + bytec_0 // "" + // tests/artifacts/Arrays/immutable.py:155 // @arc4.abimethod() - // def test_bool_array(self, length: UInt64) -> None: - proto 1 0 - bytec_1 // "" + txna ApplicationArgs 1 + btoi // tests/artifacts/Arrays/immutable.py:157 // arr = ImmutableArray[bool]() bytec_2 // 0x0000 @@ -1464,17 +986,17 @@ test_bool_array: // for i in urange(length): intc_0 // 0 -test_bool_array_for_header@1: +test_bool_array_for_header@2: // tests/artifacts/Arrays/immutable.py:160 // for i in urange(length): - frame_dig 2 - frame_dig -1 + dup + dig 3 < - bz test_bool_array_after_for@4 + bz test_bool_array_after_for@5 // tests/artifacts/Arrays/immutable.py:161 // arr = arr.append(i == Txn.num_app_args) txn NumAppArgs - frame_dig 2 + dig 1 dup uncover 2 == @@ -1482,122 +1004,123 @@ test_bool_array_for_header@1: intc_0 // 0 uncover 2 setbit - frame_dig 1 + dig 3 swap intc_1 // 1 intc_3 // 8 callsub dynamic_array_concat_bits - frame_bury 1 + bury 3 // tests/artifacts/Arrays/immutable.py:160 // for i in urange(length): intc_1 // 1 + - frame_bury 2 - b test_bool_array_for_header@1 + bury 1 + b test_bool_array_for_header@2 -test_bool_array_after_for@4: +test_bool_array_after_for@5: // tests/artifacts/Arrays/immutable.py:163 // assert arr.length == length - frame_dig 1 + dig 1 intc_0 // 0 extract_uint16 dup - frame_bury 0 - frame_dig -1 + bury 5 + dig 3 + dup + cover 2 == assert // tests/artifacts/Arrays/immutable.py:165 // if length > 0: - frame_dig -1 - bz test_bool_array_after_if_else@6 + bz test_bool_array_after_if_else@7 // tests/artifacts/Arrays/immutable.py:166 // assert not arr[0], "expected element 0 to be False" - frame_dig 0 + dig 3 assert // index access is out of bounds - frame_dig 1 + dig 1 pushint 16 // 16 getbit ! assert // expected element 0 to be False -test_bool_array_after_if_else@6: +test_bool_array_after_if_else@7: // tests/artifacts/Arrays/immutable.py:167 // if length > 1: - frame_dig -1 + dig 2 intc_1 // 1 > - bz test_bool_array_after_if_else@8 + bz test_bool_array_after_if_else@9 // tests/artifacts/Arrays/immutable.py:168 // assert not arr[1], "expected element 1 to be False" intc_1 // 1 - frame_dig 0 + dig 4 < assert // index access is out of bounds - frame_dig 1 + dig 1 pushint 17 // 17 getbit ! assert // expected element 1 to be False -test_bool_array_after_if_else@8: +test_bool_array_after_if_else@9: // tests/artifacts/Arrays/immutable.py:169 // if length > 2: - frame_dig -1 + dig 2 intc_2 // 2 > - bz test_bool_array_after_if_else@10 + bz test_bool_array_after_if_else@11 // tests/artifacts/Arrays/immutable.py:170 // assert arr[2], "expected element 2 to be True" intc_2 // 2 - frame_dig 0 + dig 4 < assert // index access is out of bounds - frame_dig 1 + dig 1 pushint 18 // 18 getbit assert // expected element 2 to be True -test_bool_array_after_if_else@10: +test_bool_array_after_if_else@11: // tests/artifacts/Arrays/immutable.py:171 // if length > 3: - frame_dig -1 + dig 2 pushint 3 // 3 > - bz test_bool_array_after_if_else@12 + bz test_bool_array_after_if_else@13 // tests/artifacts/Arrays/immutable.py:172 // assert not arr[length - 1], "expected last element to be False" - frame_dig -1 + dig 2 intc_1 // 1 - dup - frame_dig 0 + dig 5 < assert // index access is out of bounds pushint 16 // 16 + - frame_dig 1 + dig 2 swap getbit ! assert // expected last element to be False -test_bool_array_after_if_else@12: +test_bool_array_after_if_else@13: // tests/artifacts/Arrays/immutable.py:174 // self.g = arr pushbytes "g" - frame_dig 1 + dig 2 app_global_put // tests/artifacts/Arrays/immutable.py:175 // if length: - frame_dig -1 - bz test_bool_array_after_if_else@14 - frame_dig 0 + dig 2 + bz test_bool_array_after_if_else@15 + dig 3 intc_1 // 1 - dup itob extract 6 0 - frame_dig 1 + dig 3 swap replace2 0 dig 1 @@ -1619,22 +1142,21 @@ test_bool_array_after_if_else@12: // assert arr.length == length - 1 intc_0 // 0 extract_uint16 - frame_dig -1 + dig 3 intc_1 // 1 - == assert -test_bool_array_after_if_else@14: - retsub +test_bool_array_after_if_else@15: + // tests/artifacts/Arrays/immutable.py:155 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_tuple_array() -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_tuple_array[routing]() -> void: test_fixed_size_tuple_array: - // tests/artifacts/Arrays/immutable.py:179-180 - // @arc4.abimethod() - // def test_fixed_size_tuple_array(self) -> None: - proto 0 0 // tests/artifacts/Arrays/immutable.py:181 // arr = ImmutableArray[tuple[UInt64, UInt64]]() bytec_2 // 0x0000 @@ -1642,17 +1164,16 @@ test_fixed_size_tuple_array: // for i in urange(5): intc_0 // 0 -test_fixed_size_tuple_array_for_header@1: +test_fixed_size_tuple_array_for_header@2: // tests/artifacts/Arrays/immutable.py:184 // for i in urange(5): - frame_dig 1 + dup pushint 5 // 5 < - bz test_fixed_size_tuple_array_after_for@4 + bz test_fixed_size_tuple_array_after_for@5 // tests/artifacts/Arrays/immutable.py:185 // arr = arr.append((i + 1, i + 2)) - frame_dig 1 - dup + dupn 2 intc_1 // 1 + swap @@ -1663,7 +1184,7 @@ test_fixed_size_tuple_array_for_header@1: swap itob concat - frame_dig 0 + dig 3 dup uncover 2 concat // on error: max array length exceeded @@ -1675,14 +1196,14 @@ test_fixed_size_tuple_array_for_header@1: itob extract 6 2 replace2 0 - frame_bury 0 - frame_bury 1 - b test_fixed_size_tuple_array_for_header@1 + bury 3 + bury 1 + b test_fixed_size_tuple_array_for_header@2 -test_fixed_size_tuple_array_after_for@4: +test_fixed_size_tuple_array_after_for@5: // tests/artifacts/Arrays/immutable.py:187 // assert arr.length == 5 - frame_dig 0 + dig 1 dup intc_0 // 0 extract_uint16 @@ -1795,15 +1316,14 @@ test_fixed_size_tuple_array_after_for@4: pushbytes "c" swap app_global_put - retsub + // tests/artifacts/Arrays/immutable.py:179 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_named_tuple_array() -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_named_tuple_array[routing]() -> void: test_fixed_size_named_tuple_array: - // tests/artifacts/Arrays/immutable.py:197-198 - // @arc4.abimethod() - // def test_fixed_size_named_tuple_array(self) -> None: - proto 0 0 // tests/artifacts/Arrays/immutable.py:199 // arr = ImmutableArray[MyTuple]() bytec_2 // 0x0000 @@ -1811,17 +1331,16 @@ test_fixed_size_named_tuple_array: // for i in urange(5): intc_0 // 0 -test_fixed_size_named_tuple_array_for_header@1: +test_fixed_size_named_tuple_array_for_header@2: // tests/artifacts/Arrays/immutable.py:202 // for i in urange(5): - frame_dig 1 + dup pushint 5 // 5 < - bz test_fixed_size_named_tuple_array_after_for@4 + bz test_fixed_size_named_tuple_array_after_for@5 // tests/artifacts/Arrays/immutable.py:203 // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i * 3 % 2 == 0)) - frame_dig 1 - dup + dupn 2 intc_2 // 2 % ! @@ -1841,7 +1360,7 @@ test_fixed_size_named_tuple_array_for_header@1: uncover 3 setbit concat - frame_dig 0 + dig 3 dup uncover 2 concat // on error: max array length exceeded @@ -1853,18 +1372,18 @@ test_fixed_size_named_tuple_array_for_header@1: itob extract 6 2 replace2 0 - frame_bury 0 + bury 3 // tests/artifacts/Arrays/immutable.py:202 // for i in urange(5): intc_1 // 1 + - frame_bury 1 - b test_fixed_size_named_tuple_array_for_header@1 + bury 1 + b test_fixed_size_named_tuple_array_for_header@2 -test_fixed_size_named_tuple_array_after_for@4: +test_fixed_size_named_tuple_array_after_for@5: // tests/artifacts/Arrays/immutable.py:205 // assert arr.length == 5 - frame_dig 0 + dig 1 dup intc_0 // 0 extract_uint16 @@ -1901,16 +1420,15 @@ test_fixed_size_named_tuple_array_after_for@4: pushbytes "d" swap app_global_put - retsub + // tests/artifacts/Arrays/immutable.py:197 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_tuple_array() -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_tuple_array[routing]() -> void: test_dynamic_sized_tuple_array: - // tests/artifacts/Arrays/immutable.py:212-213 - // @arc4.abimethod() - // def test_dynamic_sized_tuple_array(self) -> None: - proto 0 0 - bytec_1 // "" + bytec_0 // "" // tests/artifacts/Arrays/immutable.py:214 // arr = ImmutableArray[tuple[UInt64, Bytes]]() bytec_2 // 0x0000 @@ -1918,22 +1436,21 @@ test_dynamic_sized_tuple_array: // for i in urange(5): intc_0 // 0 -test_dynamic_sized_tuple_array_for_header@1: +test_dynamic_sized_tuple_array_for_header@2: // tests/artifacts/Arrays/immutable.py:217 // for i in urange(5): - frame_dig 2 + dup pushint 5 // 5 < - bz test_dynamic_sized_tuple_array_after_for@4 + bz test_dynamic_sized_tuple_array_after_for@5 // tests/artifacts/Arrays/immutable.py:218 // arr = arr.append((i + 1, op.bzero(i))) - frame_dig 2 - dup + dupn 2 intc_1 // 1 + swap bzero - frame_dig 1 + dig 3 dup intc_0 // 0 extract_uint16 @@ -1959,38 +1476,38 @@ test_dynamic_sized_tuple_array_for_header@1: intc_1 // 1 uncover 3 callsub dynamic_array_concat_dynamic_element - frame_bury 1 - frame_bury 2 - b test_dynamic_sized_tuple_array_for_header@1 + bury 3 + bury 1 + b test_dynamic_sized_tuple_array_for_header@2 -test_dynamic_sized_tuple_array_after_for@4: +test_dynamic_sized_tuple_array_after_for@5: // tests/artifacts/Arrays/immutable.py:220 // assert arr.length == 5 - frame_dig 1 + dig 1 intc_0 // 0 extract_uint16 dup - frame_bury 0 + bury 4 pushint 5 // 5 == assert // tests/artifacts/Arrays/immutable.py:221 // for i in urange(5): intc_0 // 0 - frame_bury 2 + bury 1 -test_dynamic_sized_tuple_array_for_header@5: +test_dynamic_sized_tuple_array_for_header@6: // tests/artifacts/Arrays/immutable.py:221 // for i in urange(5): - frame_dig 2 + dup pushint 5 // 5 < - bz test_dynamic_sized_tuple_array_after_for@8 + bz test_dynamic_sized_tuple_array_after_for@9 // tests/artifacts/Arrays/immutable.py:222 // assert arr[i][0] == i + 1, "expected 1st element to be correct" - frame_dig 1 + dig 1 extract 2 0 - frame_dig 2 + dig 1 dup cover 2 intc_2 // 2 @@ -2001,7 +1518,7 @@ test_dynamic_sized_tuple_array_for_header@5: dig 2 intc_1 // 1 + - frame_dig 0 + dig 6 dig 1 - // on error: index access is out of bounds dig 3 @@ -2040,13 +1557,13 @@ test_dynamic_sized_tuple_array_for_header@5: uncover 2 == assert // expected 2nd element to be correct - frame_bury 2 - b test_dynamic_sized_tuple_array_for_header@5 + bury 1 + b test_dynamic_sized_tuple_array_for_header@6 -test_dynamic_sized_tuple_array_after_for@8: +test_dynamic_sized_tuple_array_after_for@9: // tests/artifacts/Arrays/immutable.py:225 // arr = arr.pop() - frame_dig 1 + dig 1 callsub dynamic_array_pop_dynamic_element bury 1 // tests/artifacts/Arrays/immutable.py:226 @@ -2153,16 +1670,15 @@ test_dynamic_sized_tuple_array_after_for@8: pushbytes "e" swap app_global_put - retsub + // tests/artifacts/Arrays/immutable.py:212 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_named_tuple_array() -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_named_tuple_array[routing]() -> void: test_dynamic_sized_named_tuple_array: - // tests/artifacts/Arrays/immutable.py:231-232 - // @arc4.abimethod() - // def test_dynamic_sized_named_tuple_array(self) -> None: - proto 0 0 - bytec_1 // "" + bytec_0 // "" // tests/artifacts/Arrays/immutable.py:233 // arr = ImmutableArray[MyDynamicSizedTuple]() bytec_2 // 0x0000 @@ -2170,22 +1686,21 @@ test_dynamic_sized_named_tuple_array: // for i in urange(5): intc_0 // 0 -test_dynamic_sized_named_tuple_array_for_header@1: +test_dynamic_sized_named_tuple_array_for_header@2: // tests/artifacts/Arrays/immutable.py:236 // for i in urange(5): - frame_dig 2 + dup pushint 5 // 5 < - bz test_dynamic_sized_named_tuple_array_after_for@4 + bz test_dynamic_sized_named_tuple_array_after_for@5 // tests/artifacts/Arrays/immutable.py:237 // arr = arr.append(MyDynamicSizedTuple(foo=i + 1, bar=times(i))) - frame_dig 2 - dup + dupn 2 intc_1 // 1 + swap callsub times - frame_dig 1 + dig 3 dup intc_0 // 0 extract_uint16 @@ -2211,38 +1726,38 @@ test_dynamic_sized_named_tuple_array_for_header@1: intc_1 // 1 uncover 3 callsub dynamic_array_concat_dynamic_element - frame_bury 1 - frame_bury 2 - b test_dynamic_sized_named_tuple_array_for_header@1 + bury 3 + bury 1 + b test_dynamic_sized_named_tuple_array_for_header@2 -test_dynamic_sized_named_tuple_array_after_for@4: +test_dynamic_sized_named_tuple_array_after_for@5: // tests/artifacts/Arrays/immutable.py:239 // assert arr.length == 5 - frame_dig 1 + dig 1 intc_0 // 0 extract_uint16 dup - frame_bury 0 + bury 4 pushint 5 // 5 == assert // tests/artifacts/Arrays/immutable.py:240 // for i in urange(5): intc_0 // 0 - frame_bury 2 + bury 1 -test_dynamic_sized_named_tuple_array_for_header@5: +test_dynamic_sized_named_tuple_array_for_header@6: // tests/artifacts/Arrays/immutable.py:240 // for i in urange(5): - frame_dig 2 + dup pushint 5 // 5 < - bz test_dynamic_sized_named_tuple_array_after_for@8 + bz test_dynamic_sized_named_tuple_array_after_for@9 // tests/artifacts/Arrays/immutable.py:241 // assert arr[i][0] == i + 1, "expected 1st element to be correct" - frame_dig 1 + dig 1 extract 2 0 - frame_dig 2 + dig 1 dup cover 2 intc_2 // 2 @@ -2253,7 +1768,7 @@ test_dynamic_sized_named_tuple_array_for_header@5: dig 2 intc_1 // 1 + - frame_dig 0 + dig 6 dig 1 - // on error: index access is out of bounds dig 3 @@ -2292,13 +1807,13 @@ test_dynamic_sized_named_tuple_array_for_header@5: callsub times == assert // expected 2nd element to be correct - frame_bury 2 - b test_dynamic_sized_named_tuple_array_for_header@5 + bury 1 + b test_dynamic_sized_named_tuple_array_for_header@6 -test_dynamic_sized_named_tuple_array_after_for@8: +test_dynamic_sized_named_tuple_array_after_for@9: // tests/artifacts/Arrays/immutable.py:244 // arr = arr.pop() - frame_dig 1 + dig 1 callsub dynamic_array_pop_dynamic_element bury 1 // tests/artifacts/Arrays/immutable.py:245 @@ -2349,7 +1864,7 @@ test_dynamic_sized_named_tuple_array_after_for@8: intc_1 // 1 == swap - bytec_1 // "" + bytec_0 // "" == && assert // expected 1, 0 @@ -2403,84 +1918,90 @@ test_dynamic_sized_named_tuple_array_after_for@8: pushbytes "f" swap app_global_put - retsub + // tests/artifacts/Arrays/immutable.py:231 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_log(arr: bytes) -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_log[routing]() -> void: test_implicit_conversion_log: - // tests/artifacts/Arrays/immutable.py:250-251 + // tests/artifacts/Arrays/immutable.py:250 // @arc4.abimethod() - // def test_implicit_conversion_log(self, arr: ImmutableArray[UInt64]) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/Arrays/immutable.py:252 // log(arr) - frame_dig -1 log - retsub + // tests/artifacts/Arrays/immutable.py:250 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_emit(arr: bytes) -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_emit[routing]() -> void: test_implicit_conversion_emit: - // tests/artifacts/Arrays/immutable.py:254-255 - // @arc4.abimethod() - // def test_implicit_conversion_emit(self, arr: ImmutableArray[UInt64]) -> None: - proto 1 0 // tests/artifacts/Arrays/immutable.py:256 // arc4.emit("emit_test", arr) pushbytes 0xfa40c0530002 - frame_dig -1 + // tests/artifacts/Arrays/immutable.py:254 + // @arc4.abimethod() + txna ApplicationArgs 1 + // tests/artifacts/Arrays/immutable.py:256 + // arc4.emit("emit_test", arr) concat log - retsub + // tests/artifacts/Arrays/immutable.py:254 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_nested_array(arr_to_add: uint64, arr: bytes) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_nested_array[routing]() -> void: test_nested_array: - // tests/artifacts/Arrays/immutable.py:258-261 - // @arc4.abimethod() - // def test_nested_array( - // self, arr_to_add: UInt64, arr: ImmutableArray[ImmutableArray[UInt64]] - // ) -> ImmutableArray[UInt64]: - proto 2 1 intc_0 // 0 dupn 2 - bytec_1 // "" + bytec_0 // "" dupn 5 + // tests/artifacts/Arrays/immutable.py:258 + // @arc4.abimethod() + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 // tests/artifacts/Arrays/immutable.py:262-263 // # add n new arrays // for i in urange(arr_to_add): intc_0 // 0 -test_nested_array_for_header@1: +test_nested_array_for_header@2: // tests/artifacts/Arrays/immutable.py:262-263 // # add n new arrays // for i in urange(arr_to_add): - frame_dig 9 - frame_dig -2 + dup + dig 3 < - bz test_nested_array_after_for@8 + bz test_nested_array_after_for@9 // tests/artifacts/Arrays/immutable.py:264 // extra_arr = ImmutableArray[UInt64]() bytec_2 // 0x0000 - frame_bury 0 + bury 12 // tests/artifacts/Arrays/immutable.py:265 // for j in urange(i): intc_0 // 0 - frame_bury 7 + bury 5 -test_nested_array_for_header@3: +test_nested_array_for_header@4: // tests/artifacts/Arrays/immutable.py:265 // for j in urange(i): - frame_dig 7 - frame_dig 9 + dig 4 + dig 1 < - bz test_nested_array_after_for@6 + bz test_nested_array_after_for@7 // tests/artifacts/Arrays/immutable.py:266 // extra_arr = extra_arr.append(j) - frame_dig 7 + dig 4 dup itob - frame_dig 0 + dig 13 dup uncover 2 concat // on error: max array length exceeded @@ -2492,64 +2013,65 @@ test_nested_array_for_header@3: itob extract 6 2 replace2 0 - frame_bury 0 + bury 13 // tests/artifacts/Arrays/immutable.py:265 // for j in urange(i): intc_1 // 1 + - frame_bury 7 - b test_nested_array_for_header@3 + bury 5 + b test_nested_array_for_header@4 -test_nested_array_after_for@6: +test_nested_array_after_for@7: // tests/artifacts/Arrays/immutable.py:267 // arr = arr.append(extra_arr) - frame_dig -1 + dig 1 + dup intc_0 // 0 extract_uint16 - frame_dig -1 + swap extract 2 0 bytec 4 // 0x0002 - frame_dig 0 + dig 14 concat cover 2 intc_1 // 1 uncover 3 callsub dynamic_array_concat_dynamic_element - frame_bury -1 + bury 2 // tests/artifacts/Arrays/immutable.py:262-263 // # add n new arrays // for i in urange(arr_to_add): - frame_dig 9 + dup intc_1 // 1 + - frame_bury 9 - b test_nested_array_for_header@1 + bury 1 + b test_nested_array_for_header@2 -test_nested_array_after_for@8: +test_nested_array_after_for@9: // tests/artifacts/Arrays/immutable.py:269-270 // # sum inner arrays and return an array containing sums // totals = ImmutableArray[UInt64]() bytec_2 // 0x0000 - frame_bury 2 + bury 10 // tests/artifacts/Arrays/immutable.py:271 // for inner_arr in arr: - frame_dig -1 + dig 1 intc_0 // 0 extract_uint16 - frame_bury 3 + bury 9 intc_0 // 0 - frame_bury 5 + bury 7 -test_nested_array_for_header@9: +test_nested_array_for_header@10: // tests/artifacts/Arrays/immutable.py:271 // for inner_arr in arr: - frame_dig 5 - frame_dig 3 + dig 6 + dig 9 < - bz test_nested_array_after_for@12 - frame_dig -1 + bz test_nested_array_after_for@13 + dig 1 extract 2 0 - frame_dig 5 + dig 7 intc_2 // 2 * dig 1 @@ -2563,29 +2085,29 @@ test_nested_array_for_header@9: + extract3 dup - frame_bury 1 + bury 12 // tests/artifacts/Arrays/immutable.py:519 // total = UInt64() intc_0 // 0 - frame_bury 8 + bury 5 // tests/artifacts/Arrays/immutable.py:520 // for i in arr: intc_0 // 0 extract_uint16 - frame_bury 4 + bury 8 intc_0 // 0 - frame_bury 6 + bury 6 -test_nested_array_for_header@14: +test_nested_array_for_header@15: // tests/artifacts/Arrays/immutable.py:520 // for i in arr: - frame_dig 6 - frame_dig 4 + dig 5 + dig 8 < - bz test_nested_array_after_for@16 - frame_dig 1 + bz test_nested_array_after_for@17 + dig 10 extract 2 0 - frame_dig 6 + dig 6 dup cover 2 intc_3 // 8 @@ -2593,20 +2115,20 @@ test_nested_array_for_header@14: extract_uint64 // tests/artifacts/Arrays/immutable.py:521 // total += i - frame_dig 8 + dig 5 + - frame_bury 8 + bury 5 intc_1 // 1 + - frame_bury 6 - b test_nested_array_for_header@14 + bury 6 + b test_nested_array_for_header@15 -test_nested_array_after_for@16: +test_nested_array_after_for@17: // tests/artifacts/Arrays/immutable.py:272 // totals = totals.append(sum_arr(inner_arr)) - frame_dig 8 + dig 3 itob - frame_dig 2 + dig 10 dup uncover 2 concat // on error: max array length exceeded @@ -2618,27 +2140,26 @@ test_nested_array_after_for@16: itob extract 6 2 replace2 0 - frame_bury 2 - frame_dig 5 + bury 10 + dig 6 intc_1 // 1 + - frame_bury 5 - b test_nested_array_for_header@9 + bury 7 + b test_nested_array_for_header@10 -test_nested_array_after_for@12: - // tests/artifacts/Arrays/immutable.py:274 - // return totals - frame_dig 2 - frame_bury 0 - retsub +test_nested_array_after_for@13: + // tests/artifacts/Arrays/immutable.py:258 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + dig 10 + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bit_packed_tuples() -> void: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bit_packed_tuples[routing]() -> void: test_bit_packed_tuples: - // tests/artifacts/Arrays/immutable.py:276-277 - // @arc4.abimethod() - // def test_bit_packed_tuples(self) -> None: - proto 0 0 // tests/artifacts/Arrays/immutable.py:278 // arr2 = ImmutableArray[TwoBoolTuple]() bytec_2 // 0x0000 @@ -2651,17 +2172,16 @@ test_bit_packed_tuples: // for i in urange(5): intc_0 // 0 -test_bit_packed_tuples_for_header@1: +test_bit_packed_tuples_for_header@2: // tests/artifacts/Arrays/immutable.py:287 // for i in urange(5): - frame_dig 4 + dup pushint 5 // 5 < - bz test_bit_packed_tuples_after_for@4 + bz test_bit_packed_tuples_after_for@5 // tests/artifacts/Arrays/immutable.py:288 // arr2 = arr2.append(TwoBoolTuple(a=i == 0, b=i == 1)) - frame_dig 4 - dup + dupn 2 ! dig 1 intc_1 // 1 @@ -2673,7 +2193,7 @@ test_bit_packed_tuples_for_header@1: intc_1 // 1 uncover 2 setbit - frame_dig 0 + dig 6 dup cover 2 dig 1 @@ -2686,7 +2206,7 @@ test_bit_packed_tuples_for_header@1: itob extract 6 2 replace2 0 - frame_bury 0 + bury 7 // tests/artifacts/Arrays/immutable.py:295 // c=i == 2, dig 1 @@ -2756,7 +2276,7 @@ test_bit_packed_tuples_for_header@1: swap dig 1 concat - frame_dig 1 + dig 9 dup uncover 2 concat // on error: max array length exceeded @@ -2768,7 +2288,7 @@ test_bit_packed_tuples_for_header@1: itob extract 6 2 replace2 0 - frame_bury 1 + bury 9 // tests/artifacts/Arrays/immutable.py:313 // h=i == 7, dig 4 @@ -2799,7 +2319,7 @@ test_bit_packed_tuples_for_header@1: dup dig 2 concat - frame_dig 2 + dig 7 dup uncover 2 concat // on error: max array length exceeded @@ -2811,7 +2331,7 @@ test_bit_packed_tuples_for_header@1: itob extract 6 2 replace2 0 - frame_bury 2 + bury 7 // tests/artifacts/Arrays/immutable.py:328 // i=i == 8, uncover 3 @@ -2840,7 +2360,7 @@ test_bit_packed_tuples_for_header@1: concat swap concat - frame_dig 3 + dig 3 dup uncover 2 concat // on error: max array length exceeded @@ -2852,14 +2372,14 @@ test_bit_packed_tuples_for_header@1: itob extract 6 2 replace2 0 - frame_bury 3 - frame_bury 4 - b test_bit_packed_tuples_for_header@1 + bury 3 + bury 1 + b test_bit_packed_tuples_for_header@2 -test_bit_packed_tuples_after_for@4: +test_bit_packed_tuples_after_for@5: // tests/artifacts/Arrays/immutable.py:332 // assert arr2.length == 5 - frame_dig 0 + dig 4 dup intc_0 // 0 extract_uint16 @@ -2868,7 +2388,7 @@ test_bit_packed_tuples_after_for@4: assert // tests/artifacts/Arrays/immutable.py:333 // assert arr7.length == 5 - frame_dig 1 + dig 4 dup intc_0 // 0 extract_uint16 @@ -2877,7 +2397,7 @@ test_bit_packed_tuples_after_for@4: assert // tests/artifacts/Arrays/immutable.py:334 // assert arr8.length == 5 - frame_dig 2 + dig 4 dup intc_0 // 0 extract_uint16 @@ -2886,7 +2406,7 @@ test_bit_packed_tuples_after_for@4: assert // tests/artifacts/Arrays/immutable.py:335 // assert arr9.length == 5 - frame_dig 3 + dig 4 dup intc_0 // 0 extract_uint16 @@ -2913,44 +2433,45 @@ test_bit_packed_tuples_after_for@4: pushbytes "bool9" swap app_global_put - retsub + // tests/artifacts/Arrays/immutable.py:276 + // @arc4.abimethod() + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.sum_uints_and_lengths_and_trues(arr1: bytes, arr2: bytes, arr3: bytes, arr4: bytes) -> uint64, uint64, uint64, uint64: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.sum_uints_and_lengths_and_trues[routing]() -> void: sum_uints_and_lengths_and_trues: - // tests/artifacts/Arrays/immutable.py:341-348 + bytec_0 // "" + dupn 6 + // tests/artifacts/Arrays/immutable.py:341 // @arc4.abimethod() - // def sum_uints_and_lengths_and_trues( - // self, - // arr1: ImmutableArray[UInt64], - // arr2: ImmutableArray[bool], - // arr3: ImmutableArray[MyTuple], - // arr4: ImmutableArray[MyDynamicSizedTuple], - // ) -> tuple[UInt64, UInt64, UInt64, UInt64]: - proto 4 4 - bytec_1 // "" - dupn 8 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + txna ApplicationArgs 3 + txna ApplicationArgs 4 // tests/artifacts/Arrays/immutable.py:349 // sum1 = sum2 = sum3 = sum4 = UInt64() intc_0 // 0 dupn 3 + // tests/artifacts/Arrays/immutable.py:341 + // @arc4.abimethod() + txna ApplicationArgs 1 // tests/artifacts/Arrays/immutable.py:350 // for i in arr1: - frame_dig -4 intc_0 // 0 extract_uint16 intc_0 // 0 -sum_uints_and_lengths_and_trues_for_header@1: +sum_uints_and_lengths_and_trues_for_header@2: // tests/artifacts/Arrays/immutable.py:350 // for i in arr1: - frame_dig 14 - frame_dig 13 + dup + dig 2 < - bz sum_uints_and_lengths_and_trues_after_for@4 - frame_dig -4 + bz sum_uints_and_lengths_and_trues_after_for@5 + dig 9 extract 2 0 - frame_dig 14 + dig 1 dup cover 2 intc_3 // 8 @@ -2958,78 +2479,74 @@ sum_uints_and_lengths_and_trues_for_header@1: extract_uint64 // tests/artifacts/Arrays/immutable.py:351 // sum1 += i - frame_dig 12 + dig 4 + - frame_bury 12 + bury 4 intc_1 // 1 + - frame_bury 14 - b sum_uints_and_lengths_and_trues_for_header@1 + bury 1 + b sum_uints_and_lengths_and_trues_for_header@2 -sum_uints_and_lengths_and_trues_after_for@4: +sum_uints_and_lengths_and_trues_after_for@5: // tests/artifacts/Arrays/immutable.py:352 // for b in arr2: - frame_dig -3 + dig 8 intc_0 // 0 extract_uint16 - frame_bury 0 + bury 17 intc_0 // 0 - frame_bury 4 + bury 13 -sum_uints_and_lengths_and_trues_for_header@5: +sum_uints_and_lengths_and_trues_for_header@6: // tests/artifacts/Arrays/immutable.py:352 // for b in arr2: - frame_dig 4 - frame_dig 0 + dig 12 + dig 17 < - bz sum_uints_and_lengths_and_trues_after_for@10 - frame_dig 4 + bz sum_uints_and_lengths_and_trues_after_for@11 + dig 12 pushint 16 // 16 + - frame_dig -3 + dig 9 swap getbit - frame_dig 11 - frame_bury 6 // tests/artifacts/Arrays/immutable.py:353 // if b: - bz sum_uints_and_lengths_and_trues_after_if_else@8 + bz sum_uints_and_lengths_and_trues_after_if_else@9 // tests/artifacts/Arrays/immutable.py:354 // sum2 += 1 - frame_dig 11 + dig 3 intc_1 // 1 + - frame_bury 6 + bury 4 -sum_uints_and_lengths_and_trues_after_if_else@8: - frame_dig 6 - frame_bury 11 - frame_dig 4 +sum_uints_and_lengths_and_trues_after_if_else@9: + dig 12 intc_1 // 1 + - frame_bury 4 - b sum_uints_and_lengths_and_trues_for_header@5 + bury 13 + b sum_uints_and_lengths_and_trues_for_header@6 -sum_uints_and_lengths_and_trues_after_for@10: +sum_uints_and_lengths_and_trues_after_for@11: // tests/artifacts/Arrays/immutable.py:355 // for tup in arr3: - frame_dig -2 + dig 7 intc_0 // 0 extract_uint16 - frame_bury 1 + bury 16 intc_0 // 0 - frame_bury 5 + bury 12 -sum_uints_and_lengths_and_trues_for_header@11: +sum_uints_and_lengths_and_trues_for_header@12: // tests/artifacts/Arrays/immutable.py:355 // for tup in arr3: - frame_dig 5 - frame_dig 1 + dig 11 + dig 16 < - bz sum_uints_and_lengths_and_trues_after_for@18 - frame_dig -2 + bz sum_uints_and_lengths_and_trues_after_for@19 + dig 7 extract 2 0 - frame_dig 5 + dig 12 pushint 9 // 9 * pushint 9 // 9 @@ -3043,70 +2560,62 @@ sum_uints_and_lengths_and_trues_for_header@11: uncover 2 pushint 65 // 65 getbit - frame_bury 8 + bury 13 // tests/artifacts/Arrays/immutable.py:356 // sum3 += tup.foo - frame_dig 10 + dig 6 uncover 2 + - dup - frame_bury 10 - frame_bury 7 + bury 6 // tests/artifacts/Arrays/immutable.py:357 // if tup.bar: - bz sum_uints_and_lengths_and_trues_after_if_else@14 + bz sum_uints_and_lengths_and_trues_after_if_else@15 // tests/artifacts/Arrays/immutable.py:358 // sum3 += 1 - frame_dig 10 + dig 4 intc_1 // 1 + - frame_bury 7 + bury 5 -sum_uints_and_lengths_and_trues_after_if_else@14: - frame_dig 7 - dup - frame_bury 10 - frame_bury 7 +sum_uints_and_lengths_and_trues_after_if_else@15: // tests/artifacts/Arrays/immutable.py:359 // if tup.baz: - frame_dig 8 - bz sum_uints_and_lengths_and_trues_after_if_else@16 + dig 10 + bz sum_uints_and_lengths_and_trues_after_if_else@17 // tests/artifacts/Arrays/immutable.py:360 // sum3 += 1 - frame_dig 10 + dig 4 intc_1 // 1 + - frame_bury 7 + bury 5 -sum_uints_and_lengths_and_trues_after_if_else@16: - frame_dig 7 - frame_bury 10 - frame_dig 5 +sum_uints_and_lengths_and_trues_after_if_else@17: + dig 11 intc_1 // 1 + - frame_bury 5 - b sum_uints_and_lengths_and_trues_for_header@11 + bury 12 + b sum_uints_and_lengths_and_trues_for_header@12 -sum_uints_and_lengths_and_trues_after_for@18: +sum_uints_and_lengths_and_trues_after_for@19: // tests/artifacts/Arrays/immutable.py:361 // for idx, dyn_tup in uenumerate(arr4): - frame_dig -1 + dig 6 intc_0 // 0 extract_uint16 - frame_bury 2 + bury 15 intc_0 // 0 - frame_bury 3 + bury 14 -sum_uints_and_lengths_and_trues_for_header@19: +sum_uints_and_lengths_and_trues_for_header@20: // tests/artifacts/Arrays/immutable.py:361 // for idx, dyn_tup in uenumerate(arr4): - frame_dig 3 - frame_dig 2 + dig 13 + dig 15 < - bz sum_uints_and_lengths_and_trues_after_for@22 - frame_dig -1 + bz sum_uints_and_lengths_and_trues_after_for@23 + dig 6 extract 2 0 - frame_dig 3 + dig 14 dup cover 2 intc_2 // 2 @@ -3117,7 +2626,7 @@ sum_uints_and_lengths_and_trues_for_header@19: dig 2 intc_1 // 1 + - frame_dig 2 + dig 18 dig 1 - // on error: index access is out of bounds dig 3 @@ -3148,7 +2657,7 @@ sum_uints_and_lengths_and_trues_for_header@19: extract 2 0 // tests/artifacts/Arrays/immutable.py:362 // sum4 += dyn_tup.foo - frame_dig 9 + dig 9 uncover 2 + // tests/artifacts/Arrays/immutable.py:363 @@ -3158,35 +2667,43 @@ sum_uints_and_lengths_and_trues_for_header@19: swap dig 1 + - frame_bury 9 + bury 9 // tests/artifacts/Arrays/immutable.py:364 // assert dyn_tup.bar.bytes.length == idx, "expected string length to match index" uncover 2 == assert // expected string length to match index - frame_bury 3 - b sum_uints_and_lengths_and_trues_for_header@19 - -sum_uints_and_lengths_and_trues_after_for@22: - // tests/artifacts/Arrays/immutable.py:366 - // return sum1, sum2, sum3, sum4 - frame_dig 12 - frame_dig 11 - frame_dig 10 - frame_dig 9 - frame_bury 3 - frame_bury 2 - frame_bury 1 - frame_bury 0 - retsub + bury 14 + b sum_uints_and_lengths_and_trues_for_header@20 + +sum_uints_and_lengths_and_trues_after_for@23: + // tests/artifacts/Arrays/immutable.py:341 + // @arc4.abimethod() + dig 2 + itob + dig 4 + itob + concat + dig 5 + itob + concat + dig 6 + itob + concat + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_return(append: uint64) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_return[routing]() -> void: test_uint64_return: - // tests/artifacts/Arrays/immutable.py:368-369 + // tests/artifacts/Arrays/immutable.py:368 // @arc4.abimethod() - // def test_uint64_return(self, append: UInt64) -> ImmutableArray[UInt64]: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/Arrays/immutable.py:370 // arr = ImmutableArray(UInt64(1), UInt64(2), UInt64(3)) pushbytes 0x0003000000000000000100000000000000020000000000000003 @@ -3194,19 +2711,18 @@ test_uint64_return: // for i in urange(append): intc_0 // 0 -test_uint64_return_for_header@1: +test_uint64_return_for_header@2: // tests/artifacts/Arrays/immutable.py:371 // for i in urange(append): - frame_dig 1 - frame_dig -1 + dup + dig 3 < - bz test_uint64_return_after_for@4 + bz test_uint64_return_after_for@5 // tests/artifacts/Arrays/immutable.py:372 // arr = arr.append(i) - frame_dig 1 - dup + dupn 2 itob - frame_dig 0 + dig 3 dup uncover 2 concat // on error: max array length exceeded @@ -3218,26 +2734,31 @@ test_uint64_return_for_header@1: itob extract 6 2 replace2 0 - frame_bury 0 + bury 3 // tests/artifacts/Arrays/immutable.py:371 // for i in urange(append): intc_1 // 1 + - frame_bury 1 - b test_uint64_return_for_header@1 + bury 1 + b test_uint64_return_for_header@2 -test_uint64_return_after_for@4: - // tests/artifacts/Arrays/immutable.py:373 - // return arr - retsub +test_uint64_return_after_for@5: + // tests/artifacts/Arrays/immutable.py:368 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + dig 2 + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_return(append: uint64) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_return[routing]() -> void: test_bool_return: - // tests/artifacts/Arrays/immutable.py:375-376 + // tests/artifacts/Arrays/immutable.py:375 // @arc4.abimethod() - // def test_bool_return(self, append: UInt64) -> ImmutableArray[bool]: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/Arrays/immutable.py:377 // arr = ImmutableArray(True, False, True, False, True) pushbytes 0x0005a8 @@ -3245,17 +2766,16 @@ test_bool_return: // for i in urange(append): intc_0 // 0 -test_bool_return_for_header@1: +test_bool_return_for_header@2: // tests/artifacts/Arrays/immutable.py:378 // for i in urange(append): - frame_dig 1 - frame_dig -1 + dup + dig 3 < - bz test_bool_return_after_for@4 + bz test_bool_return_after_for@5 // tests/artifacts/Arrays/immutable.py:379 // arr = arr.append(i % 2 == 0) - frame_dig 1 - dup + dupn 2 intc_2 // 2 % ! @@ -3263,31 +2783,36 @@ test_bool_return_for_header@1: intc_0 // 0 uncover 2 setbit - frame_dig 0 + dig 3 swap intc_1 // 1 intc_3 // 8 callsub dynamic_array_concat_bits - frame_bury 0 + bury 3 // tests/artifacts/Arrays/immutable.py:378 // for i in urange(append): intc_1 // 1 + - frame_bury 1 - b test_bool_return_for_header@1 + bury 1 + b test_bool_return_for_header@2 -test_bool_return_after_for@4: - // tests/artifacts/Arrays/immutable.py:380 - // return arr - retsub +test_bool_return_after_for@5: + // tests/artifacts/Arrays/immutable.py:375 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + dig 2 + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_tuple_return(append: uint64) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_tuple_return[routing]() -> void: test_tuple_return: - // tests/artifacts/Arrays/immutable.py:382-383 + // tests/artifacts/Arrays/immutable.py:382 // @arc4.abimethod() - // def test_tuple_return(self, append: UInt64) -> ImmutableArray[MyTuple]: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/Arrays/immutable.py:384 // arr = ImmutableArray(MyTuple(UInt64(), True, False)) pushbytes 0x0001000000000000000080 @@ -3295,17 +2820,16 @@ test_tuple_return: // for i in urange(append): intc_0 // 0 -test_tuple_return_for_header@1: +test_tuple_return_for_header@2: // tests/artifacts/Arrays/immutable.py:385 // for i in urange(append): - frame_dig 1 - frame_dig -1 + dup + dig 3 < - bz test_tuple_return_after_for@4 + bz test_tuple_return_after_for@5 // tests/artifacts/Arrays/immutable.py:386 // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0)) - frame_dig 1 - dup + dupn 2 intc_2 // 2 % ! @@ -3323,7 +2847,7 @@ test_tuple_return_for_header@1: uncover 3 setbit concat - frame_dig 0 + dig 3 dup uncover 2 concat // on error: max array length exceeded @@ -3335,26 +2859,31 @@ test_tuple_return_for_header@1: itob extract 6 2 replace2 0 - frame_bury 0 + bury 3 // tests/artifacts/Arrays/immutable.py:385 // for i in urange(append): intc_1 // 1 + - frame_bury 1 - b test_tuple_return_for_header@1 + bury 1 + b test_tuple_return_for_header@2 -test_tuple_return_after_for@4: - // tests/artifacts/Arrays/immutable.py:387 - // return arr - retsub +test_tuple_return_after_for@5: + // tests/artifacts/Arrays/immutable.py:382 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + dig 2 + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_tuple_return(append: uint64) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_tuple_return[routing]() -> void: test_dynamic_tuple_return: - // tests/artifacts/Arrays/immutable.py:389-390 + // tests/artifacts/Arrays/immutable.py:389 // @arc4.abimethod() - // def test_dynamic_tuple_return(self, append: UInt64) -> ImmutableArray[MyDynamicSizedTuple]: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/Arrays/immutable.py:391 // arr = ImmutableArray(MyDynamicSizedTuple(UInt64(), String("Hello"))) pushbytes 0x000100020000000000000000000a000548656c6c6f @@ -3362,19 +2891,18 @@ test_dynamic_tuple_return: // for i in urange(append): intc_0 // 0 -test_dynamic_tuple_return_for_header@1: +test_dynamic_tuple_return_for_header@2: // tests/artifacts/Arrays/immutable.py:392 // for i in urange(append): - frame_dig 1 - frame_dig -1 + dup + dig 3 < - bz test_dynamic_tuple_return_after_for@4 + bz test_dynamic_tuple_return_after_for@5 // tests/artifacts/Arrays/immutable.py:393 // arr = arr.append(MyDynamicSizedTuple(i, times(i))) - frame_dig 1 - dup + dupn 2 callsub times - frame_dig 0 + dig 3 dup intc_0 // 0 extract_uint16 @@ -3400,47 +2928,50 @@ test_dynamic_tuple_return_for_header@1: intc_1 // 1 uncover 3 callsub dynamic_array_concat_dynamic_element - frame_bury 0 + bury 3 // tests/artifacts/Arrays/immutable.py:392 // for i in urange(append): intc_1 // 1 + - frame_bury 1 - b test_dynamic_tuple_return_for_header@1 + bury 1 + b test_dynamic_tuple_return_for_header@2 -test_dynamic_tuple_return_after_for@4: - // tests/artifacts/Arrays/immutable.py:394 - // return arr - retsub +test_dynamic_tuple_return_after_for@5: + // tests/artifacts/Arrays/immutable.py:389 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + dig 2 + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_convert_to_array_and_back(arr: bytes, append: uint64) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_convert_to_array_and_back[routing]() -> void: test_convert_to_array_and_back: - // tests/artifacts/Arrays/immutable.py:396-399 + // tests/artifacts/Arrays/immutable.py:396 // @arc4.abimethod() - // def test_convert_to_array_and_back( - // self, arr: ImmutableArray[MyTuple], append: UInt64 - // ) -> ImmutableArray[MyTuple]: - proto 2 1 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + btoi + swap // tests/artifacts/Arrays/immutable.py:401 // mutable.extend(arr) - frame_dig -2 extract 2 0 // tests/artifacts/Arrays/immutable.py:402 // for i in urange(append): intc_0 // 0 -test_convert_to_array_and_back_for_header@1: +test_convert_to_array_and_back_for_header@2: // tests/artifacts/Arrays/immutable.py:402 // for i in urange(append): - frame_dig 1 - frame_dig -1 + dup + dig 3 < - bz test_convert_to_array_and_back_after_for@4 + bz test_convert_to_array_and_back_after_for@5 // tests/artifacts/Arrays/immutable.py:403 // mutable.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0)) - frame_dig 1 - dup + dupn 2 intc_2 // 2 % ! @@ -3448,7 +2979,7 @@ test_convert_to_array_and_back_for_header@1: pushint 3 // 3 % ! - frame_dig 0 + dig 4 cover 3 dig 2 itob @@ -3463,16 +2994,16 @@ test_convert_to_array_and_back_for_header@1: uncover 2 swap concat // on error: max array length exceeded - frame_bury 0 + bury 3 // tests/artifacts/Arrays/immutable.py:402 // for i in urange(append): intc_1 // 1 + - frame_bury 1 - b test_convert_to_array_and_back_for_header@1 + bury 1 + b test_convert_to_array_and_back_for_header@2 -test_convert_to_array_and_back_after_for@4: - frame_dig 0 +test_convert_to_array_and_back_after_for@5: + dig 1 // tests/artifacts/Arrays/immutable.py:404 // return mutable.freeze() dup @@ -3483,24 +3014,26 @@ test_convert_to_array_and_back_after_for@4: extract 6 2 swap concat - frame_bury 0 - retsub + // tests/artifacts/Arrays/immutable.py:396 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_arc4_tuple(arg: bytes) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_arc4_tuple[routing]() -> void: test_concat_with_arc4_tuple: - // tests/artifacts/Arrays/immutable.py:406-409 - // @arc4.abimethod() - // def test_concat_with_arc4_tuple( - // self, arg: arc4.Tuple[arc4.UInt64, arc4.UInt64] - // ) -> ImmutableArray[arc4.UInt64]: - proto 1 1 // tests/artifacts/Arrays/immutable.py:410 // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2)) bytec 8 // 0x000200000000000000010000000000000002 + // tests/artifacts/Arrays/immutable.py:406 + // @arc4.abimethod() + txna ApplicationArgs 1 // tests/artifacts/Arrays/immutable.py:411 // result = prefix + arg - frame_dig -1 concat // on error: max array length exceeded dup extract 2 0 @@ -3510,23 +3043,27 @@ test_concat_with_arc4_tuple: itob extract 6 2 replace2 0 - // tests/artifacts/Arrays/immutable.py:412 - // return result - retsub + // tests/artifacts/Arrays/immutable.py:406 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_native_tuple(arg.0: bytes, arg.1: bytes) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_native_tuple[routing]() -> void: test_concat_with_native_tuple: - // tests/artifacts/Arrays/immutable.py:414-417 + // tests/artifacts/Arrays/immutable.py:414 // @arc4.abimethod() - // def test_concat_with_native_tuple( - // self, arg: tuple[arc4.UInt64, arc4.UInt64] - // ) -> ImmutableArray[arc4.UInt64]: - proto 2 1 + txna ApplicationArgs 1 + dup + extract 0 8 + swap + extract 8 8 // tests/artifacts/Arrays/immutable.py:419 // result = prefix + arg - frame_dig -2 - frame_dig -1 concat // tests/artifacts/Arrays/immutable.py:418 // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2)) @@ -3537,27 +3074,24 @@ test_concat_with_native_tuple: concat // on error: max array length exceeded pushbytes 0x0004 replace2 0 - // tests/artifacts/Arrays/immutable.py:420 - // return result - retsub + // tests/artifacts/Arrays/immutable.py:414 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_arc4_tuple(arg: bytes) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_arc4_tuple[routing]() -> void: test_dynamic_concat_with_arc4_tuple: - // tests/artifacts/Arrays/immutable.py:422-425 + // tests/artifacts/Arrays/immutable.py:422 // @arc4.abimethod() - // def test_dynamic_concat_with_arc4_tuple( - // self, arg: arc4.Tuple[arc4.String, arc4.String] - // ) -> ImmutableArray[arc4.String]: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/Arrays/immutable.py:427 // result = prefix + arg - frame_dig -1 - len - frame_dig -1 - pushint 4 // 4 - uncover 2 - substring3 + extract 4 0 // tests/artifacts/Arrays/immutable.py:426 // prefix = ImmutableArray(arc4.String("a"), arc4.String("b")) bytec 9 // 0x000200040007000161000162 @@ -3566,23 +3100,39 @@ test_dynamic_concat_with_arc4_tuple: swap intc_2 // 2 callsub dynamic_array_concat_byte_length_head - // tests/artifacts/Arrays/immutable.py:428 - // return result - retsub + // tests/artifacts/Arrays/immutable.py:422 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_native_tuple(arg.0: bytes, arg.1: bytes) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_native_tuple[routing]() -> void: test_dynamic_concat_with_native_tuple: - // tests/artifacts/Arrays/immutable.py:430-433 + // tests/artifacts/Arrays/immutable.py:430 // @arc4.abimethod() - // def test_dynamic_concat_with_native_tuple( - // self, arg: tuple[arc4.String, arc4.String] - // ) -> ImmutableArray[arc4.String]: - proto 2 1 + txna ApplicationArgs 1 + dup + intc_0 // 0 + extract_uint16 + dig 1 + intc_2 // 2 + extract_uint16 + dig 2 + uncover 2 + dig 2 + substring3 + dig 2 + len + uncover 3 + uncover 3 + uncover 2 + substring3 // tests/artifacts/Arrays/immutable.py:435 // result = prefix + arg - frame_dig -2 - frame_dig -1 concat // tests/artifacts/Arrays/immutable.py:434 // prefix = ImmutableArray(arc4.String("a"), arc4.String("b")) @@ -3592,44 +3142,57 @@ test_dynamic_concat_with_native_tuple: swap intc_2 // 2 callsub dynamic_array_concat_byte_length_head - // tests/artifacts/Arrays/immutable.py:436 - // return result - retsub + // tests/artifacts/Arrays/immutable.py:430 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_immutable_dynamic(imm1: bytes, imm2: bytes) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_immutable_dynamic[routing]() -> void: test_concat_immutable_dynamic: - // tests/artifacts/Arrays/immutable.py:438-441 + // tests/artifacts/Arrays/immutable.py:438 // @arc4.abimethod() - // def test_concat_immutable_dynamic( - // self, imm1: ImmutableArray[MyDynamicSizedTuple], imm2: ImmutableArray[MyDynamicSizedTuple] - // ) -> ImmutableArray[MyDynamicSizedTuple]: - proto 2 1 + txna ApplicationArgs 1 + txna ApplicationArgs 2 // tests/artifacts/Arrays/immutable.py:442 // return imm1 + imm2 - frame_dig -2 + dig 1 intc_0 // 0 extract_uint16 - frame_dig -2 + uncover 2 extract 2 0 - frame_dig -1 + dig 2 + extract 2 0 + uncover 3 intc_0 // 0 extract_uint16 - frame_dig -1 - extract 2 0 + uncover 3 + uncover 3 + uncover 2 + uncover 3 callsub dynamic_array_concat_dynamic_element - retsub + // tests/artifacts/Arrays/immutable.py:438 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_immutable_arc4(imm: bytes) -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_immutable_arc4[routing]() -> void: test_immutable_arc4: - // tests/artifacts/Arrays/immutable.py:444-445 + // tests/artifacts/Arrays/immutable.py:444 // @arc4.abimethod() - // def test_immutable_arc4(self, imm: ImmutableArray[MyStruct]) -> ImmutableArray[MyStruct]: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/Arrays/immutable.py:446 // assert imm, "expected non empty array" - frame_dig -1 + dup intc_0 // 0 extract_uint16 dup @@ -3638,31 +3201,28 @@ test_immutable_arc4: // imm = imm.replace(imm.length - 1, imm[0]) intc_1 // 1 - - frame_dig -1 + dig 1 extract 2 16 swap pushint 16 // 16 * intc_2 // 2 + - frame_dig -1 swap - uncover 2 - replace3 - dup - frame_bury -1 - // tests/artifacts/Arrays/immutable.py:448 - // return imm - retsub + replace3 // on error: index access is out of bounds + // tests/artifacts/Arrays/immutable.py:444 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_imm_fixed_arr() -> bytes: +// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_imm_fixed_arr[routing]() -> void: test_imm_fixed_arr: - // tests/artifacts/Arrays/immutable.py:450-451 - // @arc4.abimethod() - // def test_imm_fixed_arr(self) -> NativeStruct3: - proto 0 1 - bytec_1 // "" + bytec_0 // "" // tests/artifacts/Arrays/immutable.py:452 // arr1 = zero_bytes(NativeStruct3) pushint 48 // 48 @@ -3700,71 +3260,70 @@ test_imm_fixed_arr: // for i in urange(3): intc_0 // 0 -test_imm_fixed_arr_for_header@1: +test_imm_fixed_arr_for_header@2: // tests/artifacts/Arrays/immutable.py:459 // for i in urange(3): - frame_dig 4 + dup pushint 3 // 3 < - bz test_imm_fixed_arr_after_for@4 + bz test_imm_fixed_arr_after_for@5 // tests/artifacts/Arrays/immutable.py:460 // arr1 = arr1.replace(i, struct12) - frame_dig 4 - dup + dupn 2 pushint 16 // 16 * - frame_dig 1 + dig 5 swap - frame_dig 2 - replace3 - frame_bury 1 + dig 5 + replace3 // on error: index access is out of bounds + bury 5 // tests/artifacts/Arrays/immutable.py:459 // for i in urange(3): intc_1 // 1 + - frame_bury 4 - b test_imm_fixed_arr_for_header@1 + bury 1 + b test_imm_fixed_arr_for_header@2 -test_imm_fixed_arr_after_for@4: +test_imm_fixed_arr_after_for@5: // tests/artifacts/Arrays/immutable.py:462 // assert arr1 == arr2, "expected arrays to be the same" - frame_dig 1 - frame_dig 3 + dig 3 + dig 2 == assert // expected arrays to be the same intc_0 // 0 - frame_bury 0 + bury 5 -test_imm_fixed_arr_for_header@5: +test_imm_fixed_arr_for_header@6: // tests/artifacts/Arrays/immutable.py:464 // for struct_it in arr1: - frame_dig 0 + dig 4 pushint 3 // 3 < - bz test_imm_fixed_arr_after_for@8 - frame_dig 0 + bz test_imm_fixed_arr_after_for@9 + dig 4 dup pushint 16 // 16 * - frame_dig 1 + dig 5 swap pushint 16 // 16 extract3 // on error: index access is out of bounds // tests/artifacts/Arrays/immutable.py:465 // assert struct_it == struct12, "expected items on iteration to be the same" - frame_dig 2 + dig 4 == assert // expected items on iteration to be the same intc_1 // 1 + - frame_bury 0 - b test_imm_fixed_arr_for_header@5 + bury 5 + b test_imm_fixed_arr_for_header@6 -test_imm_fixed_arr_after_for@8: +test_imm_fixed_arr_after_for@9: // tests/artifacts/Arrays/immutable.py:467 // self.imm_fixed_arr = arr1 bytec 10 // "imm_fixed_arr" - frame_dig 1 + dig 4 dup cover 2 app_global_put @@ -3778,7 +3337,7 @@ test_imm_fixed_arr_after_for@8: // tests/artifacts/Arrays/immutable.py:473 // mut_arr[0] = NativeStruct(UInt64(), UInt64()) pushbytes 0x00000000000000000000000000000000 - replace2 0 + replace2 0 // on error: index access is out of bounds // tests/artifacts/Arrays/immutable.py:474 // assert sum_imm_fixed(mut_arr.freeze()) == 10, "expected sum to be 10" callsub sum_imm_fixed @@ -3791,5 +3350,11 @@ test_imm_fixed_arr_after_for@8: bytec 10 // "imm_fixed_arr" app_global_get_ex assert // check self.imm_fixed_arr exists - frame_bury 0 - retsub + // tests/artifacts/Arrays/immutable.py:450 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return diff --git a/tests/artifacts/Arrays/data/ImmutableArrayContract.arc32.json b/tests/artifacts/Arrays/data/ImmutableArrayContract.arc32.json index 30e6e57..0086bc3 100644 --- a/tests/artifacts/Arrays/data/ImmutableArrayContract.arc32.json +++ b/tests/artifacts/Arrays/data/ImmutableArrayContract.arc32.json @@ -122,7 +122,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock 0x151f7c75 0x 0x0000 0x00 0x0002 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 0x000a 0x62696775696e74 0x000200000000000000010000000000000002 0x000200040007000161000162 "imm_fixed_arr"
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@29
    pushbytess 0x44d42f99 0xb7eaa60b 0x743d70ed 0x1c7e0494 0xa2d5860b 0xe05fc564 0x1e092b83 0x01310262 0xc8654a98 0x89d196f8 0x6cb7c991 0x9898bf02 0xf6b61ee8 0x60b86a7b 0x73ad283f 0x529dfae9 0x206d514f 0xe06465e2 0xec0300a2 0xecdf14af 0x511aca64 0x29852e4f 0x6d4aa358 0xb7cb96bd // method "test_uint64_array()void", method "test_biguint_array()void", method "test_bool_array(uint64)void", method "test_fixed_size_tuple_array()void", method "test_fixed_size_named_tuple_array()void", method "test_dynamic_sized_tuple_array()void", method "test_dynamic_sized_named_tuple_array()void", method "test_implicit_conversion_log(uint64[])void", method "test_implicit_conversion_emit(uint64[])void", method "test_nested_array(uint64,uint64[][])uint64[]", method "test_bit_packed_tuples()void", method "sum_uints_and_lengths_and_trues(uint64[],bool[],(uint64,bool,bool)[],(uint64,string)[])(uint64,uint64,uint64,uint64)", method "test_uint64_return(uint64)uint64[]", method "test_bool_return(uint64)bool[]", method "test_tuple_return(uint64)(uint64,bool,bool)[]", method "test_dynamic_tuple_return(uint64)(uint64,string)[]", method "test_convert_to_array_and_back((uint64,bool,bool)[],uint64)(uint64,bool,bool)[]", method "test_concat_with_arc4_tuple((uint64,uint64))uint64[]", method "test_concat_with_native_tuple((uint64,uint64))uint64[]", method "test_dynamic_concat_with_arc4_tuple((string,string))string[]", method "test_dynamic_concat_with_native_tuple((string,string))string[]", method "test_concat_immutable_dynamic((uint64,string)[],(uint64,string)[])(uint64,string)[]", method "test_immutable_arc4((uint64,uint64)[])(uint64,uint64)[]", method "test_imm_fixed_arr()(uint64,uint64)[3]"
    txna ApplicationArgs 0
    match main_test_uint64_array_route@3 main_test_biguint_array_route@4 main_test_bool_array_route@5 main_test_fixed_size_tuple_array_route@6 main_test_fixed_size_named_tuple_array_route@7 main_test_dynamic_sized_tuple_array_route@8 main_test_dynamic_sized_named_tuple_array_route@9 main_test_implicit_conversion_log_route@10 main_test_implicit_conversion_emit_route@11 main_test_nested_array_route@12 main_test_bit_packed_tuples_route@13 main_sum_uints_and_lengths_and_trues_route@14 main_test_uint64_return_route@15 main_test_bool_return_route@16 main_test_tuple_return_route@17 main_test_dynamic_tuple_return_route@18 main_test_convert_to_array_and_back_route@19 main_test_concat_with_arc4_tuple_route@20 main_test_concat_with_native_tuple_route@21 main_test_dynamic_concat_with_arc4_tuple_route@22 main_test_dynamic_concat_with_native_tuple_route@23 main_test_concat_immutable_dynamic_route@24 main_test_immutable_arc4_route@25 main_test_imm_fixed_arr_route@26

main_after_if_else@33:
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    intc_0 // 0
    return

main_test_imm_fixed_arr_route@26:
    // tests/artifacts/Arrays/immutable.py:450
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_imm_fixed_arr
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_immutable_arc4_route@25:
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    callsub test_immutable_arc4
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_concat_immutable_dynamic_route@24:
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    callsub test_concat_immutable_dynamic
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_dynamic_concat_with_native_tuple_route@23:
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    dup
    intc_0 // 0
    extract_uint16
    dig 1
    intc_2 // 2
    extract_uint16
    dig 2
    uncover 2
    dig 2
    substring3
    dig 2
    len
    uncover 3
    uncover 3
    uncover 2
    substring3
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    callsub test_dynamic_concat_with_native_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_dynamic_concat_with_arc4_tuple_route@22:
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    callsub test_dynamic_concat_with_arc4_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_concat_with_native_tuple_route@21:
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    dup
    extract 0 8
    swap
    extract 8 8
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    callsub test_concat_with_native_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_concat_with_arc4_tuple_route@20:
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    callsub test_concat_with_arc4_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_convert_to_array_and_back_route@19:
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    callsub test_convert_to_array_and_back
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_dynamic_tuple_return_route@18:
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    callsub test_dynamic_tuple_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_tuple_return_route@17:
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    callsub test_tuple_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_bool_return_route@16:
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    callsub test_bool_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_uint64_return_route@15:
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    callsub test_uint64_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_sum_uints_and_lengths_and_trues_route@14:
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    callsub sum_uints_and_lengths_and_trues
    uncover 3
    itob
    uncover 3
    itob
    concat
    uncover 2
    itob
    concat
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_bit_packed_tuples_route@13:
    // tests/artifacts/Arrays/immutable.py:276
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_bit_packed_tuples
    intc_1 // 1
    return

main_test_nested_array_route@12:
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    callsub test_nested_array
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_implicit_conversion_emit_route@11:
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    callsub test_implicit_conversion_emit
    intc_1 // 1
    return

main_test_implicit_conversion_log_route@10:
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    callsub test_implicit_conversion_log
    intc_1 // 1
    return

main_test_dynamic_sized_named_tuple_array_route@9:
    // tests/artifacts/Arrays/immutable.py:231
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_dynamic_sized_named_tuple_array
    intc_1 // 1
    return

main_test_dynamic_sized_tuple_array_route@8:
    // tests/artifacts/Arrays/immutable.py:212
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_dynamic_sized_tuple_array
    intc_1 // 1
    return

main_test_fixed_size_named_tuple_array_route@7:
    // tests/artifacts/Arrays/immutable.py:197
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_fixed_size_named_tuple_array
    intc_1 // 1
    return

main_test_fixed_size_tuple_array_route@6:
    // tests/artifacts/Arrays/immutable.py:179
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_fixed_size_tuple_array
    intc_1 // 1
    return

main_test_bool_array_route@5:
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    callsub test_bool_array
    intc_1 // 1
    return

main_test_biguint_array_route@4:
    // tests/artifacts/Arrays/immutable.py:130
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_biguint_array
    intc_1 // 1
    return

main_test_uint64_array_route@3:
    // tests/artifacts/Arrays/immutable.py:94
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_uint64_array
    intc_1 // 1
    return

main_bare_routing@29:
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@33
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.arc4.dynamic_array_pop_fixed_size(array: bytes, fixed_byte_size: uint64) -> bytes, bytes:
dynamic_array_pop_fixed_size:
    proto 2 2
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    itob
    extract 6 0
    frame_dig -2
    swap
    replace2 0
    dup
    len
    frame_dig -1
    -
    dup2
    frame_dig -1
    extract3
    uncover 2
    intc_0 // 0
    uncover 3
    substring3
    retsub


// _puya_lib.arc4.dynamic_array_pop_dynamic_element(array: bytes) -> bytes, bytes:
dynamic_array_pop_dynamic_element:
    proto 1 2
    frame_dig -1
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dup
    intc_2 // 2
    *
    dup
    frame_dig -1
    extract 2 0
    dup
    cover 2
    dup
    uncover 2
    extract_uint16
    dup
    uncover 2
    dup
    len
    swap
    cover 2
    substring3
    bytec_1 // 0x
    intc_0 // 0

dynamic_array_pop_dynamic_element_for_header@1:
    frame_dig 6
    frame_dig 1
    <
    bz dynamic_array_pop_dynamic_element_after_for@4
    frame_dig 2
    frame_dig 6
    dup
    cover 2
    extract_uint16
    intc_2 // 2
    -
    itob
    extract 6 2
    frame_dig 5
    swap
    concat
    frame_bury 5
    intc_2 // 2
    +
    frame_bury 6
    b dynamic_array_pop_dynamic_element_for_header@1

dynamic_array_pop_dynamic_element_after_for@4:
    frame_dig 0
    itob
    extract 6 2
    frame_dig 5
    concat
    frame_dig 1
    intc_2 // 2
    +
    frame_dig 2
    swap
    frame_dig 3
    substring3
    concat
    frame_dig 4
    frame_bury 0
    frame_bury 1
    retsub


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_1 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    dup
    uncover 2
    uncover 3
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    cover 3
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    cover 3
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 7

dynamic_array_concat_bits_after_if_else@2:
    frame_dig 7
    frame_bury 4
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    pushint 16 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_byte_length_head(array: bytes, new_items_bytes: bytes, new_items_count: uint64) -> bytes:
dynamic_array_concat_byte_length_head:
    proto 3 1
    frame_dig -3
    intc_0 // 0
    extract_uint16
    dup
    frame_dig -1
    +
    swap
    intc_2 // 2
    *
    intc_2 // 2
    +
    dig 1
    itob
    extract 6 2
    cover 2
    frame_dig -3
    intc_2 // 2
    dig 2
    substring3
    frame_dig -1
    intc_2 // 2
    *
    bzero
    concat
    frame_dig -3
    len
    frame_dig -3
    uncover 3
    uncover 2
    substring3
    concat
    frame_dig -2
    concat
    swap
    intc_2 // 2
    *
    dup
    intc_0 // 0
    swap

dynamic_array_concat_byte_length_head_for_header@2:
    frame_dig 3
    frame_dig 2
    <
    bz dynamic_array_concat_byte_length_head_after_for@4
    frame_dig 4
    dup
    itob
    extract 6 2
    frame_dig 1
    frame_dig 3
    dup
    cover 4
    uncover 2
    replace3
    dup
    frame_bury 1
    dig 1
    extract_uint16
    intc_2 // 2
    +
    +
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 3
    b dynamic_array_concat_byte_length_head_for_header@2

dynamic_array_concat_byte_length_head_after_for@4:
    frame_dig 0
    frame_dig 1
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    bytec_1 // ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.sum_imm_fixed(arr: bytes) -> uint64:
sum_imm_fixed:
    // tests/artifacts/Arrays/immutable.py:479-480
    // @subroutine
    // def sum_imm_fixed(arr: NativeStruct3) -> UInt64:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:481
    // total = UInt64(0)
    intc_0 // 0
    dup

sum_imm_fixed_for_header@1:
    // tests/artifacts/Arrays/immutable.py:482
    // for item in arr:
    frame_dig 1
    pushint 3 // 3
    <
    bz sum_imm_fixed_after_for@4
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    frame_dig 1
    dup
    pushint 16 // 16
    *
    frame_dig -1
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    dup
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    intc_0 // 0
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    extract_uint64
    frame_dig 0
    +
    // tests/artifacts/Arrays/immutable.py:484
    // total += item.bar
    swap
    intc_3 // 8
    extract_uint64
    +
    frame_bury 0
    intc_1 // 1
    +
    frame_bury 1
    b sum_imm_fixed_for_header@1

sum_imm_fixed_after_for@4:
    // tests/artifacts/Arrays/immutable.py:485
    // return total
    retsub


// tests.artifacts.Arrays.immutable.times(n: uint64) -> bytes:
times:
    // tests/artifacts/Arrays/immutable.py:488-489
    // @subroutine
    // def times(n: UInt64) -> String:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:490
    // result = String()
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    intc_0 // 0

times_for_header@1:
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    frame_dig -1
    <
    bz times_after_for@4
    // tests/artifacts/Arrays/immutable.py:492
    // result += String(" ")
    frame_dig 0
    pushbytes " "
    concat
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 1
    b times_for_header@1

times_after_for@4:
    // tests/artifacts/Arrays/immutable.py:493
    // return result
    retsub


// tests.artifacts.Arrays.immutable.add_x(arr: bytes, x: uint64) -> bytes:
add_x:
    // tests/artifacts/Arrays/immutable.py:496-497
    // @subroutine
    // def add_x(arr: ImmutableArray[UInt64], x: UInt64) -> ImmutableArray[UInt64]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_0 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/immutable.py:499
    // arr = arr.append(i)
    frame_dig 0
    dup
    itob
    frame_dig -2
    swap
    concat // on error: max array length exceeded
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury -2
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    // tests/artifacts/Arrays/immutable.py:500
    // return arr
    frame_dig -2
    swap
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_array() -> void:
test_uint64_array:
    // tests/artifacts/Arrays/immutable.py:94-95
    // @arc4.abimethod()
    // def test_uint64_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:99
    // arr = arr.append(UInt64(42))
    pushbytes 0x0001000000000000002a
    // tests/artifacts/Arrays/immutable.py:103
    // arr = add_x(arr, UInt64(5))
    pushint 5 // 5
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:104
    // assert arr.length == 6
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:105
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:107
    // arr = arr.append(UInt64(43))
    pushint 43 // 43
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:108
    // assert arr.length == 7
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:109
    // assert arr[-1] == 43
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 43 // 43
    ==
    assert
    intc_2 // 2
    // tests/artifacts/Arrays/immutable.py:110
    // assert arr[0] == 42
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    intc_0 // 0

test_uint64_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    frame_dig 1
    // tests/artifacts/Arrays/immutable.py:112
    // arr = pop_x(arr, UInt64(3))
    pushint 3 // 3
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    <
    bz test_uint64_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:506
    // arr = arr.pop()
    frame_dig 0
    intc_3 // 8
    callsub dynamic_array_pop_fixed_size
    frame_bury 0
    pop
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 1
    b test_uint64_array_for_header@2

test_uint64_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:113
    // assert arr.length == 4
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:114
    // assert arr[-1] == 2
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    intc_2 // 2
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:116
    // arr = add_x(arr, UInt64(10))
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:117
    // assert arr.length == 14
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:118
    // assert arr[-1] == 9
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:120
    // arr = arr.append(UInt64(44))
    pushint 44 // 44
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:121
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:122
    // assert arr[-1] == 44
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:124
    // arr = arr.replace(2, UInt64(23))
    pushint 23 // 23
    itob
    replace2 18
    // tests/artifacts/Arrays/immutable.py:125
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:126
    // assert arr[2] == 23
    dup
    pushint 18 // 18
    extract_uint64
    pushint 23 // 23
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:128
    // self.a = arr
    pushbytes "a"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_biguint_array() -> void:
test_biguint_array:
    // tests/artifacts/Arrays/immutable.py:130-131
    // @arc4.abimethod()
    // def test_biguint_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    txn NumAppArgs
    intc_1 // 1
    -
    itob
    pushint 64 // 64
    bzero
    dup
    cover 2
    b|
    // tests/artifacts/Arrays/immutable.py:132
    // arr = ImmutableArray[BigUInt]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0001
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:136
    // assert arr.length == 1
    intc_0 // 0
    extract_uint16
    dup
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:137
    // assert arr[-1] == 0
    intc_1 // 1
    -
    swap
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec_1 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_0 // 0

test_biguint_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    frame_dig 2
    // tests/artifacts/Arrays/immutable.py:139
    // arr = add_xb(arr, UInt64(5))
    pushint 5 // 5
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    <
    bz test_biguint_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:513
    // arr = arr.append(BigUInt(i))
    frame_dig 2
    dup
    itob
    frame_dig 0
    b|
    frame_dig 1
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 2
    b test_biguint_array_for_header@2

test_biguint_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:140
    // assert arr.length == 6
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:141
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0x04
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:143
    // arr = arr.append(BigUInt(2**512 - 1) - Txn.num_app_args)
    txn NumAppArgs
    itob
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    swap
    b-
    dup
    len
    pushint 64 // 64
    <=
    assert // overflow
    frame_dig 0
    b|
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:144
    // assert arr.length == 7
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:145
    // assert arr[-1] == 2**512 - 2
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:146
    // assert arr[0] == 0
    dig 1
    extract 2 64
    bytec_1 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:148
    // arr = arr.append(BigUInt(2**512 - 1))
    swap
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:149
    // assert arr.length == 8
    dup
    intc_0 // 0
    extract_uint16
    dup
    intc_3 // 8
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:150
    // assert arr[-1] == 2**512 - 1
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:151
    // assert arr[0] == 0
    dup
    extract 2 64
    bytec_1 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:153
    // Box(ImmutableArray[BigUInt], key=b"biguint").value = arr
    bytec 7 // 0x62696775696e74
    box_del
    pop
    bytec 7 // 0x62696775696e74
    swap
    box_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_array(length: uint64) -> void:
test_bool_array:
    // tests/artifacts/Arrays/immutable.py:155-156
    // @arc4.abimethod()
    // def test_bool_array(self, length: UInt64) -> None:
    proto 1 0
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:157
    // arr = ImmutableArray[bool]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_0 // 0

test_bool_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    frame_dig 2
    frame_dig -1
    <
    bz test_bool_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:161
    // arr = arr.append(i == Txn.num_app_args)
    txn NumAppArgs
    frame_dig 2
    dup
    uncover 2
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    frame_dig 1
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_1 // 1
    +
    frame_bury 2
    b test_bool_array_for_header@1

test_bool_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:163
    // assert arr.length == length
    frame_dig 1
    intc_0 // 0
    extract_uint16
    dup
    frame_bury 0
    frame_dig -1
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:165
    // if length > 0:
    frame_dig -1
    bz test_bool_array_after_if_else@6
    // tests/artifacts/Arrays/immutable.py:166
    // assert not arr[0], "expected element 0 to be False"
    frame_dig 0
    assert // index access is out of bounds
    frame_dig 1
    pushint 16 // 16
    getbit
    !
    assert // expected element 0 to be False

test_bool_array_after_if_else@6:
    // tests/artifacts/Arrays/immutable.py:167
    // if length > 1:
    frame_dig -1
    intc_1 // 1
    >
    bz test_bool_array_after_if_else@8
    // tests/artifacts/Arrays/immutable.py:168
    // assert not arr[1], "expected element 1 to be False"
    intc_1 // 1
    frame_dig 0
    <
    assert // index access is out of bounds
    frame_dig 1
    pushint 17 // 17
    getbit
    !
    assert // expected element 1 to be False

test_bool_array_after_if_else@8:
    // tests/artifacts/Arrays/immutable.py:169
    // if length > 2:
    frame_dig -1
    intc_2 // 2
    >
    bz test_bool_array_after_if_else@10
    // tests/artifacts/Arrays/immutable.py:170
    // assert arr[2], "expected element 2 to be True"
    intc_2 // 2
    frame_dig 0
    <
    assert // index access is out of bounds
    frame_dig 1
    pushint 18 // 18
    getbit
    assert // expected element 2 to be True

test_bool_array_after_if_else@10:
    // tests/artifacts/Arrays/immutable.py:171
    // if length > 3:
    frame_dig -1
    pushint 3 // 3
    >
    bz test_bool_array_after_if_else@12
    // tests/artifacts/Arrays/immutable.py:172
    // assert not arr[length - 1], "expected last element to be False"
    frame_dig -1
    intc_1 // 1
    -
    dup
    frame_dig 0
    <
    assert // index access is out of bounds
    pushint 16 // 16
    +
    frame_dig 1
    swap
    getbit
    !
    assert // expected last element to be False

test_bool_array_after_if_else@12:
    // tests/artifacts/Arrays/immutable.py:174
    // self.g = arr
    pushbytes "g"
    frame_dig 1
    app_global_put
    // tests/artifacts/Arrays/immutable.py:175
    // if length:
    frame_dig -1
    bz test_bool_array_after_if_else@14
    frame_dig 0
    intc_1 // 1
    -
    dup
    itob
    extract 6 0
    frame_dig 1
    swap
    replace2 0
    dig 1
    pushint 16 // 16
    +
    intc_0 // 0
    setbit
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    intc_2 // 2
    +
    intc_0 // 0
    swap
    substring3
    // tests/artifacts/Arrays/immutable.py:177
    // assert arr.length == length - 1
    intc_0 // 0
    extract_uint16
    frame_dig -1
    intc_1 // 1
    -
    ==
    assert

test_bool_array_after_if_else@14:
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_tuple_array() -> void:
test_fixed_size_tuple_array:
    // tests/artifacts/Arrays/immutable.py:179-180
    // @arc4.abimethod()
    // def test_fixed_size_tuple_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:181
    // arr = ImmutableArray[tuple[UInt64, UInt64]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    frame_dig 1
    pushint 5 // 5
    <
    bz test_fixed_size_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:185
    // arr = arr.append((i + 1, i + 2))
    frame_dig 1
    dup
    intc_1 // 1
    +
    swap
    intc_2 // 2
    +
    dig 1
    itob
    swap
    itob
    concat
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    frame_bury 1
    b test_fixed_size_tuple_array_for_header@1

test_fixed_size_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:187
    // assert arr.length == 5
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:188
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:189
    // assert arr[-1] == (UInt64(5), UInt64(6))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 5 // 5
    ==
    swap
    pushint 6 // 6
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:191
    // arr = arr.pop()
    pushint 16 // 16
    callsub dynamic_array_pop_fixed_size
    bury 1
    // tests/artifacts/Arrays/immutable.py:192
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:193
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:194
    // assert arr[-1] == (UInt64(4), UInt64(5))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 4 // 4
    ==
    swap
    pushint 5 // 5
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:195
    // self.c = arr
    pushbytes "c"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_named_tuple_array() -> void:
test_fixed_size_named_tuple_array:
    // tests/artifacts/Arrays/immutable.py:197-198
    // @arc4.abimethod()
    // def test_fixed_size_named_tuple_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:199
    // arr = ImmutableArray[MyTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_named_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    frame_dig 1
    pushint 5 // 5
    <
    bz test_fixed_size_named_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:203
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i * 3 % 2 == 0))
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    *
    intc_2 // 2
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_1 // 1
    +
    frame_bury 1
    b test_fixed_size_named_tuple_array_for_header@1

test_fixed_size_named_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:205
    // assert arr.length == 5
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:206
    // foo, bar, baz = arr[0]
    dup
    extract 2 9
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    // tests/artifacts/Arrays/immutable.py:207
    // assert foo == 0
    uncover 2
    !
    assert
    // tests/artifacts/Arrays/immutable.py:208
    // assert bar
    swap
    assert
    // tests/artifacts/Arrays/immutable.py:209
    // assert baz
    assert
    // tests/artifacts/Arrays/immutable.py:210
    // self.d = arr
    pushbytes "d"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_tuple_array() -> void:
test_dynamic_sized_tuple_array:
    // tests/artifacts/Arrays/immutable.py:212-213
    // @arc4.abimethod()
    // def test_dynamic_sized_tuple_array(self) -> None:
    proto 0 0
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:214
    // arr = ImmutableArray[tuple[UInt64, Bytes]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:218
    // arr = arr.append((i + 1, op.bzero(i)))
    frame_dig 2
    dup
    intc_1 // 1
    +
    swap
    bzero
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury 1
    frame_bury 2
    b test_dynamic_sized_tuple_array_for_header@1

test_dynamic_sized_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:220
    // assert arr.length == 5
    frame_dig 1
    intc_0 // 0
    extract_uint16
    dup
    frame_bury 0
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    intc_0 // 0
    frame_bury 2

test_dynamic_sized_tuple_array_for_header@5:
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@8
    // tests/artifacts/Arrays/immutable.py:222
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    frame_dig 1
    extract 2 0
    frame_dig 2
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    frame_dig 0
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:223
    // assert arr[i][1].length == i, "expected 2nd element to be correct"
    len
    uncover 2
    ==
    assert // expected 2nd element to be correct
    frame_bury 2
    b test_dynamic_sized_tuple_array_for_header@5

test_dynamic_sized_tuple_array_after_for@8:
    // tests/artifacts/Arrays/immutable.py:225
    // arr = arr.pop()
    frame_dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:226
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:227
    // assert arr[0] == (UInt64(1), op.bzero(0)), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    intc_0 // 0
    bzero
    uncover 2
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:228
    // assert arr[-1] == (UInt64(4), op.bzero(3)), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    pushint 3 // 3
    bzero
    uncover 2
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:229
    // self.e = arr
    pushbytes "e"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_named_tuple_array() -> void:
test_dynamic_sized_named_tuple_array:
    // tests/artifacts/Arrays/immutable.py:231-232
    // @arc4.abimethod()
    // def test_dynamic_sized_named_tuple_array(self) -> None:
    proto 0 0
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:233
    // arr = ImmutableArray[MyDynamicSizedTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_named_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:237
    // arr = arr.append(MyDynamicSizedTuple(foo=i + 1, bar=times(i)))
    frame_dig 2
    dup
    intc_1 // 1
    +
    swap
    callsub times
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury 1
    frame_bury 2
    b test_dynamic_sized_named_tuple_array_for_header@1

test_dynamic_sized_named_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:239
    // assert arr.length == 5
    frame_dig 1
    intc_0 // 0
    extract_uint16
    dup
    frame_bury 0
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    intc_0 // 0
    frame_bury 2

test_dynamic_sized_named_tuple_array_for_header@5:
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@8
    // tests/artifacts/Arrays/immutable.py:241
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    frame_dig 1
    extract 2 0
    frame_dig 2
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    frame_dig 0
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:242
    // assert arr[i][1] == times(i), "expected 2nd element to be correct"
    uncover 2
    callsub times
    ==
    assert // expected 2nd element to be correct
    frame_bury 2
    b test_dynamic_sized_named_tuple_array_for_header@5

test_dynamic_sized_named_tuple_array_after_for@8:
    // tests/artifacts/Arrays/immutable.py:244
    // arr = arr.pop()
    frame_dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:245
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:246
    // assert arr[0] == MyDynamicSizedTuple(UInt64(1), String()), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    swap
    bytec_1 // ""
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:247
    // assert arr[-1] == MyDynamicSizedTuple(UInt64(4), String("   ")), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    swap
    pushbytes "   "
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:248
    // self.f = arr
    pushbytes "f"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_log(arr: bytes) -> void:
test_implicit_conversion_log:
    // tests/artifacts/Arrays/immutable.py:250-251
    // @arc4.abimethod()
    // def test_implicit_conversion_log(self, arr: ImmutableArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/immutable.py:252
    // log(arr)
    frame_dig -1
    log
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_emit(arr: bytes) -> void:
test_implicit_conversion_emit:
    // tests/artifacts/Arrays/immutable.py:254-255
    // @arc4.abimethod()
    // def test_implicit_conversion_emit(self, arr: ImmutableArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/immutable.py:256
    // arc4.emit("emit_test", arr)
    pushbytes 0xfa40c0530002
    frame_dig -1
    concat
    log
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_nested_array(arr_to_add: uint64, arr: bytes) -> bytes:
test_nested_array:
    // tests/artifacts/Arrays/immutable.py:258-261
    // @arc4.abimethod()
    // def test_nested_array(
    //     self, arr_to_add: UInt64, arr: ImmutableArray[ImmutableArray[UInt64]]
    // ) -> ImmutableArray[UInt64]:
    proto 2 1
    intc_0 // 0
    dupn 2
    bytec_1 // ""
    dupn 5
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    intc_0 // 0

test_nested_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    frame_dig 9
    frame_dig -2
    <
    bz test_nested_array_after_for@8
    // tests/artifacts/Arrays/immutable.py:264
    // extra_arr = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_0 // 0
    frame_bury 7

test_nested_array_for_header@3:
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    frame_dig 7
    frame_dig 9
    <
    bz test_nested_array_after_for@6
    // tests/artifacts/Arrays/immutable.py:266
    // extra_arr = extra_arr.append(j)
    frame_dig 7
    dup
    itob
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_1 // 1
    +
    frame_bury 7
    b test_nested_array_for_header@3

test_nested_array_after_for@6:
    // tests/artifacts/Arrays/immutable.py:267
    // arr = arr.append(extra_arr)
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_dig -1
    extract 2 0
    bytec 4 // 0x0002
    frame_dig 0
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury -1
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    frame_dig 9
    intc_1 // 1
    +
    frame_bury 9
    b test_nested_array_for_header@1

test_nested_array_after_for@8:
    // tests/artifacts/Arrays/immutable.py:269-270
    // # sum inner arrays and return an array containing sums
    // totals = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    frame_bury 2
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_bury 3
    intc_0 // 0
    frame_bury 5

test_nested_array_for_header@9:
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    frame_dig 5
    frame_dig 3
    <
    bz test_nested_array_after_for@12
    frame_dig -1
    extract 2 0
    frame_dig 5
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dup2
    extract_uint16
    intc_3 // 8
    *
    intc_2 // 2
    +
    extract3
    dup
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:519
    // total = UInt64()
    intc_0 // 0
    frame_bury 8
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    intc_0 // 0
    extract_uint16
    frame_bury 4
    intc_0 // 0
    frame_bury 6

test_nested_array_for_header@14:
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    frame_dig 6
    frame_dig 4
    <
    bz test_nested_array_after_for@16
    frame_dig 1
    extract 2 0
    frame_dig 6
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:521
    // total += i
    frame_dig 8
    +
    frame_bury 8
    intc_1 // 1
    +
    frame_bury 6
    b test_nested_array_for_header@14

test_nested_array_after_for@16:
    // tests/artifacts/Arrays/immutable.py:272
    // totals = totals.append(sum_arr(inner_arr))
    frame_dig 8
    itob
    frame_dig 2
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 2
    frame_dig 5
    intc_1 // 1
    +
    frame_bury 5
    b test_nested_array_for_header@9

test_nested_array_after_for@12:
    // tests/artifacts/Arrays/immutable.py:274
    // return totals
    frame_dig 2
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bit_packed_tuples() -> void:
test_bit_packed_tuples:
    // tests/artifacts/Arrays/immutable.py:276-277
    // @arc4.abimethod()
    // def test_bit_packed_tuples(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:278
    // arr2 = ImmutableArray[TwoBoolTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:279-281
    // arr7 = ImmutableArray[SevenBoolTuple]()
    // arr8 = ImmutableArray[EightBoolTuple]()
    // arr9 = ImmutableArray[NineBoolTuple]()
    dupn 3
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    intc_0 // 0

test_bit_packed_tuples_for_header@1:
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    frame_dig 4
    pushint 5 // 5
    <
    bz test_bit_packed_tuples_after_for@4
    // tests/artifacts/Arrays/immutable.py:288
    // arr2 = arr2.append(TwoBoolTuple(a=i == 0, b=i == 1))
    frame_dig 4
    dup
    !
    dig 1
    intc_1 // 1
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    intc_1 // 1
    uncover 2
    setbit
    frame_dig 0
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:295
    // c=i == 2,
    dig 1
    intc_2 // 2
    ==
    // tests/artifacts/Arrays/immutable.py:296
    // d=i == 3,
    dig 2
    pushint 3 // 3
    ==
    // tests/artifacts/Arrays/immutable.py:297
    // e=i == 4,
    dig 3
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/immutable.py:298
    // f=i == 5,
    dig 4
    pushint 5 // 5
    ==
    // tests/artifacts/Arrays/immutable.py:299
    // g=i == 6,
    dig 5
    pushint 6 // 6
    ==
    // tests/artifacts/Arrays/immutable.py:292
    // bar=i + 1,
    dig 6
    intc_1 // 1
    +
    // tests/artifacts/Arrays/immutable.py:289-301
    // arr7 = arr7.append(
    //     SevenBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //     )
    // )
    dig 7
    itob
    uncover 7
    intc_2 // 2
    uncover 8
    setbit
    pushint 3 // 3
    uncover 7
    setbit
    pushint 4 // 4
    uncover 6
    setbit
    pushint 5 // 5
    uncover 5
    setbit
    pushint 6 // 6
    uncover 4
    setbit
    dup2
    concat
    dig 3
    itob
    swap
    dig 1
    concat
    frame_dig 1
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:313
    // h=i == 7,
    dig 4
    pushint 7 // 7
    ==
    // tests/artifacts/Arrays/immutable.py:302-315
    // arr8 = arr8.append(
    //     EightBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //     )
    // )
    uncover 2
    pushint 7 // 7
    uncover 2
    setbit
    uncover 2
    swap
    concat
    dup
    dig 2
    concat
    frame_dig 2
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 2
    // tests/artifacts/Arrays/immutable.py:328
    // i=i == 8,
    uncover 3
    intc_3 // 8
    ==
    // tests/artifacts/Arrays/immutable.py:316-330
    // arr9 = arr9.append(
    //     NineBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //         i=i == 8,
    //     )
    // )
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat
    swap
    concat
    frame_dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 3
    frame_bury 4
    b test_bit_packed_tuples_for_header@1

test_bit_packed_tuples_after_for@4:
    // tests/artifacts/Arrays/immutable.py:332
    // assert arr2.length == 5
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:333
    // assert arr7.length == 5
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:334
    // assert arr8.length == 5
    frame_dig 2
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:335
    // assert arr9.length == 5
    frame_dig 3
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:336
    // self.bool2 = arr2
    pushbytes "bool2"
    uncover 4
    app_global_put
    // tests/artifacts/Arrays/immutable.py:337
    // self.bool7 = arr7
    pushbytes "bool7"
    uncover 3
    app_global_put
    // tests/artifacts/Arrays/immutable.py:338
    // self.bool8 = arr8
    pushbytes "bool8"
    uncover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:339
    // self.bool9 = arr9
    pushbytes "bool9"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.sum_uints_and_lengths_and_trues(arr1: bytes, arr2: bytes, arr3: bytes, arr4: bytes) -> uint64, uint64, uint64, uint64:
sum_uints_and_lengths_and_trues:
    // tests/artifacts/Arrays/immutable.py:341-348
    // @arc4.abimethod()
    // def sum_uints_and_lengths_and_trues(
    //     self,
    //     arr1: ImmutableArray[UInt64],
    //     arr2: ImmutableArray[bool],
    //     arr3: ImmutableArray[MyTuple],
    //     arr4: ImmutableArray[MyDynamicSizedTuple],
    // ) -> tuple[UInt64, UInt64, UInt64, UInt64]:
    proto 4 4
    bytec_1 // ""
    dupn 8
    // tests/artifacts/Arrays/immutable.py:349
    // sum1 = sum2 = sum3 = sum4 = UInt64()
    intc_0 // 0
    dupn 3
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    frame_dig -4
    intc_0 // 0
    extract_uint16
    intc_0 // 0

sum_uints_and_lengths_and_trues_for_header@1:
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    frame_dig 14
    frame_dig 13
    <
    bz sum_uints_and_lengths_and_trues_after_for@4
    frame_dig -4
    extract 2 0
    frame_dig 14
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:351
    // sum1 += i
    frame_dig 12
    +
    frame_bury 12
    intc_1 // 1
    +
    frame_bury 14
    b sum_uints_and_lengths_and_trues_for_header@1

sum_uints_and_lengths_and_trues_after_for@4:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    frame_dig -3
    intc_0 // 0
    extract_uint16
    frame_bury 0
    intc_0 // 0
    frame_bury 4

sum_uints_and_lengths_and_trues_for_header@5:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    frame_dig 4
    frame_dig 0
    <
    bz sum_uints_and_lengths_and_trues_after_for@10
    frame_dig 4
    pushint 16 // 16
    +
    frame_dig -3
    swap
    getbit
    frame_dig 11
    frame_bury 6
    // tests/artifacts/Arrays/immutable.py:353
    // if b:
    bz sum_uints_and_lengths_and_trues_after_if_else@8
    // tests/artifacts/Arrays/immutable.py:354
    // sum2 += 1
    frame_dig 11
    intc_1 // 1
    +
    frame_bury 6

sum_uints_and_lengths_and_trues_after_if_else@8:
    frame_dig 6
    frame_bury 11
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    b sum_uints_and_lengths_and_trues_for_header@5

sum_uints_and_lengths_and_trues_after_for@10:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    frame_dig -2
    intc_0 // 0
    extract_uint16
    frame_bury 1
    intc_0 // 0
    frame_bury 5

sum_uints_and_lengths_and_trues_for_header@11:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    frame_dig 5
    frame_dig 1
    <
    bz sum_uints_and_lengths_and_trues_after_for@18
    frame_dig -2
    extract 2 0
    frame_dig 5
    pushint 9 // 9
    *
    pushint 9 // 9
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    frame_bury 8
    // tests/artifacts/Arrays/immutable.py:356
    // sum3 += tup.foo
    frame_dig 10
    uncover 2
    +
    dup
    frame_bury 10
    frame_bury 7
    // tests/artifacts/Arrays/immutable.py:357
    // if tup.bar:
    bz sum_uints_and_lengths_and_trues_after_if_else@14
    // tests/artifacts/Arrays/immutable.py:358
    // sum3 += 1
    frame_dig 10
    intc_1 // 1
    +
    frame_bury 7

sum_uints_and_lengths_and_trues_after_if_else@14:
    frame_dig 7
    dup
    frame_bury 10
    frame_bury 7
    // tests/artifacts/Arrays/immutable.py:359
    // if tup.baz:
    frame_dig 8
    bz sum_uints_and_lengths_and_trues_after_if_else@16
    // tests/artifacts/Arrays/immutable.py:360
    // sum3 += 1
    frame_dig 10
    intc_1 // 1
    +
    frame_bury 7

sum_uints_and_lengths_and_trues_after_if_else@16:
    frame_dig 7
    frame_bury 10
    frame_dig 5
    intc_1 // 1
    +
    frame_bury 5
    b sum_uints_and_lengths_and_trues_for_header@11

sum_uints_and_lengths_and_trues_after_for@18:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_bury 2
    intc_0 // 0
    frame_bury 3

sum_uints_and_lengths_and_trues_for_header@19:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    frame_dig 3
    frame_dig 2
    <
    bz sum_uints_and_lengths_and_trues_after_for@22
    frame_dig -1
    extract 2 0
    frame_dig 3
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    frame_dig 2
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:362
    // sum4 += dyn_tup.foo
    frame_dig 9
    uncover 2
    +
    // tests/artifacts/Arrays/immutable.py:363
    // sum4 += dyn_tup.bar.bytes.length
    swap
    len
    swap
    dig 1
    +
    frame_bury 9
    // tests/artifacts/Arrays/immutable.py:364
    // assert dyn_tup.bar.bytes.length == idx, "expected string length to match index"
    uncover 2
    ==
    assert // expected string length to match index
    frame_bury 3
    b sum_uints_and_lengths_and_trues_for_header@19

sum_uints_and_lengths_and_trues_after_for@22:
    // tests/artifacts/Arrays/immutable.py:366
    // return sum1, sum2, sum3, sum4
    frame_dig 12
    frame_dig 11
    frame_dig 10
    frame_dig 9
    frame_bury 3
    frame_bury 2
    frame_bury 1
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_return(append: uint64) -> bytes:
test_uint64_return:
    // tests/artifacts/Arrays/immutable.py:368-369
    // @arc4.abimethod()
    // def test_uint64_return(self, append: UInt64) -> ImmutableArray[UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:370
    // arr = ImmutableArray(UInt64(1), UInt64(2), UInt64(3))
    pushbytes 0x0003000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_0 // 0

test_uint64_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_uint64_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:372
    // arr = arr.append(i)
    frame_dig 1
    dup
    itob
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_uint64_return_for_header@1

test_uint64_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:373
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_return(append: uint64) -> bytes:
test_bool_return:
    // tests/artifacts/Arrays/immutable.py:375-376
    // @arc4.abimethod()
    // def test_bool_return(self, append: UInt64) -> ImmutableArray[bool]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:377
    // arr = ImmutableArray(True, False, True, False, True)
    pushbytes 0x0005a8
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_0 // 0

test_bool_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_bool_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:379
    // arr = arr.append(i % 2 == 0)
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    frame_dig 0
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_bool_return_for_header@1

test_bool_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:380
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_tuple_return(append: uint64) -> bytes:
test_tuple_return:
    // tests/artifacts/Arrays/immutable.py:382-383
    // @arc4.abimethod()
    // def test_tuple_return(self, append: UInt64) -> ImmutableArray[MyTuple]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:384
    // arr = ImmutableArray(MyTuple(UInt64(), True, False))
    pushbytes 0x0001000000000000000080
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_0 // 0

test_tuple_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_tuple_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:386
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_tuple_return_for_header@1

test_tuple_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:387
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_tuple_return(append: uint64) -> bytes:
test_dynamic_tuple_return:
    // tests/artifacts/Arrays/immutable.py:389-390
    // @arc4.abimethod()
    // def test_dynamic_tuple_return(self, append: UInt64) -> ImmutableArray[MyDynamicSizedTuple]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:391
    // arr = ImmutableArray(MyDynamicSizedTuple(UInt64(), String("Hello")))
    pushbytes 0x000100020000000000000000000a000548656c6c6f
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_0 // 0

test_dynamic_tuple_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_dynamic_tuple_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:393
    // arr = arr.append(MyDynamicSizedTuple(i, times(i)))
    frame_dig 1
    dup
    callsub times
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_dynamic_tuple_return_for_header@1

test_dynamic_tuple_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:394
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_convert_to_array_and_back(arr: bytes, append: uint64) -> bytes:
test_convert_to_array_and_back:
    // tests/artifacts/Arrays/immutable.py:396-399
    // @arc4.abimethod()
    // def test_convert_to_array_and_back(
    //     self, arr: ImmutableArray[MyTuple], append: UInt64
    // ) -> ImmutableArray[MyTuple]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:401
    // mutable.extend(arr)
    frame_dig -2
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_0 // 0

test_convert_to_array_and_back_for_header@1:
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_convert_to_array_and_back_after_for@4
    // tests/artifacts/Arrays/immutable.py:403
    // mutable.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    frame_dig 0
    cover 3
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    uncover 2
    swap
    concat // on error: max array length exceeded
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_convert_to_array_and_back_for_header@1

test_convert_to_array_and_back_after_for@4:
    frame_dig 0
    // tests/artifacts/Arrays/immutable.py:404
    // return mutable.freeze()
    dup
    len
    pushint 9 // 9
    /
    itob
    extract 6 2
    swap
    concat
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_arc4_tuple(arg: bytes) -> bytes:
test_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:406-409
    // @arc4.abimethod()
    // def test_concat_with_arc4_tuple(
    //     self, arg: arc4.Tuple[arc4.UInt64, arc4.UInt64]
    // ) -> ImmutableArray[arc4.UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:410
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:411
    // result = prefix + arg
    frame_dig -1
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_3 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:412
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_native_tuple(arg.0: bytes, arg.1: bytes) -> bytes:
test_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:414-417
    // @arc4.abimethod()
    // def test_concat_with_native_tuple(
    //     self, arg: tuple[arc4.UInt64, arc4.UInt64]
    // ) -> ImmutableArray[arc4.UInt64]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    frame_dig -2
    frame_dig -1
    concat
    // tests/artifacts/Arrays/immutable.py:418
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0004
    replace2 0
    // tests/artifacts/Arrays/immutable.py:420
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_arc4_tuple(arg: bytes) -> bytes:
test_dynamic_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:422-425
    // @arc4.abimethod()
    // def test_dynamic_concat_with_arc4_tuple(
    //     self, arg: arc4.Tuple[arc4.String, arc4.String]
    // ) -> ImmutableArray[arc4.String]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    frame_dig -1
    len
    frame_dig -1
    pushint 4 // 4
    uncover 2
    substring3
    // tests/artifacts/Arrays/immutable.py:426
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:428
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_native_tuple(arg.0: bytes, arg.1: bytes) -> bytes:
test_dynamic_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:430-433
    // @arc4.abimethod()
    // def test_dynamic_concat_with_native_tuple(
    //     self, arg: tuple[arc4.String, arc4.String]
    // ) -> ImmutableArray[arc4.String]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    frame_dig -2
    frame_dig -1
    concat
    // tests/artifacts/Arrays/immutable.py:434
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:436
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_immutable_dynamic(imm1: bytes, imm2: bytes) -> bytes:
test_concat_immutable_dynamic:
    // tests/artifacts/Arrays/immutable.py:438-441
    // @arc4.abimethod()
    // def test_concat_immutable_dynamic(
    //     self, imm1: ImmutableArray[MyDynamicSizedTuple], imm2: ImmutableArray[MyDynamicSizedTuple]
    // ) -> ImmutableArray[MyDynamicSizedTuple]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:442
    // return imm1 + imm2
    frame_dig -2
    intc_0 // 0
    extract_uint16
    frame_dig -2
    extract 2 0
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_dig -1
    extract 2 0
    callsub dynamic_array_concat_dynamic_element
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_immutable_arc4(imm: bytes) -> bytes:
test_immutable_arc4:
    // tests/artifacts/Arrays/immutable.py:444-445
    // @arc4.abimethod()
    // def test_immutable_arc4(self, imm: ImmutableArray[MyStruct]) -> ImmutableArray[MyStruct]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:446
    // assert imm, "expected non empty array"
    frame_dig -1
    intc_0 // 0
    extract_uint16
    dup
    assert // expected non empty array
    // tests/artifacts/Arrays/immutable.py:447
    // imm = imm.replace(imm.length - 1, imm[0])
    intc_1 // 1
    -
    frame_dig -1
    extract 2 16
    swap
    pushint 16 // 16
    *
    intc_2 // 2
    +
    frame_dig -1
    swap
    uncover 2
    replace3
    dup
    frame_bury -1
    // tests/artifacts/Arrays/immutable.py:448
    // return imm
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_imm_fixed_arr() -> bytes:
test_imm_fixed_arr:
    // tests/artifacts/Arrays/immutable.py:450-451
    // @arc4.abimethod()
    // def test_imm_fixed_arr(self) -> NativeStruct3:
    proto 0 1
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:452
    // arr1 = zero_bytes(NativeStruct3)
    pushint 48 // 48
    bzero
    dup
    // tests/artifacts/Arrays/immutable.py:453
    // struct12 = NativeStruct(Txn.num_app_args + 1, Txn.num_app_args + 2)
    txn NumAppArgs
    intc_1 // 1
    +
    txn NumAppArgs
    intc_2 // 2
    +
    swap
    itob
    swap
    itob
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:454
    // arr2 = NativeStruct3((struct12, struct12, struct12))
    dup
    dig 1
    concat
    swap
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:456
    // assert arr1 != arr2, "expected arrays to be different"
    !=
    assert // expected arrays to be different
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_0 // 0

test_imm_fixed_arr_for_header@1:
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    frame_dig 4
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@4
    // tests/artifacts/Arrays/immutable.py:460
    // arr1 = arr1.replace(i, struct12)
    frame_dig 4
    dup
    pushint 16 // 16
    *
    frame_dig 1
    swap
    frame_dig 2
    replace3
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_1 // 1
    +
    frame_bury 4
    b test_imm_fixed_arr_for_header@1

test_imm_fixed_arr_after_for@4:
    // tests/artifacts/Arrays/immutable.py:462
    // assert arr1 == arr2, "expected arrays to be the same"
    frame_dig 1
    frame_dig 3
    ==
    assert // expected arrays to be the same
    intc_0 // 0
    frame_bury 0

test_imm_fixed_arr_for_header@5:
    // tests/artifacts/Arrays/immutable.py:464
    // for struct_it in arr1:
    frame_dig 0
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@8
    frame_dig 0
    dup
    pushint 16 // 16
    *
    frame_dig 1
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:465
    // assert struct_it == struct12, "expected items on iteration to be the same"
    frame_dig 2
    ==
    assert // expected items on iteration to be the same
    intc_1 // 1
    +
    frame_bury 0
    b test_imm_fixed_arr_for_header@5

test_imm_fixed_arr_after_for@8:
    // tests/artifacts/Arrays/immutable.py:467
    // self.imm_fixed_arr = arr1
    bytec 10 // "imm_fixed_arr"
    frame_dig 1
    dup
    cover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:471
    // assert sum_imm_fixed(mut_arr.freeze()) == 15, "expected sum to be 15"
    dup
    callsub sum_imm_fixed
    pushint 15 // 15
    ==
    assert // expected sum to be 15
    // tests/artifacts/Arrays/immutable.py:473
    // mut_arr[0] = NativeStruct(UInt64(), UInt64())
    pushbytes 0x00000000000000000000000000000000
    replace2 0
    // tests/artifacts/Arrays/immutable.py:474
    // assert sum_imm_fixed(mut_arr.freeze()) == 10, "expected sum to be 10"
    callsub sum_imm_fixed
    pushint 10 // 10
    ==
    assert // expected sum to be 10
    // tests/artifacts/Arrays/immutable.py:476
    // return self.imm_fixed_arr
    intc_0 // 0
    bytec 10 // "imm_fixed_arr"
    app_global_get_ex
    assert // check self.imm_fixed_arr exists
    frame_bury 0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock 0x 0x151f7c75 0x0000 0x00 0x0002 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 0x000a 0x62696775696e74 0x000200000000000000010000000000000002 0x000200040007000161000162 "imm_fixed_arr"
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@31
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x44d42f99 0xb7eaa60b 0x743d70ed 0x1c7e0494 0xa2d5860b 0xe05fc564 0x1e092b83 0x01310262 0xc8654a98 0x89d196f8 0x6cb7c991 0x9898bf02 0xf6b61ee8 0x60b86a7b 0x73ad283f 0x529dfae9 0x206d514f 0xe06465e2 0xec0300a2 0xecdf14af 0x511aca64 0x29852e4f 0x6d4aa358 0xb7cb96bd // method "test_uint64_array()void", method "test_biguint_array()void", method "test_bool_array(uint64)void", method "test_fixed_size_tuple_array()void", method "test_fixed_size_named_tuple_array()void", method "test_dynamic_sized_tuple_array()void", method "test_dynamic_sized_named_tuple_array()void", method "test_implicit_conversion_log(uint64[])void", method "test_implicit_conversion_emit(uint64[])void", method "test_nested_array(uint64,uint64[][])uint64[]", method "test_bit_packed_tuples()void", method "sum_uints_and_lengths_and_trues(uint64[],bool[],(uint64,bool,bool)[],(uint64,string)[])(uint64,uint64,uint64,uint64)", method "test_uint64_return(uint64)uint64[]", method "test_bool_return(uint64)bool[]", method "test_tuple_return(uint64)(uint64,bool,bool)[]", method "test_dynamic_tuple_return(uint64)(uint64,string)[]", method "test_convert_to_array_and_back((uint64,bool,bool)[],uint64)(uint64,bool,bool)[]", method "test_concat_with_arc4_tuple((uint64,uint64))uint64[]", method "test_concat_with_native_tuple((uint64,uint64))uint64[]", method "test_dynamic_concat_with_arc4_tuple((string,string))string[]", method "test_dynamic_concat_with_native_tuple((string,string))string[]", method "test_concat_immutable_dynamic((uint64,string)[],(uint64,string)[])(uint64,string)[]", method "test_immutable_arc4((uint64,uint64)[])(uint64,uint64)[]", method "test_imm_fixed_arr()(uint64,uint64)[3]"
    txna ApplicationArgs 0
    match test_uint64_array test_biguint_array test_bool_array test_fixed_size_tuple_array test_fixed_size_named_tuple_array test_dynamic_sized_tuple_array test_dynamic_sized_named_tuple_array test_implicit_conversion_log test_implicit_conversion_emit test_nested_array test_bit_packed_tuples sum_uints_and_lengths_and_trues test_uint64_return test_bool_return test_tuple_return test_dynamic_tuple_return test_convert_to_array_and_back test_concat_with_arc4_tuple test_concat_with_native_tuple test_dynamic_concat_with_arc4_tuple test_dynamic_concat_with_native_tuple test_concat_immutable_dynamic test_immutable_arc4 test_imm_fixed_arr
    err

main___algopy_default_create@31:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// _puya_lib.arc4.dynamic_array_pop_fixed_size(array: bytes, fixed_byte_size: uint64) -> bytes, bytes:
dynamic_array_pop_fixed_size:
    proto 2 2
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    itob
    extract 6 0
    frame_dig -2
    swap
    replace2 0
    dup
    len
    frame_dig -1
    -
    dup2
    frame_dig -1
    extract3
    uncover 2
    intc_0 // 0
    uncover 3
    substring3
    retsub


// _puya_lib.arc4.dynamic_array_pop_dynamic_element(array: bytes) -> bytes, bytes:
dynamic_array_pop_dynamic_element:
    proto 1 2
    frame_dig -1
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dup
    intc_2 // 2
    *
    dup
    frame_dig -1
    extract 2 0
    dup
    cover 2
    dup
    uncover 2
    extract_uint16
    dup
    uncover 2
    dup
    len
    swap
    cover 2
    substring3
    bytec_0 // 0x
    intc_0 // 0

dynamic_array_pop_dynamic_element_for_header@1:
    frame_dig 6
    frame_dig 1
    <
    bz dynamic_array_pop_dynamic_element_after_for@4
    frame_dig 2
    frame_dig 6
    dup
    cover 2
    extract_uint16
    intc_2 // 2
    -
    itob
    extract 6 2
    frame_dig 5
    swap
    concat
    frame_bury 5
    intc_2 // 2
    +
    frame_bury 6
    b dynamic_array_pop_dynamic_element_for_header@1

dynamic_array_pop_dynamic_element_after_for@4:
    frame_dig 0
    itob
    extract 6 2
    frame_dig 5
    concat
    frame_dig 1
    intc_2 // 2
    +
    frame_dig 2
    swap
    frame_dig 3
    substring3
    concat
    frame_dig 4
    frame_bury 0
    frame_bury 1
    retsub


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_0 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    cover 2
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    uncover 2
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    cover 2
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 4

dynamic_array_concat_bits_after_if_else@2:
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    pushint 16 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_byte_length_head(array: bytes, new_items_bytes: bytes, new_items_count: uint64) -> bytes:
dynamic_array_concat_byte_length_head:
    proto 3 1
    frame_dig -3
    intc_0 // 0
    extract_uint16
    dup
    frame_dig -1
    +
    swap
    intc_2 // 2
    *
    intc_2 // 2
    +
    dig 1
    itob
    extract 6 2
    cover 2
    frame_dig -3
    intc_2 // 2
    dig 2
    substring3
    frame_dig -1
    intc_2 // 2
    *
    bzero
    concat
    frame_dig -3
    len
    frame_dig -3
    uncover 3
    uncover 2
    substring3
    concat
    frame_dig -2
    concat
    swap
    intc_2 // 2
    *
    dup
    intc_0 // 0
    swap

dynamic_array_concat_byte_length_head_for_header@2:
    frame_dig 3
    frame_dig 2
    <
    bz dynamic_array_concat_byte_length_head_after_for@4
    frame_dig 4
    dup
    itob
    extract 6 2
    frame_dig 1
    frame_dig 3
    dup
    cover 4
    uncover 2
    replace3
    dup
    frame_bury 1
    dig 1
    extract_uint16
    intc_2 // 2
    +
    +
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 3
    b dynamic_array_concat_byte_length_head_for_header@2

dynamic_array_concat_byte_length_head_after_for@4:
    frame_dig 0
    frame_dig 1
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    bytec_0 // ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.sum_imm_fixed(arr: bytes) -> uint64:
sum_imm_fixed:
    // tests/artifacts/Arrays/immutable.py:479-480
    // @subroutine
    // def sum_imm_fixed(arr: NativeStruct3) -> UInt64:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:481
    // total = UInt64(0)
    intc_0 // 0
    dup

sum_imm_fixed_for_header@1:
    // tests/artifacts/Arrays/immutable.py:482
    // for item in arr:
    frame_dig 1
    pushint 3 // 3
    <
    bz sum_imm_fixed_after_for@4
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    frame_dig 1
    dup
    pushint 16 // 16
    *
    frame_dig -1
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    dup
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    intc_0 // 0
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    extract_uint64
    frame_dig 0
    +
    // tests/artifacts/Arrays/immutable.py:484
    // total += item.bar
    swap
    intc_3 // 8
    extract_uint64
    +
    frame_bury 0
    intc_1 // 1
    +
    frame_bury 1
    b sum_imm_fixed_for_header@1

sum_imm_fixed_after_for@4:
    // tests/artifacts/Arrays/immutable.py:485
    // return total
    retsub


// tests.artifacts.Arrays.immutable.times(n: uint64) -> bytes:
times:
    // tests/artifacts/Arrays/immutable.py:488-489
    // @subroutine
    // def times(n: UInt64) -> String:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:490
    // result = String()
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    intc_0 // 0

times_for_header@1:
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    frame_dig -1
    <
    bz times_after_for@4
    // tests/artifacts/Arrays/immutable.py:492
    // result += String(" ")
    frame_dig 0
    pushbytes " "
    concat
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 1
    b times_for_header@1

times_after_for@4:
    // tests/artifacts/Arrays/immutable.py:493
    // return result
    retsub


// tests.artifacts.Arrays.immutable.add_x(arr: bytes, x: uint64) -> bytes:
add_x:
    // tests/artifacts/Arrays/immutable.py:496-497
    // @subroutine
    // def add_x(arr: ImmutableArray[UInt64], x: UInt64) -> ImmutableArray[UInt64]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_0 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/immutable.py:499
    // arr = arr.append(i)
    frame_dig 0
    dup
    itob
    frame_dig -2
    swap
    concat // on error: max array length exceeded
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury -2
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    // tests/artifacts/Arrays/immutable.py:500
    // return arr
    frame_dig -2
    swap
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_array[routing]() -> void:
test_uint64_array:
    // tests/artifacts/Arrays/immutable.py:99
    // arr = arr.append(UInt64(42))
    pushbytes 0x0001000000000000002a
    // tests/artifacts/Arrays/immutable.py:103
    // arr = add_x(arr, UInt64(5))
    pushint 5 // 5
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:104
    // assert arr.length == 6
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:105
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:107
    // arr = arr.append(UInt64(43))
    pushint 43 // 43
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:108
    // assert arr.length == 7
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:109
    // assert arr[-1] == 43
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 43 // 43
    ==
    assert
    intc_2 // 2
    // tests/artifacts/Arrays/immutable.py:110
    // assert arr[0] == 42
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    intc_0 // 0

test_uint64_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    dup
    // tests/artifacts/Arrays/immutable.py:112
    // arr = pop_x(arr, UInt64(3))
    pushint 3 // 3
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    <
    bz test_uint64_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:506
    // arr = arr.pop()
    dig 1
    intc_3 // 8
    callsub dynamic_array_pop_fixed_size
    bury 3
    pop
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    dup
    intc_1 // 1
    +
    bury 1
    b test_uint64_array_for_header@2

test_uint64_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:113
    // assert arr.length == 4
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:114
    // assert arr[-1] == 2
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    intc_2 // 2
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:116
    // arr = add_x(arr, UInt64(10))
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:117
    // assert arr.length == 14
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:118
    // assert arr[-1] == 9
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:120
    // arr = arr.append(UInt64(44))
    pushint 44 // 44
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:121
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:122
    // assert arr[-1] == 44
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:124
    // arr = arr.replace(2, UInt64(23))
    pushint 23 // 23
    itob
    replace2 18 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:125
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:126
    // assert arr[2] == 23
    dup
    pushint 18 // 18
    extract_uint64
    pushint 23 // 23
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:128
    // self.a = arr
    pushbytes "a"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:94
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_biguint_array[routing]() -> void:
test_biguint_array:
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    txn NumAppArgs
    intc_1 // 1
    -
    itob
    pushint 64 // 64
    bzero
    dup
    cover 2
    b|
    // tests/artifacts/Arrays/immutable.py:132
    // arr = ImmutableArray[BigUInt]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0001
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:136
    // assert arr.length == 1
    intc_0 // 0
    extract_uint16
    dup
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:137
    // assert arr[-1] == 0
    intc_1 // 1
    -
    swap
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec_0 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_0 // 0

test_biguint_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    dup
    // tests/artifacts/Arrays/immutable.py:139
    // arr = add_xb(arr, UInt64(5))
    pushint 5 // 5
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    <
    bz test_biguint_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:513
    // arr = arr.append(BigUInt(i))
    dupn 2
    itob
    dig 4
    b|
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_1 // 1
    +
    bury 1
    b test_biguint_array_for_header@2

test_biguint_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:140
    // assert arr.length == 6
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:141
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0x04
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:143
    // arr = arr.append(BigUInt(2**512 - 1) - Txn.num_app_args)
    txn NumAppArgs
    itob
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    swap
    b-
    dup
    len
    pushint 64 // 64
    <=
    assert // overflow
    dig 5
    b|
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:144
    // assert arr.length == 7
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:145
    // assert arr[-1] == 2**512 - 2
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:146
    // assert arr[0] == 0
    dig 1
    extract 2 64
    bytec_0 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:148
    // arr = arr.append(BigUInt(2**512 - 1))
    swap
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:149
    // assert arr.length == 8
    dup
    intc_0 // 0
    extract_uint16
    dup
    intc_3 // 8
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:150
    // assert arr[-1] == 2**512 - 1
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:151
    // assert arr[0] == 0
    dup
    extract 2 64
    bytec_0 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:153
    // Box(ImmutableArray[BigUInt], key=b"biguint").value = arr
    bytec 7 // 0x62696775696e74
    box_del
    pop
    bytec 7 // 0x62696775696e74
    swap
    box_put
    // tests/artifacts/Arrays/immutable.py:130
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_array[routing]() -> void:
test_bool_array:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:157
    // arr = ImmutableArray[bool]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_0 // 0

test_bool_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    dup
    dig 3
    <
    bz test_bool_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:161
    // arr = arr.append(i == Txn.num_app_args)
    txn NumAppArgs
    dig 1
    dup
    uncover 2
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    bury 3
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_1 // 1
    +
    bury 1
    b test_bool_array_for_header@2

test_bool_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:163
    // assert arr.length == length
    dig 1
    intc_0 // 0
    extract_uint16
    dup
    bury 5
    dig 3
    dup
    cover 2
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:165
    // if length > 0:
    bz test_bool_array_after_if_else@7
    // tests/artifacts/Arrays/immutable.py:166
    // assert not arr[0], "expected element 0 to be False"
    dig 3
    assert // index access is out of bounds
    dig 1
    pushint 16 // 16
    getbit
    !
    assert // expected element 0 to be False

test_bool_array_after_if_else@7:
    // tests/artifacts/Arrays/immutable.py:167
    // if length > 1:
    dig 2
    intc_1 // 1
    >
    bz test_bool_array_after_if_else@9
    // tests/artifacts/Arrays/immutable.py:168
    // assert not arr[1], "expected element 1 to be False"
    intc_1 // 1
    dig 4
    <
    assert // index access is out of bounds
    dig 1
    pushint 17 // 17
    getbit
    !
    assert // expected element 1 to be False

test_bool_array_after_if_else@9:
    // tests/artifacts/Arrays/immutable.py:169
    // if length > 2:
    dig 2
    intc_2 // 2
    >
    bz test_bool_array_after_if_else@11
    // tests/artifacts/Arrays/immutable.py:170
    // assert arr[2], "expected element 2 to be True"
    intc_2 // 2
    dig 4
    <
    assert // index access is out of bounds
    dig 1
    pushint 18 // 18
    getbit
    assert // expected element 2 to be True

test_bool_array_after_if_else@11:
    // tests/artifacts/Arrays/immutable.py:171
    // if length > 3:
    dig 2
    pushint 3 // 3
    >
    bz test_bool_array_after_if_else@13
    // tests/artifacts/Arrays/immutable.py:172
    // assert not arr[length - 1], "expected last element to be False"
    dig 2
    intc_1 // 1
    -
    dup
    dig 5
    <
    assert // index access is out of bounds
    pushint 16 // 16
    +
    dig 2
    swap
    getbit
    !
    assert // expected last element to be False

test_bool_array_after_if_else@13:
    // tests/artifacts/Arrays/immutable.py:174
    // self.g = arr
    pushbytes "g"
    dig 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:175
    // if length:
    dig 2
    bz test_bool_array_after_if_else@15
    dig 3
    intc_1 // 1
    -
    dup
    itob
    extract 6 0
    dig 3
    swap
    replace2 0
    dig 1
    pushint 16 // 16
    +
    intc_0 // 0
    setbit
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    intc_2 // 2
    +
    intc_0 // 0
    swap
    substring3
    // tests/artifacts/Arrays/immutable.py:177
    // assert arr.length == length - 1
    intc_0 // 0
    extract_uint16
    dig 3
    intc_1 // 1
    -
    ==
    assert

test_bool_array_after_if_else@15:
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_tuple_array[routing]() -> void:
test_fixed_size_tuple_array:
    // tests/artifacts/Arrays/immutable.py:181
    // arr = ImmutableArray[tuple[UInt64, UInt64]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_fixed_size_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:185
    // arr = arr.append((i + 1, i + 2))
    dupn 2
    intc_1 // 1
    +
    swap
    intc_2 // 2
    +
    dig 1
    itob
    swap
    itob
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    bury 1
    b test_fixed_size_tuple_array_for_header@2

test_fixed_size_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:187
    // assert arr.length == 5
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:188
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:189
    // assert arr[-1] == (UInt64(5), UInt64(6))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 5 // 5
    ==
    swap
    pushint 6 // 6
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:191
    // arr = arr.pop()
    pushint 16 // 16
    callsub dynamic_array_pop_fixed_size
    bury 1
    // tests/artifacts/Arrays/immutable.py:192
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:193
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:194
    // assert arr[-1] == (UInt64(4), UInt64(5))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 4 // 4
    ==
    swap
    pushint 5 // 5
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:195
    // self.c = arr
    pushbytes "c"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:179
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_named_tuple_array[routing]() -> void:
test_fixed_size_named_tuple_array:
    // tests/artifacts/Arrays/immutable.py:199
    // arr = ImmutableArray[MyTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_named_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_fixed_size_named_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:203
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i * 3 % 2 == 0))
    dupn 2
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    *
    intc_2 // 2
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_1 // 1
    +
    bury 1
    b test_fixed_size_named_tuple_array_for_header@2

test_fixed_size_named_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:205
    // assert arr.length == 5
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:206
    // foo, bar, baz = arr[0]
    dup
    extract 2 9
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    // tests/artifacts/Arrays/immutable.py:207
    // assert foo == 0
    uncover 2
    !
    assert
    // tests/artifacts/Arrays/immutable.py:208
    // assert bar
    swap
    assert
    // tests/artifacts/Arrays/immutable.py:209
    // assert baz
    assert
    // tests/artifacts/Arrays/immutable.py:210
    // self.d = arr
    pushbytes "d"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:197
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_tuple_array[routing]() -> void:
test_dynamic_sized_tuple_array:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:214
    // arr = ImmutableArray[tuple[UInt64, Bytes]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:218
    // arr = arr.append((i + 1, op.bzero(i)))
    dupn 2
    intc_1 // 1
    +
    swap
    bzero
    dig 3
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 3
    bury 1
    b test_dynamic_sized_tuple_array_for_header@2

test_dynamic_sized_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:220
    // assert arr.length == 5
    dig 1
    intc_0 // 0
    extract_uint16
    dup
    bury 4
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    intc_0 // 0
    bury 1

test_dynamic_sized_tuple_array_for_header@6:
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@9
    // tests/artifacts/Arrays/immutable.py:222
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    dig 1
    extract 2 0
    dig 1
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    dig 6
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:223
    // assert arr[i][1].length == i, "expected 2nd element to be correct"
    len
    uncover 2
    ==
    assert // expected 2nd element to be correct
    bury 1
    b test_dynamic_sized_tuple_array_for_header@6

test_dynamic_sized_tuple_array_after_for@9:
    // tests/artifacts/Arrays/immutable.py:225
    // arr = arr.pop()
    dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:226
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:227
    // assert arr[0] == (UInt64(1), op.bzero(0)), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    intc_0 // 0
    bzero
    uncover 2
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:228
    // assert arr[-1] == (UInt64(4), op.bzero(3)), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    pushint 3 // 3
    bzero
    uncover 2
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:229
    // self.e = arr
    pushbytes "e"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:212
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_named_tuple_array[routing]() -> void:
test_dynamic_sized_named_tuple_array:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:233
    // arr = ImmutableArray[MyDynamicSizedTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_named_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:237
    // arr = arr.append(MyDynamicSizedTuple(foo=i + 1, bar=times(i)))
    dupn 2
    intc_1 // 1
    +
    swap
    callsub times
    dig 3
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 3
    bury 1
    b test_dynamic_sized_named_tuple_array_for_header@2

test_dynamic_sized_named_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:239
    // assert arr.length == 5
    dig 1
    intc_0 // 0
    extract_uint16
    dup
    bury 4
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    intc_0 // 0
    bury 1

test_dynamic_sized_named_tuple_array_for_header@6:
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@9
    // tests/artifacts/Arrays/immutable.py:241
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    dig 1
    extract 2 0
    dig 1
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    dig 6
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:242
    // assert arr[i][1] == times(i), "expected 2nd element to be correct"
    uncover 2
    callsub times
    ==
    assert // expected 2nd element to be correct
    bury 1
    b test_dynamic_sized_named_tuple_array_for_header@6

test_dynamic_sized_named_tuple_array_after_for@9:
    // tests/artifacts/Arrays/immutable.py:244
    // arr = arr.pop()
    dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:245
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:246
    // assert arr[0] == MyDynamicSizedTuple(UInt64(1), String()), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    swap
    bytec_0 // ""
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:247
    // assert arr[-1] == MyDynamicSizedTuple(UInt64(4), String("   ")), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    swap
    pushbytes "   "
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:248
    // self.f = arr
    pushbytes "f"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:231
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_log[routing]() -> void:
test_implicit_conversion_log:
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:252
    // log(arr)
    log
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_emit[routing]() -> void:
test_implicit_conversion_emit:
    // tests/artifacts/Arrays/immutable.py:256
    // arc4.emit("emit_test", arr)
    pushbytes 0xfa40c0530002
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:256
    // arc4.emit("emit_test", arr)
    concat
    log
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_nested_array[routing]() -> void:
test_nested_array:
    intc_0 // 0
    dupn 2
    bytec_0 // ""
    dupn 5
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    intc_0 // 0

test_nested_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    dup
    dig 3
    <
    bz test_nested_array_after_for@9
    // tests/artifacts/Arrays/immutable.py:264
    // extra_arr = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    bury 12
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_0 // 0
    bury 5

test_nested_array_for_header@4:
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    dig 4
    dig 1
    <
    bz test_nested_array_after_for@7
    // tests/artifacts/Arrays/immutable.py:266
    // extra_arr = extra_arr.append(j)
    dig 4
    dup
    itob
    dig 13
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 13
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_1 // 1
    +
    bury 5
    b test_nested_array_for_header@4

test_nested_array_after_for@7:
    // tests/artifacts/Arrays/immutable.py:267
    // arr = arr.append(extra_arr)
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    bytec 4 // 0x0002
    dig 14
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 2
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    dup
    intc_1 // 1
    +
    bury 1
    b test_nested_array_for_header@2

test_nested_array_after_for@9:
    // tests/artifacts/Arrays/immutable.py:269-270
    // # sum inner arrays and return an array containing sums
    // totals = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    bury 10
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    dig 1
    intc_0 // 0
    extract_uint16
    bury 9
    intc_0 // 0
    bury 7

test_nested_array_for_header@10:
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    dig 6
    dig 9
    <
    bz test_nested_array_after_for@13
    dig 1
    extract 2 0
    dig 7
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dup2
    extract_uint16
    intc_3 // 8
    *
    intc_2 // 2
    +
    extract3
    dup
    bury 12
    // tests/artifacts/Arrays/immutable.py:519
    // total = UInt64()
    intc_0 // 0
    bury 5
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    intc_0 // 0
    extract_uint16
    bury 8
    intc_0 // 0
    bury 6

test_nested_array_for_header@15:
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    dig 5
    dig 8
    <
    bz test_nested_array_after_for@17
    dig 10
    extract 2 0
    dig 6
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:521
    // total += i
    dig 5
    +
    bury 5
    intc_1 // 1
    +
    bury 6
    b test_nested_array_for_header@15

test_nested_array_after_for@17:
    // tests/artifacts/Arrays/immutable.py:272
    // totals = totals.append(sum_arr(inner_arr))
    dig 3
    itob
    dig 10
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 10
    dig 6
    intc_1 // 1
    +
    bury 7
    b test_nested_array_for_header@10

test_nested_array_after_for@13:
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 10
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bit_packed_tuples[routing]() -> void:
test_bit_packed_tuples:
    // tests/artifacts/Arrays/immutable.py:278
    // arr2 = ImmutableArray[TwoBoolTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:279-281
    // arr7 = ImmutableArray[SevenBoolTuple]()
    // arr8 = ImmutableArray[EightBoolTuple]()
    // arr9 = ImmutableArray[NineBoolTuple]()
    dupn 3
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    intc_0 // 0

test_bit_packed_tuples_for_header@2:
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_bit_packed_tuples_after_for@5
    // tests/artifacts/Arrays/immutable.py:288
    // arr2 = arr2.append(TwoBoolTuple(a=i == 0, b=i == 1))
    dupn 2
    !
    dig 1
    intc_1 // 1
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    intc_1 // 1
    uncover 2
    setbit
    dig 6
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 7
    // tests/artifacts/Arrays/immutable.py:295
    // c=i == 2,
    dig 1
    intc_2 // 2
    ==
    // tests/artifacts/Arrays/immutable.py:296
    // d=i == 3,
    dig 2
    pushint 3 // 3
    ==
    // tests/artifacts/Arrays/immutable.py:297
    // e=i == 4,
    dig 3
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/immutable.py:298
    // f=i == 5,
    dig 4
    pushint 5 // 5
    ==
    // tests/artifacts/Arrays/immutable.py:299
    // g=i == 6,
    dig 5
    pushint 6 // 6
    ==
    // tests/artifacts/Arrays/immutable.py:292
    // bar=i + 1,
    dig 6
    intc_1 // 1
    +
    // tests/artifacts/Arrays/immutable.py:289-301
    // arr7 = arr7.append(
    //     SevenBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //     )
    // )
    dig 7
    itob
    uncover 7
    intc_2 // 2
    uncover 8
    setbit
    pushint 3 // 3
    uncover 7
    setbit
    pushint 4 // 4
    uncover 6
    setbit
    pushint 5 // 5
    uncover 5
    setbit
    pushint 6 // 6
    uncover 4
    setbit
    dup2
    concat
    dig 3
    itob
    swap
    dig 1
    concat
    dig 9
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 9
    // tests/artifacts/Arrays/immutable.py:313
    // h=i == 7,
    dig 4
    pushint 7 // 7
    ==
    // tests/artifacts/Arrays/immutable.py:302-315
    // arr8 = arr8.append(
    //     EightBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //     )
    // )
    uncover 2
    pushint 7 // 7
    uncover 2
    setbit
    uncover 2
    swap
    concat
    dup
    dig 2
    concat
    dig 7
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 7
    // tests/artifacts/Arrays/immutable.py:328
    // i=i == 8,
    uncover 3
    intc_3 // 8
    ==
    // tests/artifacts/Arrays/immutable.py:316-330
    // arr9 = arr9.append(
    //     NineBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //         i=i == 8,
    //     )
    // )
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat
    swap
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    bury 1
    b test_bit_packed_tuples_for_header@2

test_bit_packed_tuples_after_for@5:
    // tests/artifacts/Arrays/immutable.py:332
    // assert arr2.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:333
    // assert arr7.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:334
    // assert arr8.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:335
    // assert arr9.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:336
    // self.bool2 = arr2
    pushbytes "bool2"
    uncover 4
    app_global_put
    // tests/artifacts/Arrays/immutable.py:337
    // self.bool7 = arr7
    pushbytes "bool7"
    uncover 3
    app_global_put
    // tests/artifacts/Arrays/immutable.py:338
    // self.bool8 = arr8
    pushbytes "bool8"
    uncover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:339
    // self.bool9 = arr9
    pushbytes "bool9"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:276
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.sum_uints_and_lengths_and_trues[routing]() -> void:
sum_uints_and_lengths_and_trues:
    bytec_0 // ""
    dupn 6
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // tests/artifacts/Arrays/immutable.py:349
    // sum1 = sum2 = sum3 = sum4 = UInt64()
    intc_0 // 0
    dupn 3
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    intc_0 // 0
    extract_uint16
    intc_0 // 0

sum_uints_and_lengths_and_trues_for_header@2:
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    dup
    dig 2
    <
    bz sum_uints_and_lengths_and_trues_after_for@5
    dig 9
    extract 2 0
    dig 1
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:351
    // sum1 += i
    dig 4
    +
    bury 4
    intc_1 // 1
    +
    bury 1
    b sum_uints_and_lengths_and_trues_for_header@2

sum_uints_and_lengths_and_trues_after_for@5:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    dig 8
    intc_0 // 0
    extract_uint16
    bury 17
    intc_0 // 0
    bury 13

sum_uints_and_lengths_and_trues_for_header@6:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    dig 12
    dig 17
    <
    bz sum_uints_and_lengths_and_trues_after_for@11
    dig 12
    pushint 16 // 16
    +
    dig 9
    swap
    getbit
    // tests/artifacts/Arrays/immutable.py:353
    // if b:
    bz sum_uints_and_lengths_and_trues_after_if_else@9
    // tests/artifacts/Arrays/immutable.py:354
    // sum2 += 1
    dig 3
    intc_1 // 1
    +
    bury 4

sum_uints_and_lengths_and_trues_after_if_else@9:
    dig 12
    intc_1 // 1
    +
    bury 13
    b sum_uints_and_lengths_and_trues_for_header@6

sum_uints_and_lengths_and_trues_after_for@11:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    dig 7
    intc_0 // 0
    extract_uint16
    bury 16
    intc_0 // 0
    bury 12

sum_uints_and_lengths_and_trues_for_header@12:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    dig 11
    dig 16
    <
    bz sum_uints_and_lengths_and_trues_after_for@19
    dig 7
    extract 2 0
    dig 12
    pushint 9 // 9
    *
    pushint 9 // 9
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    bury 13
    // tests/artifacts/Arrays/immutable.py:356
    // sum3 += tup.foo
    dig 6
    uncover 2
    +
    bury 6
    // tests/artifacts/Arrays/immutable.py:357
    // if tup.bar:
    bz sum_uints_and_lengths_and_trues_after_if_else@15
    // tests/artifacts/Arrays/immutable.py:358
    // sum3 += 1
    dig 4
    intc_1 // 1
    +
    bury 5

sum_uints_and_lengths_and_trues_after_if_else@15:
    // tests/artifacts/Arrays/immutable.py:359
    // if tup.baz:
    dig 10
    bz sum_uints_and_lengths_and_trues_after_if_else@17
    // tests/artifacts/Arrays/immutable.py:360
    // sum3 += 1
    dig 4
    intc_1 // 1
    +
    bury 5

sum_uints_and_lengths_and_trues_after_if_else@17:
    dig 11
    intc_1 // 1
    +
    bury 12
    b sum_uints_and_lengths_and_trues_for_header@12

sum_uints_and_lengths_and_trues_after_for@19:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    dig 6
    intc_0 // 0
    extract_uint16
    bury 15
    intc_0 // 0
    bury 14

sum_uints_and_lengths_and_trues_for_header@20:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    dig 13
    dig 15
    <
    bz sum_uints_and_lengths_and_trues_after_for@23
    dig 6
    extract 2 0
    dig 14
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    dig 18
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:362
    // sum4 += dyn_tup.foo
    dig 9
    uncover 2
    +
    // tests/artifacts/Arrays/immutable.py:363
    // sum4 += dyn_tup.bar.bytes.length
    swap
    len
    swap
    dig 1
    +
    bury 9
    // tests/artifacts/Arrays/immutable.py:364
    // assert dyn_tup.bar.bytes.length == idx, "expected string length to match index"
    uncover 2
    ==
    assert // expected string length to match index
    bury 14
    b sum_uints_and_lengths_and_trues_for_header@20

sum_uints_and_lengths_and_trues_after_for@23:
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    dig 2
    itob
    dig 4
    itob
    concat
    dig 5
    itob
    concat
    dig 6
    itob
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_return[routing]() -> void:
test_uint64_return:
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:370
    // arr = ImmutableArray(UInt64(1), UInt64(2), UInt64(3))
    pushbytes 0x0003000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_0 // 0

test_uint64_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_uint64_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:372
    // arr = arr.append(i)
    dupn 2
    itob
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_uint64_return_for_header@2

test_uint64_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_return[routing]() -> void:
test_bool_return:
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:377
    // arr = ImmutableArray(True, False, True, False, True)
    pushbytes 0x0005a8
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_0 // 0

test_bool_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_bool_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:379
    // arr = arr.append(i % 2 == 0)
    dupn 2
    intc_2 // 2
    %
    !
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    bury 3
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_bool_return_for_header@2

test_bool_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_tuple_return[routing]() -> void:
test_tuple_return:
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:384
    // arr = ImmutableArray(MyTuple(UInt64(), True, False))
    pushbytes 0x0001000000000000000080
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_0 // 0

test_tuple_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_tuple_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:386
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    dupn 2
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_tuple_return_for_header@2

test_tuple_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_tuple_return[routing]() -> void:
test_dynamic_tuple_return:
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:391
    // arr = ImmutableArray(MyDynamicSizedTuple(UInt64(), String("Hello")))
    pushbytes 0x000100020000000000000000000a000548656c6c6f
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_0 // 0

test_dynamic_tuple_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_dynamic_tuple_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:393
    // arr = arr.append(MyDynamicSizedTuple(i, times(i)))
    dupn 2
    callsub times
    dig 3
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 3
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_dynamic_tuple_return_for_header@2

test_dynamic_tuple_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_convert_to_array_and_back[routing]() -> void:
test_convert_to_array_and_back:
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    swap
    // tests/artifacts/Arrays/immutable.py:401
    // mutable.extend(arr)
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_0 // 0

test_convert_to_array_and_back_for_header@2:
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_convert_to_array_and_back_after_for@5
    // tests/artifacts/Arrays/immutable.py:403
    // mutable.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    dupn 2
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    dig 4
    cover 3
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    uncover 2
    swap
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_convert_to_array_and_back_for_header@2

test_convert_to_array_and_back_after_for@5:
    dig 1
    // tests/artifacts/Arrays/immutable.py:404
    // return mutable.freeze()
    dup
    len
    pushint 9 // 9
    /
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_arc4_tuple[routing]() -> void:
test_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:410
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:411
    // result = prefix + arg
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_3 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_native_tuple[routing]() -> void:
test_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    extract 0 8
    swap
    extract 8 8
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    concat
    // tests/artifacts/Arrays/immutable.py:418
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0004
    replace2 0
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_arc4_tuple[routing]() -> void:
test_dynamic_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    extract 4 0
    // tests/artifacts/Arrays/immutable.py:426
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_native_tuple[routing]() -> void:
test_dynamic_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    intc_0 // 0
    extract_uint16
    dig 1
    intc_2 // 2
    extract_uint16
    dig 2
    uncover 2
    dig 2
    substring3
    dig 2
    len
    uncover 3
    uncover 3
    uncover 2
    substring3
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    concat
    // tests/artifacts/Arrays/immutable.py:434
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_immutable_dynamic[routing]() -> void:
test_concat_immutable_dynamic:
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:442
    // return imm1 + imm2
    dig 1
    intc_0 // 0
    extract_uint16
    uncover 2
    extract 2 0
    dig 2
    extract 2 0
    uncover 3
    intc_0 // 0
    extract_uint16
    uncover 3
    uncover 3
    uncover 2
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_immutable_arc4[routing]() -> void:
test_immutable_arc4:
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:446
    // assert imm, "expected non empty array"
    dup
    intc_0 // 0
    extract_uint16
    dup
    assert // expected non empty array
    // tests/artifacts/Arrays/immutable.py:447
    // imm = imm.replace(imm.length - 1, imm[0])
    intc_1 // 1
    -
    dig 1
    extract 2 16
    swap
    pushint 16 // 16
    *
    intc_2 // 2
    +
    swap
    replace3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_imm_fixed_arr[routing]() -> void:
test_imm_fixed_arr:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:452
    // arr1 = zero_bytes(NativeStruct3)
    pushint 48 // 48
    bzero
    dup
    // tests/artifacts/Arrays/immutable.py:453
    // struct12 = NativeStruct(Txn.num_app_args + 1, Txn.num_app_args + 2)
    txn NumAppArgs
    intc_1 // 1
    +
    txn NumAppArgs
    intc_2 // 2
    +
    swap
    itob
    swap
    itob
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:454
    // arr2 = NativeStruct3((struct12, struct12, struct12))
    dup
    dig 1
    concat
    swap
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:456
    // assert arr1 != arr2, "expected arrays to be different"
    !=
    assert // expected arrays to be different
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_0 // 0

test_imm_fixed_arr_for_header@2:
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    dup
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@5
    // tests/artifacts/Arrays/immutable.py:460
    // arr1 = arr1.replace(i, struct12)
    dupn 2
    pushint 16 // 16
    *
    dig 5
    swap
    dig 5
    replace3 // on error: index access is out of bounds
    bury 5
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_1 // 1
    +
    bury 1
    b test_imm_fixed_arr_for_header@2

test_imm_fixed_arr_after_for@5:
    // tests/artifacts/Arrays/immutable.py:462
    // assert arr1 == arr2, "expected arrays to be the same"
    dig 3
    dig 2
    ==
    assert // expected arrays to be the same
    intc_0 // 0
    bury 5

test_imm_fixed_arr_for_header@6:
    // tests/artifacts/Arrays/immutable.py:464
    // for struct_it in arr1:
    dig 4
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@9
    dig 4
    dup
    pushint 16 // 16
    *
    dig 5
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:465
    // assert struct_it == struct12, "expected items on iteration to be the same"
    dig 4
    ==
    assert // expected items on iteration to be the same
    intc_1 // 1
    +
    bury 5
    b test_imm_fixed_arr_for_header@6

test_imm_fixed_arr_after_for@9:
    // tests/artifacts/Arrays/immutable.py:467
    // self.imm_fixed_arr = arr1
    bytec 10 // "imm_fixed_arr"
    dig 4
    dup
    cover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:471
    // assert sum_imm_fixed(mut_arr.freeze()) == 15, "expected sum to be 15"
    dup
    callsub sum_imm_fixed
    pushint 15 // 15
    ==
    assert // expected sum to be 15
    // tests/artifacts/Arrays/immutable.py:473
    // mut_arr[0] = NativeStruct(UInt64(), UInt64())
    pushbytes 0x00000000000000000000000000000000
    replace2 0 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:474
    // assert sum_imm_fixed(mut_arr.freeze()) == 10, "expected sum to be 10"
    callsub sum_imm_fixed
    pushint 10 // 10
    ==
    assert // expected sum to be 10
    // tests/artifacts/Arrays/immutable.py:476
    // return self.imm_fixed_arr
    intc_0 // 0
    bytec 10 // "imm_fixed_arr"
    app_global_get_ex
    assert // check self.imm_fixed_arr exists
    // tests/artifacts/Arrays/immutable.py:450
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/Arrays/data/ImmutableArrayContract.arc56.json b/tests/artifacts/Arrays/data/ImmutableArrayContract.arc56.json index a88a4d3..f460573 100644 --- a/tests/artifacts/Arrays/data/ImmutableArrayContract.arc56.json +++ b/tests/artifacts/Arrays/data/ImmutableArrayContract.arc56.json @@ -595,221 +595,173 @@ "sourceInfo": [ { "pc": [ - 330, - 346, - 365, - 387, - 430, - 449, - 476, - 495, - 518, - 538, - 558, - 578, - 598, - 640, - 652, - 675, - 690, - 705, - 717, - 729, - 741, - 753, - 769, - 781 + 153 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 798 + 340 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 333, - 349, - 368, - 390, - 433, - 452, - 479, - 498, - 521, - 541, - 561, - 581, - 601, - 643, - 655, - 678, - 693, - 708, - 720, - 732, - 744, - 756, - 772, - 784 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 4540 + 4105 ], "errorMessage": "check self.imm_fixed_arr exists" }, { "pc": [ - 2667, - 2980 + 2180, + 2488 ], "errorMessage": "expected 1, 0" }, { "pc": [ - 2582, - 2895 + 2095, + 2403 ], "errorMessage": "expected 1st element to be correct" }, { "pc": [ - 2587, - 2902 + 2100, + 2410 ], "errorMessage": "expected 2nd element to be correct" }, { "pc": [ - 2728, - 3042 + 2241, + 2550 ], "errorMessage": "expected 4, 3" }, { "pc": [ - 4422 + 3989 ], "errorMessage": "expected arrays to be different" }, { "pc": [ - 4458 + 4023 ], "errorMessage": "expected arrays to be the same" }, { "pc": [ - 2023 + 1549 ], "errorMessage": "expected element 0 to be False" }, { "pc": [ - 2042 + 1568 ], "errorMessage": "expected element 1 to be False" }, { "pc": [ - 2060 + 1586 ], "errorMessage": "expected element 2 to be True" }, { "pc": [ - 4485 + 4050 ], "errorMessage": "expected items on iteration to be the same" }, { "pc": [ - 2086 + 1612 ], "errorMessage": "expected last element to be False" }, { "pc": [ - 4364 + 3936 ], "errorMessage": "expected non empty array" }, { "pc": [ - 3870 + 3364 ], "errorMessage": "expected string length to match index" }, { "pc": [ - 4535 + 4100 ], "errorMessage": "expected sum to be 10" }, { "pc": [ - 4508 + 4073 ], "errorMessage": "expected sum to be 15" }, { "pc": [ - 1320, - 1696, - 1766, - 1823, - 1933, - 2016, - 2035, - 2054, - 2077, - 2232, - 2296, - 2538, - 2619, - 2684, - 2851, - 2934, - 2997, - 3707, - 3814, - 4481 + 853, + 1157, + 1222, + 1290, + 1347, + 1457, + 1542, + 1561, + 1580, + 1603, + 1754, + 1818, + 2051, + 2132, + 2197, + 2359, + 2442, + 2505, + 3215, + 3308, + 3951, + 4008, + 4046, + 4092 ], "errorMessage": "index access is out of bounds" }, { "pc": [ - 1391, - 1467, - 1593, - 1669, - 1721, - 1791, - 1903, - 2171, - 2364, - 3113, - 3261, - 3328, - 3414, - 3453, - 3484, - 3942, - 4065, - 4227, - 4260, - 4286 + 924, + 997, + 1121, + 1195, + 1245, + 1315, + 1427, + 1693, + 1882, + 2623, + 2770, + 2834, + 2920, + 2959, + 2990, + 3439, + 3572, + 3746, + 3780, + 3815 ], "errorMessage": "max array length exceeded" }, { "pc": [ - 1784 + 1308 ], "errorMessage": "overflow" } @@ -822,18 +774,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock 0x151f7c75 0x 0x0000 0x00 0x0002 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 0x000a 0x62696775696e74 0x000200000000000000010000000000000002 0x000200040007000161000162 "imm_fixed_arr"
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@29
    pushbytess 0x44d42f99 0xb7eaa60b 0x743d70ed 0x1c7e0494 0xa2d5860b 0xe05fc564 0x1e092b83 0x01310262 0xc8654a98 0x89d196f8 0x6cb7c991 0x9898bf02 0xf6b61ee8 0x60b86a7b 0x73ad283f 0x529dfae9 0x206d514f 0xe06465e2 0xec0300a2 0xecdf14af 0x511aca64 0x29852e4f 0x6d4aa358 0xb7cb96bd // method "test_uint64_array()void", method "test_biguint_array()void", method "test_bool_array(uint64)void", method "test_fixed_size_tuple_array()void", method "test_fixed_size_named_tuple_array()void", method "test_dynamic_sized_tuple_array()void", method "test_dynamic_sized_named_tuple_array()void", method "test_implicit_conversion_log(uint64[])void", method "test_implicit_conversion_emit(uint64[])void", method "test_nested_array(uint64,uint64[][])uint64[]", method "test_bit_packed_tuples()void", method "sum_uints_and_lengths_and_trues(uint64[],bool[],(uint64,bool,bool)[],(uint64,string)[])(uint64,uint64,uint64,uint64)", method "test_uint64_return(uint64)uint64[]", method "test_bool_return(uint64)bool[]", method "test_tuple_return(uint64)(uint64,bool,bool)[]", method "test_dynamic_tuple_return(uint64)(uint64,string)[]", method "test_convert_to_array_and_back((uint64,bool,bool)[],uint64)(uint64,bool,bool)[]", method "test_concat_with_arc4_tuple((uint64,uint64))uint64[]", method "test_concat_with_native_tuple((uint64,uint64))uint64[]", method "test_dynamic_concat_with_arc4_tuple((string,string))string[]", method "test_dynamic_concat_with_native_tuple((string,string))string[]", method "test_concat_immutable_dynamic((uint64,string)[],(uint64,string)[])(uint64,string)[]", method "test_immutable_arc4((uint64,uint64)[])(uint64,uint64)[]", method "test_imm_fixed_arr()(uint64,uint64)[3]"
    txna ApplicationArgs 0
    match main_test_uint64_array_route@3 main_test_biguint_array_route@4 main_test_bool_array_route@5 main_test_fixed_size_tuple_array_route@6 main_test_fixed_size_named_tuple_array_route@7 main_test_dynamic_sized_tuple_array_route@8 main_test_dynamic_sized_named_tuple_array_route@9 main_test_implicit_conversion_log_route@10 main_test_implicit_conversion_emit_route@11 main_test_nested_array_route@12 main_test_bit_packed_tuples_route@13 main_sum_uints_and_lengths_and_trues_route@14 main_test_uint64_return_route@15 main_test_bool_return_route@16 main_test_tuple_return_route@17 main_test_dynamic_tuple_return_route@18 main_test_convert_to_array_and_back_route@19 main_test_concat_with_arc4_tuple_route@20 main_test_concat_with_native_tuple_route@21 main_test_dynamic_concat_with_arc4_tuple_route@22 main_test_dynamic_concat_with_native_tuple_route@23 main_test_concat_immutable_dynamic_route@24 main_test_immutable_arc4_route@25 main_test_imm_fixed_arr_route@26

main_after_if_else@33:
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    intc_0 // 0
    return

main_test_imm_fixed_arr_route@26:
    // tests/artifacts/Arrays/immutable.py:450
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_imm_fixed_arr
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_immutable_arc4_route@25:
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    callsub test_immutable_arc4
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_concat_immutable_dynamic_route@24:
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    callsub test_concat_immutable_dynamic
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_dynamic_concat_with_native_tuple_route@23:
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    dup
    intc_0 // 0
    extract_uint16
    dig 1
    intc_2 // 2
    extract_uint16
    dig 2
    uncover 2
    dig 2
    substring3
    dig 2
    len
    uncover 3
    uncover 3
    uncover 2
    substring3
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    callsub test_dynamic_concat_with_native_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_dynamic_concat_with_arc4_tuple_route@22:
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    callsub test_dynamic_concat_with_arc4_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_concat_with_native_tuple_route@21:
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    dup
    extract 0 8
    swap
    extract 8 8
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    callsub test_concat_with_native_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_concat_with_arc4_tuple_route@20:
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    callsub test_concat_with_arc4_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_convert_to_array_and_back_route@19:
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    callsub test_convert_to_array_and_back
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_dynamic_tuple_return_route@18:
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    callsub test_dynamic_tuple_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_tuple_return_route@17:
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    callsub test_tuple_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_bool_return_route@16:
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    callsub test_bool_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_uint64_return_route@15:
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    callsub test_uint64_return
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_sum_uints_and_lengths_and_trues_route@14:
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    callsub sum_uints_and_lengths_and_trues
    uncover 3
    itob
    uncover 3
    itob
    concat
    uncover 2
    itob
    concat
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_bit_packed_tuples_route@13:
    // tests/artifacts/Arrays/immutable.py:276
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_bit_packed_tuples
    intc_1 // 1
    return

main_test_nested_array_route@12:
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    callsub test_nested_array
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_implicit_conversion_emit_route@11:
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    callsub test_implicit_conversion_emit
    intc_1 // 1
    return

main_test_implicit_conversion_log_route@10:
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    callsub test_implicit_conversion_log
    intc_1 // 1
    return

main_test_dynamic_sized_named_tuple_array_route@9:
    // tests/artifacts/Arrays/immutable.py:231
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_dynamic_sized_named_tuple_array
    intc_1 // 1
    return

main_test_dynamic_sized_tuple_array_route@8:
    // tests/artifacts/Arrays/immutable.py:212
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_dynamic_sized_tuple_array
    intc_1 // 1
    return

main_test_fixed_size_named_tuple_array_route@7:
    // tests/artifacts/Arrays/immutable.py:197
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_fixed_size_named_tuple_array
    intc_1 // 1
    return

main_test_fixed_size_tuple_array_route@6:
    // tests/artifacts/Arrays/immutable.py:179
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_fixed_size_tuple_array
    intc_1 // 1
    return

main_test_bool_array_route@5:
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    callsub test_bool_array
    intc_1 // 1
    return

main_test_biguint_array_route@4:
    // tests/artifacts/Arrays/immutable.py:130
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_biguint_array
    intc_1 // 1
    return

main_test_uint64_array_route@3:
    // tests/artifacts/Arrays/immutable.py:94
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_uint64_array
    intc_1 // 1
    return

main_bare_routing@29:
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@33
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.arc4.dynamic_array_pop_fixed_size(array: bytes, fixed_byte_size: uint64) -> bytes, bytes:
dynamic_array_pop_fixed_size:
    proto 2 2
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    itob
    extract 6 0
    frame_dig -2
    swap
    replace2 0
    dup
    len
    frame_dig -1
    -
    dup2
    frame_dig -1
    extract3
    uncover 2
    intc_0 // 0
    uncover 3
    substring3
    retsub


// _puya_lib.arc4.dynamic_array_pop_dynamic_element(array: bytes) -> bytes, bytes:
dynamic_array_pop_dynamic_element:
    proto 1 2
    frame_dig -1
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dup
    intc_2 // 2
    *
    dup
    frame_dig -1
    extract 2 0
    dup
    cover 2
    dup
    uncover 2
    extract_uint16
    dup
    uncover 2
    dup
    len
    swap
    cover 2
    substring3
    bytec_1 // 0x
    intc_0 // 0

dynamic_array_pop_dynamic_element_for_header@1:
    frame_dig 6
    frame_dig 1
    <
    bz dynamic_array_pop_dynamic_element_after_for@4
    frame_dig 2
    frame_dig 6
    dup
    cover 2
    extract_uint16
    intc_2 // 2
    -
    itob
    extract 6 2
    frame_dig 5
    swap
    concat
    frame_bury 5
    intc_2 // 2
    +
    frame_bury 6
    b dynamic_array_pop_dynamic_element_for_header@1

dynamic_array_pop_dynamic_element_after_for@4:
    frame_dig 0
    itob
    extract 6 2
    frame_dig 5
    concat
    frame_dig 1
    intc_2 // 2
    +
    frame_dig 2
    swap
    frame_dig 3
    substring3
    concat
    frame_dig 4
    frame_bury 0
    frame_bury 1
    retsub


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_1 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    dup
    uncover 2
    uncover 3
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    cover 3
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    cover 3
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 7

dynamic_array_concat_bits_after_if_else@2:
    frame_dig 7
    frame_bury 4
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    pushint 16 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_byte_length_head(array: bytes, new_items_bytes: bytes, new_items_count: uint64) -> bytes:
dynamic_array_concat_byte_length_head:
    proto 3 1
    frame_dig -3
    intc_0 // 0
    extract_uint16
    dup
    frame_dig -1
    +
    swap
    intc_2 // 2
    *
    intc_2 // 2
    +
    dig 1
    itob
    extract 6 2
    cover 2
    frame_dig -3
    intc_2 // 2
    dig 2
    substring3
    frame_dig -1
    intc_2 // 2
    *
    bzero
    concat
    frame_dig -3
    len
    frame_dig -3
    uncover 3
    uncover 2
    substring3
    concat
    frame_dig -2
    concat
    swap
    intc_2 // 2
    *
    dup
    intc_0 // 0
    swap

dynamic_array_concat_byte_length_head_for_header@2:
    frame_dig 3
    frame_dig 2
    <
    bz dynamic_array_concat_byte_length_head_after_for@4
    frame_dig 4
    dup
    itob
    extract 6 2
    frame_dig 1
    frame_dig 3
    dup
    cover 4
    uncover 2
    replace3
    dup
    frame_bury 1
    dig 1
    extract_uint16
    intc_2 // 2
    +
    +
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 3
    b dynamic_array_concat_byte_length_head_for_header@2

dynamic_array_concat_byte_length_head_after_for@4:
    frame_dig 0
    frame_dig 1
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    bytec_1 // ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.sum_imm_fixed(arr: bytes) -> uint64:
sum_imm_fixed:
    // tests/artifacts/Arrays/immutable.py:479-480
    // @subroutine
    // def sum_imm_fixed(arr: NativeStruct3) -> UInt64:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:481
    // total = UInt64(0)
    intc_0 // 0
    dup

sum_imm_fixed_for_header@1:
    // tests/artifacts/Arrays/immutable.py:482
    // for item in arr:
    frame_dig 1
    pushint 3 // 3
    <
    bz sum_imm_fixed_after_for@4
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    frame_dig 1
    dup
    pushint 16 // 16
    *
    frame_dig -1
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    dup
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    intc_0 // 0
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    extract_uint64
    frame_dig 0
    +
    // tests/artifacts/Arrays/immutable.py:484
    // total += item.bar
    swap
    intc_3 // 8
    extract_uint64
    +
    frame_bury 0
    intc_1 // 1
    +
    frame_bury 1
    b sum_imm_fixed_for_header@1

sum_imm_fixed_after_for@4:
    // tests/artifacts/Arrays/immutable.py:485
    // return total
    retsub


// tests.artifacts.Arrays.immutable.times(n: uint64) -> bytes:
times:
    // tests/artifacts/Arrays/immutable.py:488-489
    // @subroutine
    // def times(n: UInt64) -> String:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:490
    // result = String()
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    intc_0 // 0

times_for_header@1:
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    frame_dig -1
    <
    bz times_after_for@4
    // tests/artifacts/Arrays/immutable.py:492
    // result += String(" ")
    frame_dig 0
    pushbytes " "
    concat
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 1
    b times_for_header@1

times_after_for@4:
    // tests/artifacts/Arrays/immutable.py:493
    // return result
    retsub


// tests.artifacts.Arrays.immutable.add_x(arr: bytes, x: uint64) -> bytes:
add_x:
    // tests/artifacts/Arrays/immutable.py:496-497
    // @subroutine
    // def add_x(arr: ImmutableArray[UInt64], x: UInt64) -> ImmutableArray[UInt64]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_0 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/immutable.py:499
    // arr = arr.append(i)
    frame_dig 0
    dup
    itob
    frame_dig -2
    swap
    concat // on error: max array length exceeded
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury -2
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    // tests/artifacts/Arrays/immutable.py:500
    // return arr
    frame_dig -2
    swap
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_array() -> void:
test_uint64_array:
    // tests/artifacts/Arrays/immutable.py:94-95
    // @arc4.abimethod()
    // def test_uint64_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:99
    // arr = arr.append(UInt64(42))
    pushbytes 0x0001000000000000002a
    // tests/artifacts/Arrays/immutable.py:103
    // arr = add_x(arr, UInt64(5))
    pushint 5 // 5
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:104
    // assert arr.length == 6
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:105
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:107
    // arr = arr.append(UInt64(43))
    pushint 43 // 43
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:108
    // assert arr.length == 7
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:109
    // assert arr[-1] == 43
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 43 // 43
    ==
    assert
    intc_2 // 2
    // tests/artifacts/Arrays/immutable.py:110
    // assert arr[0] == 42
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    intc_0 // 0

test_uint64_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    frame_dig 1
    // tests/artifacts/Arrays/immutable.py:112
    // arr = pop_x(arr, UInt64(3))
    pushint 3 // 3
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    <
    bz test_uint64_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:506
    // arr = arr.pop()
    frame_dig 0
    intc_3 // 8
    callsub dynamic_array_pop_fixed_size
    frame_bury 0
    pop
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 1
    b test_uint64_array_for_header@2

test_uint64_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:113
    // assert arr.length == 4
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:114
    // assert arr[-1] == 2
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    intc_2 // 2
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:116
    // arr = add_x(arr, UInt64(10))
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:117
    // assert arr.length == 14
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:118
    // assert arr[-1] == 9
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:120
    // arr = arr.append(UInt64(44))
    pushint 44 // 44
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:121
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:122
    // assert arr[-1] == 44
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:124
    // arr = arr.replace(2, UInt64(23))
    pushint 23 // 23
    itob
    replace2 18
    // tests/artifacts/Arrays/immutable.py:125
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:126
    // assert arr[2] == 23
    dup
    pushint 18 // 18
    extract_uint64
    pushint 23 // 23
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:128
    // self.a = arr
    pushbytes "a"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_biguint_array() -> void:
test_biguint_array:
    // tests/artifacts/Arrays/immutable.py:130-131
    // @arc4.abimethod()
    // def test_biguint_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    txn NumAppArgs
    intc_1 // 1
    -
    itob
    pushint 64 // 64
    bzero
    dup
    cover 2
    b|
    // tests/artifacts/Arrays/immutable.py:132
    // arr = ImmutableArray[BigUInt]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0001
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:136
    // assert arr.length == 1
    intc_0 // 0
    extract_uint16
    dup
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:137
    // assert arr[-1] == 0
    intc_1 // 1
    -
    swap
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec_1 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_0 // 0

test_biguint_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    frame_dig 2
    // tests/artifacts/Arrays/immutable.py:139
    // arr = add_xb(arr, UInt64(5))
    pushint 5 // 5
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    <
    bz test_biguint_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:513
    // arr = arr.append(BigUInt(i))
    frame_dig 2
    dup
    itob
    frame_dig 0
    b|
    frame_dig 1
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 2
    b test_biguint_array_for_header@2

test_biguint_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:140
    // assert arr.length == 6
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:141
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0x04
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:143
    // arr = arr.append(BigUInt(2**512 - 1) - Txn.num_app_args)
    txn NumAppArgs
    itob
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    swap
    b-
    dup
    len
    pushint 64 // 64
    <=
    assert // overflow
    frame_dig 0
    b|
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:144
    // assert arr.length == 7
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:145
    // assert arr[-1] == 2**512 - 2
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:146
    // assert arr[0] == 0
    dig 1
    extract 2 64
    bytec_1 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:148
    // arr = arr.append(BigUInt(2**512 - 1))
    swap
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:149
    // assert arr.length == 8
    dup
    intc_0 // 0
    extract_uint16
    dup
    intc_3 // 8
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:150
    // assert arr[-1] == 2**512 - 1
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:151
    // assert arr[0] == 0
    dup
    extract 2 64
    bytec_1 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:153
    // Box(ImmutableArray[BigUInt], key=b"biguint").value = arr
    bytec 7 // 0x62696775696e74
    box_del
    pop
    bytec 7 // 0x62696775696e74
    swap
    box_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_array(length: uint64) -> void:
test_bool_array:
    // tests/artifacts/Arrays/immutable.py:155-156
    // @arc4.abimethod()
    // def test_bool_array(self, length: UInt64) -> None:
    proto 1 0
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:157
    // arr = ImmutableArray[bool]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_0 // 0

test_bool_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    frame_dig 2
    frame_dig -1
    <
    bz test_bool_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:161
    // arr = arr.append(i == Txn.num_app_args)
    txn NumAppArgs
    frame_dig 2
    dup
    uncover 2
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    frame_dig 1
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_1 // 1
    +
    frame_bury 2
    b test_bool_array_for_header@1

test_bool_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:163
    // assert arr.length == length
    frame_dig 1
    intc_0 // 0
    extract_uint16
    dup
    frame_bury 0
    frame_dig -1
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:165
    // if length > 0:
    frame_dig -1
    bz test_bool_array_after_if_else@6
    // tests/artifacts/Arrays/immutable.py:166
    // assert not arr[0], "expected element 0 to be False"
    frame_dig 0
    assert // index access is out of bounds
    frame_dig 1
    pushint 16 // 16
    getbit
    !
    assert // expected element 0 to be False

test_bool_array_after_if_else@6:
    // tests/artifacts/Arrays/immutable.py:167
    // if length > 1:
    frame_dig -1
    intc_1 // 1
    >
    bz test_bool_array_after_if_else@8
    // tests/artifacts/Arrays/immutable.py:168
    // assert not arr[1], "expected element 1 to be False"
    intc_1 // 1
    frame_dig 0
    <
    assert // index access is out of bounds
    frame_dig 1
    pushint 17 // 17
    getbit
    !
    assert // expected element 1 to be False

test_bool_array_after_if_else@8:
    // tests/artifacts/Arrays/immutable.py:169
    // if length > 2:
    frame_dig -1
    intc_2 // 2
    >
    bz test_bool_array_after_if_else@10
    // tests/artifacts/Arrays/immutable.py:170
    // assert arr[2], "expected element 2 to be True"
    intc_2 // 2
    frame_dig 0
    <
    assert // index access is out of bounds
    frame_dig 1
    pushint 18 // 18
    getbit
    assert // expected element 2 to be True

test_bool_array_after_if_else@10:
    // tests/artifacts/Arrays/immutable.py:171
    // if length > 3:
    frame_dig -1
    pushint 3 // 3
    >
    bz test_bool_array_after_if_else@12
    // tests/artifacts/Arrays/immutable.py:172
    // assert not arr[length - 1], "expected last element to be False"
    frame_dig -1
    intc_1 // 1
    -
    dup
    frame_dig 0
    <
    assert // index access is out of bounds
    pushint 16 // 16
    +
    frame_dig 1
    swap
    getbit
    !
    assert // expected last element to be False

test_bool_array_after_if_else@12:
    // tests/artifacts/Arrays/immutable.py:174
    // self.g = arr
    pushbytes "g"
    frame_dig 1
    app_global_put
    // tests/artifacts/Arrays/immutable.py:175
    // if length:
    frame_dig -1
    bz test_bool_array_after_if_else@14
    frame_dig 0
    intc_1 // 1
    -
    dup
    itob
    extract 6 0
    frame_dig 1
    swap
    replace2 0
    dig 1
    pushint 16 // 16
    +
    intc_0 // 0
    setbit
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    intc_2 // 2
    +
    intc_0 // 0
    swap
    substring3
    // tests/artifacts/Arrays/immutable.py:177
    // assert arr.length == length - 1
    intc_0 // 0
    extract_uint16
    frame_dig -1
    intc_1 // 1
    -
    ==
    assert

test_bool_array_after_if_else@14:
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_tuple_array() -> void:
test_fixed_size_tuple_array:
    // tests/artifacts/Arrays/immutable.py:179-180
    // @arc4.abimethod()
    // def test_fixed_size_tuple_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:181
    // arr = ImmutableArray[tuple[UInt64, UInt64]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    frame_dig 1
    pushint 5 // 5
    <
    bz test_fixed_size_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:185
    // arr = arr.append((i + 1, i + 2))
    frame_dig 1
    dup
    intc_1 // 1
    +
    swap
    intc_2 // 2
    +
    dig 1
    itob
    swap
    itob
    concat
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    frame_bury 1
    b test_fixed_size_tuple_array_for_header@1

test_fixed_size_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:187
    // assert arr.length == 5
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:188
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:189
    // assert arr[-1] == (UInt64(5), UInt64(6))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 5 // 5
    ==
    swap
    pushint 6 // 6
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:191
    // arr = arr.pop()
    pushint 16 // 16
    callsub dynamic_array_pop_fixed_size
    bury 1
    // tests/artifacts/Arrays/immutable.py:192
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:193
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:194
    // assert arr[-1] == (UInt64(4), UInt64(5))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 4 // 4
    ==
    swap
    pushint 5 // 5
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:195
    // self.c = arr
    pushbytes "c"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_named_tuple_array() -> void:
test_fixed_size_named_tuple_array:
    // tests/artifacts/Arrays/immutable.py:197-198
    // @arc4.abimethod()
    // def test_fixed_size_named_tuple_array(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:199
    // arr = ImmutableArray[MyTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_named_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    frame_dig 1
    pushint 5 // 5
    <
    bz test_fixed_size_named_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:203
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i * 3 % 2 == 0))
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    *
    intc_2 // 2
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_1 // 1
    +
    frame_bury 1
    b test_fixed_size_named_tuple_array_for_header@1

test_fixed_size_named_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:205
    // assert arr.length == 5
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:206
    // foo, bar, baz = arr[0]
    dup
    extract 2 9
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    // tests/artifacts/Arrays/immutable.py:207
    // assert foo == 0
    uncover 2
    !
    assert
    // tests/artifacts/Arrays/immutable.py:208
    // assert bar
    swap
    assert
    // tests/artifacts/Arrays/immutable.py:209
    // assert baz
    assert
    // tests/artifacts/Arrays/immutable.py:210
    // self.d = arr
    pushbytes "d"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_tuple_array() -> void:
test_dynamic_sized_tuple_array:
    // tests/artifacts/Arrays/immutable.py:212-213
    // @arc4.abimethod()
    // def test_dynamic_sized_tuple_array(self) -> None:
    proto 0 0
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:214
    // arr = ImmutableArray[tuple[UInt64, Bytes]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:218
    // arr = arr.append((i + 1, op.bzero(i)))
    frame_dig 2
    dup
    intc_1 // 1
    +
    swap
    bzero
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury 1
    frame_bury 2
    b test_dynamic_sized_tuple_array_for_header@1

test_dynamic_sized_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:220
    // assert arr.length == 5
    frame_dig 1
    intc_0 // 0
    extract_uint16
    dup
    frame_bury 0
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    intc_0 // 0
    frame_bury 2

test_dynamic_sized_tuple_array_for_header@5:
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@8
    // tests/artifacts/Arrays/immutable.py:222
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    frame_dig 1
    extract 2 0
    frame_dig 2
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    frame_dig 0
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:223
    // assert arr[i][1].length == i, "expected 2nd element to be correct"
    len
    uncover 2
    ==
    assert // expected 2nd element to be correct
    frame_bury 2
    b test_dynamic_sized_tuple_array_for_header@5

test_dynamic_sized_tuple_array_after_for@8:
    // tests/artifacts/Arrays/immutable.py:225
    // arr = arr.pop()
    frame_dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:226
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:227
    // assert arr[0] == (UInt64(1), op.bzero(0)), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    intc_0 // 0
    bzero
    uncover 2
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:228
    // assert arr[-1] == (UInt64(4), op.bzero(3)), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    pushint 3 // 3
    bzero
    uncover 2
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:229
    // self.e = arr
    pushbytes "e"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_named_tuple_array() -> void:
test_dynamic_sized_named_tuple_array:
    // tests/artifacts/Arrays/immutable.py:231-232
    // @arc4.abimethod()
    // def test_dynamic_sized_named_tuple_array(self) -> None:
    proto 0 0
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:233
    // arr = ImmutableArray[MyDynamicSizedTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_named_tuple_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:237
    // arr = arr.append(MyDynamicSizedTuple(foo=i + 1, bar=times(i)))
    frame_dig 2
    dup
    intc_1 // 1
    +
    swap
    callsub times
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury 1
    frame_bury 2
    b test_dynamic_sized_named_tuple_array_for_header@1

test_dynamic_sized_named_tuple_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:239
    // assert arr.length == 5
    frame_dig 1
    intc_0 // 0
    extract_uint16
    dup
    frame_bury 0
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    intc_0 // 0
    frame_bury 2

test_dynamic_sized_named_tuple_array_for_header@5:
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    frame_dig 2
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@8
    // tests/artifacts/Arrays/immutable.py:241
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    frame_dig 1
    extract 2 0
    frame_dig 2
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    frame_dig 0
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:242
    // assert arr[i][1] == times(i), "expected 2nd element to be correct"
    uncover 2
    callsub times
    ==
    assert // expected 2nd element to be correct
    frame_bury 2
    b test_dynamic_sized_named_tuple_array_for_header@5

test_dynamic_sized_named_tuple_array_after_for@8:
    // tests/artifacts/Arrays/immutable.py:244
    // arr = arr.pop()
    frame_dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:245
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:246
    // assert arr[0] == MyDynamicSizedTuple(UInt64(1), String()), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    swap
    bytec_1 // ""
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:247
    // assert arr[-1] == MyDynamicSizedTuple(UInt64(4), String("   ")), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    swap
    pushbytes "   "
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:248
    // self.f = arr
    pushbytes "f"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_log(arr: bytes) -> void:
test_implicit_conversion_log:
    // tests/artifacts/Arrays/immutable.py:250-251
    // @arc4.abimethod()
    // def test_implicit_conversion_log(self, arr: ImmutableArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/immutable.py:252
    // log(arr)
    frame_dig -1
    log
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_emit(arr: bytes) -> void:
test_implicit_conversion_emit:
    // tests/artifacts/Arrays/immutable.py:254-255
    // @arc4.abimethod()
    // def test_implicit_conversion_emit(self, arr: ImmutableArray[UInt64]) -> None:
    proto 1 0
    // tests/artifacts/Arrays/immutable.py:256
    // arc4.emit("emit_test", arr)
    pushbytes 0xfa40c0530002
    frame_dig -1
    concat
    log
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_nested_array(arr_to_add: uint64, arr: bytes) -> bytes:
test_nested_array:
    // tests/artifacts/Arrays/immutable.py:258-261
    // @arc4.abimethod()
    // def test_nested_array(
    //     self, arr_to_add: UInt64, arr: ImmutableArray[ImmutableArray[UInt64]]
    // ) -> ImmutableArray[UInt64]:
    proto 2 1
    intc_0 // 0
    dupn 2
    bytec_1 // ""
    dupn 5
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    intc_0 // 0

test_nested_array_for_header@1:
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    frame_dig 9
    frame_dig -2
    <
    bz test_nested_array_after_for@8
    // tests/artifacts/Arrays/immutable.py:264
    // extra_arr = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_0 // 0
    frame_bury 7

test_nested_array_for_header@3:
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    frame_dig 7
    frame_dig 9
    <
    bz test_nested_array_after_for@6
    // tests/artifacts/Arrays/immutable.py:266
    // extra_arr = extra_arr.append(j)
    frame_dig 7
    dup
    itob
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_1 // 1
    +
    frame_bury 7
    b test_nested_array_for_header@3

test_nested_array_after_for@6:
    // tests/artifacts/Arrays/immutable.py:267
    // arr = arr.append(extra_arr)
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_dig -1
    extract 2 0
    bytec 4 // 0x0002
    frame_dig 0
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury -1
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    frame_dig 9
    intc_1 // 1
    +
    frame_bury 9
    b test_nested_array_for_header@1

test_nested_array_after_for@8:
    // tests/artifacts/Arrays/immutable.py:269-270
    // # sum inner arrays and return an array containing sums
    // totals = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    frame_bury 2
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_bury 3
    intc_0 // 0
    frame_bury 5

test_nested_array_for_header@9:
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    frame_dig 5
    frame_dig 3
    <
    bz test_nested_array_after_for@12
    frame_dig -1
    extract 2 0
    frame_dig 5
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dup2
    extract_uint16
    intc_3 // 8
    *
    intc_2 // 2
    +
    extract3
    dup
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:519
    // total = UInt64()
    intc_0 // 0
    frame_bury 8
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    intc_0 // 0
    extract_uint16
    frame_bury 4
    intc_0 // 0
    frame_bury 6

test_nested_array_for_header@14:
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    frame_dig 6
    frame_dig 4
    <
    bz test_nested_array_after_for@16
    frame_dig 1
    extract 2 0
    frame_dig 6
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:521
    // total += i
    frame_dig 8
    +
    frame_bury 8
    intc_1 // 1
    +
    frame_bury 6
    b test_nested_array_for_header@14

test_nested_array_after_for@16:
    // tests/artifacts/Arrays/immutable.py:272
    // totals = totals.append(sum_arr(inner_arr))
    frame_dig 8
    itob
    frame_dig 2
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 2
    frame_dig 5
    intc_1 // 1
    +
    frame_bury 5
    b test_nested_array_for_header@9

test_nested_array_after_for@12:
    // tests/artifacts/Arrays/immutable.py:274
    // return totals
    frame_dig 2
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bit_packed_tuples() -> void:
test_bit_packed_tuples:
    // tests/artifacts/Arrays/immutable.py:276-277
    // @arc4.abimethod()
    // def test_bit_packed_tuples(self) -> None:
    proto 0 0
    // tests/artifacts/Arrays/immutable.py:278
    // arr2 = ImmutableArray[TwoBoolTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:279-281
    // arr7 = ImmutableArray[SevenBoolTuple]()
    // arr8 = ImmutableArray[EightBoolTuple]()
    // arr9 = ImmutableArray[NineBoolTuple]()
    dupn 3
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    intc_0 // 0

test_bit_packed_tuples_for_header@1:
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    frame_dig 4
    pushint 5 // 5
    <
    bz test_bit_packed_tuples_after_for@4
    // tests/artifacts/Arrays/immutable.py:288
    // arr2 = arr2.append(TwoBoolTuple(a=i == 0, b=i == 1))
    frame_dig 4
    dup
    !
    dig 1
    intc_1 // 1
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    intc_1 // 1
    uncover 2
    setbit
    frame_dig 0
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:295
    // c=i == 2,
    dig 1
    intc_2 // 2
    ==
    // tests/artifacts/Arrays/immutable.py:296
    // d=i == 3,
    dig 2
    pushint 3 // 3
    ==
    // tests/artifacts/Arrays/immutable.py:297
    // e=i == 4,
    dig 3
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/immutable.py:298
    // f=i == 5,
    dig 4
    pushint 5 // 5
    ==
    // tests/artifacts/Arrays/immutable.py:299
    // g=i == 6,
    dig 5
    pushint 6 // 6
    ==
    // tests/artifacts/Arrays/immutable.py:292
    // bar=i + 1,
    dig 6
    intc_1 // 1
    +
    // tests/artifacts/Arrays/immutable.py:289-301
    // arr7 = arr7.append(
    //     SevenBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //     )
    // )
    dig 7
    itob
    uncover 7
    intc_2 // 2
    uncover 8
    setbit
    pushint 3 // 3
    uncover 7
    setbit
    pushint 4 // 4
    uncover 6
    setbit
    pushint 5 // 5
    uncover 5
    setbit
    pushint 6 // 6
    uncover 4
    setbit
    dup2
    concat
    dig 3
    itob
    swap
    dig 1
    concat
    frame_dig 1
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:313
    // h=i == 7,
    dig 4
    pushint 7 // 7
    ==
    // tests/artifacts/Arrays/immutable.py:302-315
    // arr8 = arr8.append(
    //     EightBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //     )
    // )
    uncover 2
    pushint 7 // 7
    uncover 2
    setbit
    uncover 2
    swap
    concat
    dup
    dig 2
    concat
    frame_dig 2
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 2
    // tests/artifacts/Arrays/immutable.py:328
    // i=i == 8,
    uncover 3
    intc_3 // 8
    ==
    // tests/artifacts/Arrays/immutable.py:316-330
    // arr9 = arr9.append(
    //     NineBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //         i=i == 8,
    //     )
    // )
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat
    swap
    concat
    frame_dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 3
    frame_bury 4
    b test_bit_packed_tuples_for_header@1

test_bit_packed_tuples_after_for@4:
    // tests/artifacts/Arrays/immutable.py:332
    // assert arr2.length == 5
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:333
    // assert arr7.length == 5
    frame_dig 1
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:334
    // assert arr8.length == 5
    frame_dig 2
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:335
    // assert arr9.length == 5
    frame_dig 3
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:336
    // self.bool2 = arr2
    pushbytes "bool2"
    uncover 4
    app_global_put
    // tests/artifacts/Arrays/immutable.py:337
    // self.bool7 = arr7
    pushbytes "bool7"
    uncover 3
    app_global_put
    // tests/artifacts/Arrays/immutable.py:338
    // self.bool8 = arr8
    pushbytes "bool8"
    uncover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:339
    // self.bool9 = arr9
    pushbytes "bool9"
    swap
    app_global_put
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.sum_uints_and_lengths_and_trues(arr1: bytes, arr2: bytes, arr3: bytes, arr4: bytes) -> uint64, uint64, uint64, uint64:
sum_uints_and_lengths_and_trues:
    // tests/artifacts/Arrays/immutable.py:341-348
    // @arc4.abimethod()
    // def sum_uints_and_lengths_and_trues(
    //     self,
    //     arr1: ImmutableArray[UInt64],
    //     arr2: ImmutableArray[bool],
    //     arr3: ImmutableArray[MyTuple],
    //     arr4: ImmutableArray[MyDynamicSizedTuple],
    // ) -> tuple[UInt64, UInt64, UInt64, UInt64]:
    proto 4 4
    bytec_1 // ""
    dupn 8
    // tests/artifacts/Arrays/immutable.py:349
    // sum1 = sum2 = sum3 = sum4 = UInt64()
    intc_0 // 0
    dupn 3
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    frame_dig -4
    intc_0 // 0
    extract_uint16
    intc_0 // 0

sum_uints_and_lengths_and_trues_for_header@1:
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    frame_dig 14
    frame_dig 13
    <
    bz sum_uints_and_lengths_and_trues_after_for@4
    frame_dig -4
    extract 2 0
    frame_dig 14
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:351
    // sum1 += i
    frame_dig 12
    +
    frame_bury 12
    intc_1 // 1
    +
    frame_bury 14
    b sum_uints_and_lengths_and_trues_for_header@1

sum_uints_and_lengths_and_trues_after_for@4:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    frame_dig -3
    intc_0 // 0
    extract_uint16
    frame_bury 0
    intc_0 // 0
    frame_bury 4

sum_uints_and_lengths_and_trues_for_header@5:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    frame_dig 4
    frame_dig 0
    <
    bz sum_uints_and_lengths_and_trues_after_for@10
    frame_dig 4
    pushint 16 // 16
    +
    frame_dig -3
    swap
    getbit
    frame_dig 11
    frame_bury 6
    // tests/artifacts/Arrays/immutable.py:353
    // if b:
    bz sum_uints_and_lengths_and_trues_after_if_else@8
    // tests/artifacts/Arrays/immutable.py:354
    // sum2 += 1
    frame_dig 11
    intc_1 // 1
    +
    frame_bury 6

sum_uints_and_lengths_and_trues_after_if_else@8:
    frame_dig 6
    frame_bury 11
    frame_dig 4
    intc_1 // 1
    +
    frame_bury 4
    b sum_uints_and_lengths_and_trues_for_header@5

sum_uints_and_lengths_and_trues_after_for@10:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    frame_dig -2
    intc_0 // 0
    extract_uint16
    frame_bury 1
    intc_0 // 0
    frame_bury 5

sum_uints_and_lengths_and_trues_for_header@11:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    frame_dig 5
    frame_dig 1
    <
    bz sum_uints_and_lengths_and_trues_after_for@18
    frame_dig -2
    extract 2 0
    frame_dig 5
    pushint 9 // 9
    *
    pushint 9 // 9
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    frame_bury 8
    // tests/artifacts/Arrays/immutable.py:356
    // sum3 += tup.foo
    frame_dig 10
    uncover 2
    +
    dup
    frame_bury 10
    frame_bury 7
    // tests/artifacts/Arrays/immutable.py:357
    // if tup.bar:
    bz sum_uints_and_lengths_and_trues_after_if_else@14
    // tests/artifacts/Arrays/immutable.py:358
    // sum3 += 1
    frame_dig 10
    intc_1 // 1
    +
    frame_bury 7

sum_uints_and_lengths_and_trues_after_if_else@14:
    frame_dig 7
    dup
    frame_bury 10
    frame_bury 7
    // tests/artifacts/Arrays/immutable.py:359
    // if tup.baz:
    frame_dig 8
    bz sum_uints_and_lengths_and_trues_after_if_else@16
    // tests/artifacts/Arrays/immutable.py:360
    // sum3 += 1
    frame_dig 10
    intc_1 // 1
    +
    frame_bury 7

sum_uints_and_lengths_and_trues_after_if_else@16:
    frame_dig 7
    frame_bury 10
    frame_dig 5
    intc_1 // 1
    +
    frame_bury 5
    b sum_uints_and_lengths_and_trues_for_header@11

sum_uints_and_lengths_and_trues_after_for@18:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_bury 2
    intc_0 // 0
    frame_bury 3

sum_uints_and_lengths_and_trues_for_header@19:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    frame_dig 3
    frame_dig 2
    <
    bz sum_uints_and_lengths_and_trues_after_for@22
    frame_dig -1
    extract 2 0
    frame_dig 3
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    frame_dig 2
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:362
    // sum4 += dyn_tup.foo
    frame_dig 9
    uncover 2
    +
    // tests/artifacts/Arrays/immutable.py:363
    // sum4 += dyn_tup.bar.bytes.length
    swap
    len
    swap
    dig 1
    +
    frame_bury 9
    // tests/artifacts/Arrays/immutable.py:364
    // assert dyn_tup.bar.bytes.length == idx, "expected string length to match index"
    uncover 2
    ==
    assert // expected string length to match index
    frame_bury 3
    b sum_uints_and_lengths_and_trues_for_header@19

sum_uints_and_lengths_and_trues_after_for@22:
    // tests/artifacts/Arrays/immutable.py:366
    // return sum1, sum2, sum3, sum4
    frame_dig 12
    frame_dig 11
    frame_dig 10
    frame_dig 9
    frame_bury 3
    frame_bury 2
    frame_bury 1
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_return(append: uint64) -> bytes:
test_uint64_return:
    // tests/artifacts/Arrays/immutable.py:368-369
    // @arc4.abimethod()
    // def test_uint64_return(self, append: UInt64) -> ImmutableArray[UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:370
    // arr = ImmutableArray(UInt64(1), UInt64(2), UInt64(3))
    pushbytes 0x0003000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_0 // 0

test_uint64_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_uint64_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:372
    // arr = arr.append(i)
    frame_dig 1
    dup
    itob
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_uint64_return_for_header@1

test_uint64_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:373
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_return(append: uint64) -> bytes:
test_bool_return:
    // tests/artifacts/Arrays/immutable.py:375-376
    // @arc4.abimethod()
    // def test_bool_return(self, append: UInt64) -> ImmutableArray[bool]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:377
    // arr = ImmutableArray(True, False, True, False, True)
    pushbytes 0x0005a8
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_0 // 0

test_bool_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_bool_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:379
    // arr = arr.append(i % 2 == 0)
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    frame_dig 0
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_bool_return_for_header@1

test_bool_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:380
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_tuple_return(append: uint64) -> bytes:
test_tuple_return:
    // tests/artifacts/Arrays/immutable.py:382-383
    // @arc4.abimethod()
    // def test_tuple_return(self, append: UInt64) -> ImmutableArray[MyTuple]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:384
    // arr = ImmutableArray(MyTuple(UInt64(), True, False))
    pushbytes 0x0001000000000000000080
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_0 // 0

test_tuple_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_tuple_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:386
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    frame_dig 0
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_tuple_return_for_header@1

test_tuple_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:387
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_tuple_return(append: uint64) -> bytes:
test_dynamic_tuple_return:
    // tests/artifacts/Arrays/immutable.py:389-390
    // @arc4.abimethod()
    // def test_dynamic_tuple_return(self, append: UInt64) -> ImmutableArray[MyDynamicSizedTuple]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:391
    // arr = ImmutableArray(MyDynamicSizedTuple(UInt64(), String("Hello")))
    pushbytes 0x000100020000000000000000000a000548656c6c6f
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_0 // 0

test_dynamic_tuple_return_for_header@1:
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_dynamic_tuple_return_after_for@4
    // tests/artifacts/Arrays/immutable.py:393
    // arr = arr.append(MyDynamicSizedTuple(i, times(i)))
    frame_dig 1
    dup
    callsub times
    frame_dig 0
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_dynamic_tuple_return_for_header@1

test_dynamic_tuple_return_after_for@4:
    // tests/artifacts/Arrays/immutable.py:394
    // return arr
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_convert_to_array_and_back(arr: bytes, append: uint64) -> bytes:
test_convert_to_array_and_back:
    // tests/artifacts/Arrays/immutable.py:396-399
    // @arc4.abimethod()
    // def test_convert_to_array_and_back(
    //     self, arr: ImmutableArray[MyTuple], append: UInt64
    // ) -> ImmutableArray[MyTuple]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:401
    // mutable.extend(arr)
    frame_dig -2
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_0 // 0

test_convert_to_array_and_back_for_header@1:
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    frame_dig 1
    frame_dig -1
    <
    bz test_convert_to_array_and_back_after_for@4
    // tests/artifacts/Arrays/immutable.py:403
    // mutable.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    frame_dig 1
    dup
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    frame_dig 0
    cover 3
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    uncover 2
    swap
    concat // on error: max array length exceeded
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_1 // 1
    +
    frame_bury 1
    b test_convert_to_array_and_back_for_header@1

test_convert_to_array_and_back_after_for@4:
    frame_dig 0
    // tests/artifacts/Arrays/immutable.py:404
    // return mutable.freeze()
    dup
    len
    pushint 9 // 9
    /
    itob
    extract 6 2
    swap
    concat
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_arc4_tuple(arg: bytes) -> bytes:
test_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:406-409
    // @arc4.abimethod()
    // def test_concat_with_arc4_tuple(
    //     self, arg: arc4.Tuple[arc4.UInt64, arc4.UInt64]
    // ) -> ImmutableArray[arc4.UInt64]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:410
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:411
    // result = prefix + arg
    frame_dig -1
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_3 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:412
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_native_tuple(arg.0: bytes, arg.1: bytes) -> bytes:
test_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:414-417
    // @arc4.abimethod()
    // def test_concat_with_native_tuple(
    //     self, arg: tuple[arc4.UInt64, arc4.UInt64]
    // ) -> ImmutableArray[arc4.UInt64]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    frame_dig -2
    frame_dig -1
    concat
    // tests/artifacts/Arrays/immutable.py:418
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0004
    replace2 0
    // tests/artifacts/Arrays/immutable.py:420
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_arc4_tuple(arg: bytes) -> bytes:
test_dynamic_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:422-425
    // @arc4.abimethod()
    // def test_dynamic_concat_with_arc4_tuple(
    //     self, arg: arc4.Tuple[arc4.String, arc4.String]
    // ) -> ImmutableArray[arc4.String]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    frame_dig -1
    len
    frame_dig -1
    pushint 4 // 4
    uncover 2
    substring3
    // tests/artifacts/Arrays/immutable.py:426
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:428
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_native_tuple(arg.0: bytes, arg.1: bytes) -> bytes:
test_dynamic_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:430-433
    // @arc4.abimethod()
    // def test_dynamic_concat_with_native_tuple(
    //     self, arg: tuple[arc4.String, arc4.String]
    // ) -> ImmutableArray[arc4.String]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    frame_dig -2
    frame_dig -1
    concat
    // tests/artifacts/Arrays/immutable.py:434
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:436
    // return result
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_immutable_dynamic(imm1: bytes, imm2: bytes) -> bytes:
test_concat_immutable_dynamic:
    // tests/artifacts/Arrays/immutable.py:438-441
    // @arc4.abimethod()
    // def test_concat_immutable_dynamic(
    //     self, imm1: ImmutableArray[MyDynamicSizedTuple], imm2: ImmutableArray[MyDynamicSizedTuple]
    // ) -> ImmutableArray[MyDynamicSizedTuple]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:442
    // return imm1 + imm2
    frame_dig -2
    intc_0 // 0
    extract_uint16
    frame_dig -2
    extract 2 0
    frame_dig -1
    intc_0 // 0
    extract_uint16
    frame_dig -1
    extract 2 0
    callsub dynamic_array_concat_dynamic_element
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_immutable_arc4(imm: bytes) -> bytes:
test_immutable_arc4:
    // tests/artifacts/Arrays/immutable.py:444-445
    // @arc4.abimethod()
    // def test_immutable_arc4(self, imm: ImmutableArray[MyStruct]) -> ImmutableArray[MyStruct]:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:446
    // assert imm, "expected non empty array"
    frame_dig -1
    intc_0 // 0
    extract_uint16
    dup
    assert // expected non empty array
    // tests/artifacts/Arrays/immutable.py:447
    // imm = imm.replace(imm.length - 1, imm[0])
    intc_1 // 1
    -
    frame_dig -1
    extract 2 16
    swap
    pushint 16 // 16
    *
    intc_2 // 2
    +
    frame_dig -1
    swap
    uncover 2
    replace3
    dup
    frame_bury -1
    // tests/artifacts/Arrays/immutable.py:448
    // return imm
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_imm_fixed_arr() -> bytes:
test_imm_fixed_arr:
    // tests/artifacts/Arrays/immutable.py:450-451
    // @arc4.abimethod()
    // def test_imm_fixed_arr(self) -> NativeStruct3:
    proto 0 1
    bytec_1 // ""
    // tests/artifacts/Arrays/immutable.py:452
    // arr1 = zero_bytes(NativeStruct3)
    pushint 48 // 48
    bzero
    dup
    // tests/artifacts/Arrays/immutable.py:453
    // struct12 = NativeStruct(Txn.num_app_args + 1, Txn.num_app_args + 2)
    txn NumAppArgs
    intc_1 // 1
    +
    txn NumAppArgs
    intc_2 // 2
    +
    swap
    itob
    swap
    itob
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:454
    // arr2 = NativeStruct3((struct12, struct12, struct12))
    dup
    dig 1
    concat
    swap
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:456
    // assert arr1 != arr2, "expected arrays to be different"
    !=
    assert // expected arrays to be different
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_0 // 0

test_imm_fixed_arr_for_header@1:
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    frame_dig 4
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@4
    // tests/artifacts/Arrays/immutable.py:460
    // arr1 = arr1.replace(i, struct12)
    frame_dig 4
    dup
    pushint 16 // 16
    *
    frame_dig 1
    swap
    frame_dig 2
    replace3
    frame_bury 1
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_1 // 1
    +
    frame_bury 4
    b test_imm_fixed_arr_for_header@1

test_imm_fixed_arr_after_for@4:
    // tests/artifacts/Arrays/immutable.py:462
    // assert arr1 == arr2, "expected arrays to be the same"
    frame_dig 1
    frame_dig 3
    ==
    assert // expected arrays to be the same
    intc_0 // 0
    frame_bury 0

test_imm_fixed_arr_for_header@5:
    // tests/artifacts/Arrays/immutable.py:464
    // for struct_it in arr1:
    frame_dig 0
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@8
    frame_dig 0
    dup
    pushint 16 // 16
    *
    frame_dig 1
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:465
    // assert struct_it == struct12, "expected items on iteration to be the same"
    frame_dig 2
    ==
    assert // expected items on iteration to be the same
    intc_1 // 1
    +
    frame_bury 0
    b test_imm_fixed_arr_for_header@5

test_imm_fixed_arr_after_for@8:
    // tests/artifacts/Arrays/immutable.py:467
    // self.imm_fixed_arr = arr1
    bytec 10 // "imm_fixed_arr"
    frame_dig 1
    dup
    cover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:471
    // assert sum_imm_fixed(mut_arr.freeze()) == 15, "expected sum to be 15"
    dup
    callsub sum_imm_fixed
    pushint 15 // 15
    ==
    assert // expected sum to be 15
    // tests/artifacts/Arrays/immutable.py:473
    // mut_arr[0] = NativeStruct(UInt64(), UInt64())
    pushbytes 0x00000000000000000000000000000000
    replace2 0
    // tests/artifacts/Arrays/immutable.py:474
    // assert sum_imm_fixed(mut_arr.freeze()) == 10, "expected sum to be 10"
    callsub sum_imm_fixed
    pushint 10 // 10
    ==
    assert // expected sum to be 10
    // tests/artifacts/Arrays/immutable.py:476
    // return self.imm_fixed_arr
    intc_0 // 0
    bytec 10 // "imm_fixed_arr"
    app_global_get_ex
    assert // check self.imm_fixed_arr exists
    frame_bury 0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock 0x 0x151f7c75 0x0000 0x00 0x0002 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 0x000a 0x62696775696e74 0x000200000000000000010000000000000002 0x000200040007000161000162 "imm_fixed_arr"
    // tests/artifacts/Arrays/immutable.py:93
    // class ImmutableArrayContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@31
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x44d42f99 0xb7eaa60b 0x743d70ed 0x1c7e0494 0xa2d5860b 0xe05fc564 0x1e092b83 0x01310262 0xc8654a98 0x89d196f8 0x6cb7c991 0x9898bf02 0xf6b61ee8 0x60b86a7b 0x73ad283f 0x529dfae9 0x206d514f 0xe06465e2 0xec0300a2 0xecdf14af 0x511aca64 0x29852e4f 0x6d4aa358 0xb7cb96bd // method "test_uint64_array()void", method "test_biguint_array()void", method "test_bool_array(uint64)void", method "test_fixed_size_tuple_array()void", method "test_fixed_size_named_tuple_array()void", method "test_dynamic_sized_tuple_array()void", method "test_dynamic_sized_named_tuple_array()void", method "test_implicit_conversion_log(uint64[])void", method "test_implicit_conversion_emit(uint64[])void", method "test_nested_array(uint64,uint64[][])uint64[]", method "test_bit_packed_tuples()void", method "sum_uints_and_lengths_and_trues(uint64[],bool[],(uint64,bool,bool)[],(uint64,string)[])(uint64,uint64,uint64,uint64)", method "test_uint64_return(uint64)uint64[]", method "test_bool_return(uint64)bool[]", method "test_tuple_return(uint64)(uint64,bool,bool)[]", method "test_dynamic_tuple_return(uint64)(uint64,string)[]", method "test_convert_to_array_and_back((uint64,bool,bool)[],uint64)(uint64,bool,bool)[]", method "test_concat_with_arc4_tuple((uint64,uint64))uint64[]", method "test_concat_with_native_tuple((uint64,uint64))uint64[]", method "test_dynamic_concat_with_arc4_tuple((string,string))string[]", method "test_dynamic_concat_with_native_tuple((string,string))string[]", method "test_concat_immutable_dynamic((uint64,string)[],(uint64,string)[])(uint64,string)[]", method "test_immutable_arc4((uint64,uint64)[])(uint64,uint64)[]", method "test_imm_fixed_arr()(uint64,uint64)[3]"
    txna ApplicationArgs 0
    match test_uint64_array test_biguint_array test_bool_array test_fixed_size_tuple_array test_fixed_size_named_tuple_array test_dynamic_sized_tuple_array test_dynamic_sized_named_tuple_array test_implicit_conversion_log test_implicit_conversion_emit test_nested_array test_bit_packed_tuples sum_uints_and_lengths_and_trues test_uint64_return test_bool_return test_tuple_return test_dynamic_tuple_return test_convert_to_array_and_back test_concat_with_arc4_tuple test_concat_with_native_tuple test_dynamic_concat_with_arc4_tuple test_dynamic_concat_with_native_tuple test_concat_immutable_dynamic test_immutable_arc4 test_imm_fixed_arr
    err

main___algopy_default_create@31:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// _puya_lib.arc4.dynamic_array_pop_fixed_size(array: bytes, fixed_byte_size: uint64) -> bytes, bytes:
dynamic_array_pop_fixed_size:
    proto 2 2
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    itob
    extract 6 0
    frame_dig -2
    swap
    replace2 0
    dup
    len
    frame_dig -1
    -
    dup2
    frame_dig -1
    extract3
    uncover 2
    intc_0 // 0
    uncover 3
    substring3
    retsub


// _puya_lib.arc4.dynamic_array_pop_dynamic_element(array: bytes) -> bytes, bytes:
dynamic_array_pop_dynamic_element:
    proto 1 2
    frame_dig -1
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dup
    intc_2 // 2
    *
    dup
    frame_dig -1
    extract 2 0
    dup
    cover 2
    dup
    uncover 2
    extract_uint16
    dup
    uncover 2
    dup
    len
    swap
    cover 2
    substring3
    bytec_0 // 0x
    intc_0 // 0

dynamic_array_pop_dynamic_element_for_header@1:
    frame_dig 6
    frame_dig 1
    <
    bz dynamic_array_pop_dynamic_element_after_for@4
    frame_dig 2
    frame_dig 6
    dup
    cover 2
    extract_uint16
    intc_2 // 2
    -
    itob
    extract 6 2
    frame_dig 5
    swap
    concat
    frame_bury 5
    intc_2 // 2
    +
    frame_bury 6
    b dynamic_array_pop_dynamic_element_for_header@1

dynamic_array_pop_dynamic_element_after_for@4:
    frame_dig 0
    itob
    extract 6 2
    frame_dig 5
    concat
    frame_dig 1
    intc_2 // 2
    +
    frame_dig 2
    swap
    frame_dig 3
    substring3
    concat
    frame_dig 4
    frame_bury 0
    frame_bury 1
    retsub


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_0 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    cover 2
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    uncover 2
    pushint 7 // 7
    +
    intc_3 // 8
    /
    dup
    cover 2
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 4

dynamic_array_concat_bits_after_if_else@2:
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    pushint 16 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_byte_length_head(array: bytes, new_items_bytes: bytes, new_items_count: uint64) -> bytes:
dynamic_array_concat_byte_length_head:
    proto 3 1
    frame_dig -3
    intc_0 // 0
    extract_uint16
    dup
    frame_dig -1
    +
    swap
    intc_2 // 2
    *
    intc_2 // 2
    +
    dig 1
    itob
    extract 6 2
    cover 2
    frame_dig -3
    intc_2 // 2
    dig 2
    substring3
    frame_dig -1
    intc_2 // 2
    *
    bzero
    concat
    frame_dig -3
    len
    frame_dig -3
    uncover 3
    uncover 2
    substring3
    concat
    frame_dig -2
    concat
    swap
    intc_2 // 2
    *
    dup
    intc_0 // 0
    swap

dynamic_array_concat_byte_length_head_for_header@2:
    frame_dig 3
    frame_dig 2
    <
    bz dynamic_array_concat_byte_length_head_after_for@4
    frame_dig 4
    dup
    itob
    extract 6 2
    frame_dig 1
    frame_dig 3
    dup
    cover 4
    uncover 2
    replace3
    dup
    frame_bury 1
    dig 1
    extract_uint16
    intc_2 // 2
    +
    +
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 3
    b dynamic_array_concat_byte_length_head_for_header@2

dynamic_array_concat_byte_length_head_after_for@4:
    frame_dig 0
    frame_dig 1
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    bytec_0 // ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// tests.artifacts.Arrays.immutable.sum_imm_fixed(arr: bytes) -> uint64:
sum_imm_fixed:
    // tests/artifacts/Arrays/immutable.py:479-480
    // @subroutine
    // def sum_imm_fixed(arr: NativeStruct3) -> UInt64:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:481
    // total = UInt64(0)
    intc_0 // 0
    dup

sum_imm_fixed_for_header@1:
    // tests/artifacts/Arrays/immutable.py:482
    // for item in arr:
    frame_dig 1
    pushint 3 // 3
    <
    bz sum_imm_fixed_after_for@4
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    frame_dig 1
    dup
    pushint 16 // 16
    *
    frame_dig -1
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    dup
    // tests/artifacts/Arrays/immutable.py:482-483
    // for item in arr:
    //     total += item.foo
    intc_0 // 0
    // tests/artifacts/Arrays/immutable.py:483
    // total += item.foo
    extract_uint64
    frame_dig 0
    +
    // tests/artifacts/Arrays/immutable.py:484
    // total += item.bar
    swap
    intc_3 // 8
    extract_uint64
    +
    frame_bury 0
    intc_1 // 1
    +
    frame_bury 1
    b sum_imm_fixed_for_header@1

sum_imm_fixed_after_for@4:
    // tests/artifacts/Arrays/immutable.py:485
    // return total
    retsub


// tests.artifacts.Arrays.immutable.times(n: uint64) -> bytes:
times:
    // tests/artifacts/Arrays/immutable.py:488-489
    // @subroutine
    // def times(n: UInt64) -> String:
    proto 1 1
    // tests/artifacts/Arrays/immutable.py:490
    // result = String()
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    intc_0 // 0

times_for_header@1:
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    frame_dig -1
    <
    bz times_after_for@4
    // tests/artifacts/Arrays/immutable.py:492
    // result += String(" ")
    frame_dig 0
    pushbytes " "
    concat
    frame_bury 0
    // tests/artifacts/Arrays/immutable.py:491
    // for _i in urange(n):
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 1
    b times_for_header@1

times_after_for@4:
    // tests/artifacts/Arrays/immutable.py:493
    // return result
    retsub


// tests.artifacts.Arrays.immutable.add_x(arr: bytes, x: uint64) -> bytes:
add_x:
    // tests/artifacts/Arrays/immutable.py:496-497
    // @subroutine
    // def add_x(arr: ImmutableArray[UInt64], x: UInt64) -> ImmutableArray[UInt64]:
    proto 2 1
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_0 // 0

add_x_for_header@1:
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    frame_dig 0
    frame_dig -1
    <
    bz add_x_after_for@4
    // tests/artifacts/Arrays/immutable.py:499
    // arr = arr.append(i)
    frame_dig 0
    dup
    itob
    frame_dig -2
    swap
    concat // on error: max array length exceeded
    frame_dig -2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    frame_bury -2
    // tests/artifacts/Arrays/immutable.py:498
    // for i in urange(x):
    intc_1 // 1
    +
    frame_bury 0
    b add_x_for_header@1

add_x_after_for@4:
    // tests/artifacts/Arrays/immutable.py:500
    // return arr
    frame_dig -2
    swap
    retsub


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_array[routing]() -> void:
test_uint64_array:
    // tests/artifacts/Arrays/immutable.py:99
    // arr = arr.append(UInt64(42))
    pushbytes 0x0001000000000000002a
    // tests/artifacts/Arrays/immutable.py:103
    // arr = add_x(arr, UInt64(5))
    pushint 5 // 5
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:104
    // assert arr.length == 6
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:105
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:107
    // arr = arr.append(UInt64(43))
    pushint 43 // 43
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:108
    // assert arr.length == 7
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:109
    // assert arr[-1] == 43
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 43 // 43
    ==
    assert
    intc_2 // 2
    // tests/artifacts/Arrays/immutable.py:110
    // assert arr[0] == 42
    extract_uint64
    pushint 42 // 42
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    intc_0 // 0

test_uint64_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    dup
    // tests/artifacts/Arrays/immutable.py:112
    // arr = pop_x(arr, UInt64(3))
    pushint 3 // 3
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    <
    bz test_uint64_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:506
    // arr = arr.pop()
    dig 1
    intc_3 // 8
    callsub dynamic_array_pop_fixed_size
    bury 3
    pop
    // tests/artifacts/Arrays/immutable.py:505
    // for _i in urange(x):
    dup
    intc_1 // 1
    +
    bury 1
    b test_uint64_array_for_header@2

test_uint64_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:113
    // assert arr.length == 4
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:114
    // assert arr[-1] == 2
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    intc_2 // 2
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:116
    // arr = add_x(arr, UInt64(10))
    pushint 10 // 10
    callsub add_x
    // tests/artifacts/Arrays/immutable.py:117
    // assert arr.length == 14
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 14 // 14
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:118
    // assert arr[-1] == 9
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 9 // 9
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:120
    // arr = arr.append(UInt64(44))
    pushint 44 // 44
    itob
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:121
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:122
    // assert arr[-1] == 44
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 8
    *
    extract_uint64
    pushint 44 // 44
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:124
    // arr = arr.replace(2, UInt64(23))
    pushint 23 // 23
    itob
    replace2 18 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:125
    // assert arr.length == 15
    dup
    intc_0 // 0
    extract_uint16
    pushint 15 // 15
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:126
    // assert arr[2] == 23
    dup
    pushint 18 // 18
    extract_uint64
    pushint 23 // 23
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:128
    // self.a = arr
    pushbytes "a"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:94
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_biguint_array[routing]() -> void:
test_biguint_array:
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    txn NumAppArgs
    intc_1 // 1
    -
    itob
    pushint 64 // 64
    bzero
    dup
    cover 2
    b|
    // tests/artifacts/Arrays/immutable.py:132
    // arr = ImmutableArray[BigUInt]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:135
    // arr = arr.append(BigUInt(Txn.num_app_args - 1))
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0001
    replace2 0
    dupn 2
    // tests/artifacts/Arrays/immutable.py:136
    // assert arr.length == 1
    intc_0 // 0
    extract_uint16
    dup
    intc_1 // 1
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:137
    // assert arr[-1] == 0
    intc_1 // 1
    -
    swap
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec_0 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_0 // 0

test_biguint_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    dup
    // tests/artifacts/Arrays/immutable.py:139
    // arr = add_xb(arr, UInt64(5))
    pushint 5 // 5
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    <
    bz test_biguint_array_after_for@4
    // tests/artifacts/Arrays/immutable.py:513
    // arr = arr.append(BigUInt(i))
    dupn 2
    itob
    dig 4
    b|
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:512
    // for i in urange(x):
    intc_1 // 1
    +
    bury 1
    b test_biguint_array_for_header@2

test_biguint_array_after_for@4:
    // tests/artifacts/Arrays/immutable.py:140
    // assert arr.length == 6
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 6 // 6
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:141
    // assert arr[-1] == 4
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0x04
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:143
    // arr = arr.append(BigUInt(2**512 - 1) - Txn.num_app_args)
    txn NumAppArgs
    itob
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    swap
    b-
    dup
    len
    pushint 64 // 64
    <=
    assert // overflow
    dig 5
    b|
    uncover 2
    swap
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:144
    // assert arr.length == 7
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 7 // 7
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:145
    // assert arr[-1] == 2**512 - 2
    dup
    intc_1 // 1
    -
    dig 2
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    pushbytes 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:146
    // assert arr[0] == 0
    dig 1
    extract 2 64
    bytec_0 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:148
    // arr = arr.append(BigUInt(2**512 - 1))
    swap
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    concat // on error: max array length exceeded
    swap
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:149
    // assert arr.length == 8
    dup
    intc_0 // 0
    extract_uint16
    dup
    intc_3 // 8
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:150
    // assert arr[-1] == 2**512 - 1
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    pushint 64 // 64
    *
    pushint 64 // 64
    extract3 // on error: index access is out of bounds
    bytec 5 // 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:151
    // assert arr[0] == 0
    dup
    extract 2 64
    bytec_0 // 0x
    b==
    assert
    // tests/artifacts/Arrays/immutable.py:153
    // Box(ImmutableArray[BigUInt], key=b"biguint").value = arr
    bytec 7 // 0x62696775696e74
    box_del
    pop
    bytec 7 // 0x62696775696e74
    swap
    box_put
    // tests/artifacts/Arrays/immutable.py:130
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_array[routing]() -> void:
test_bool_array:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:157
    // arr = ImmutableArray[bool]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_0 // 0

test_bool_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    dup
    dig 3
    <
    bz test_bool_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:161
    // arr = arr.append(i == Txn.num_app_args)
    txn NumAppArgs
    dig 1
    dup
    uncover 2
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    bury 3
    // tests/artifacts/Arrays/immutable.py:160
    // for i in urange(length):
    intc_1 // 1
    +
    bury 1
    b test_bool_array_for_header@2

test_bool_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:163
    // assert arr.length == length
    dig 1
    intc_0 // 0
    extract_uint16
    dup
    bury 5
    dig 3
    dup
    cover 2
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:165
    // if length > 0:
    bz test_bool_array_after_if_else@7
    // tests/artifacts/Arrays/immutable.py:166
    // assert not arr[0], "expected element 0 to be False"
    dig 3
    assert // index access is out of bounds
    dig 1
    pushint 16 // 16
    getbit
    !
    assert // expected element 0 to be False

test_bool_array_after_if_else@7:
    // tests/artifacts/Arrays/immutable.py:167
    // if length > 1:
    dig 2
    intc_1 // 1
    >
    bz test_bool_array_after_if_else@9
    // tests/artifacts/Arrays/immutable.py:168
    // assert not arr[1], "expected element 1 to be False"
    intc_1 // 1
    dig 4
    <
    assert // index access is out of bounds
    dig 1
    pushint 17 // 17
    getbit
    !
    assert // expected element 1 to be False

test_bool_array_after_if_else@9:
    // tests/artifacts/Arrays/immutable.py:169
    // if length > 2:
    dig 2
    intc_2 // 2
    >
    bz test_bool_array_after_if_else@11
    // tests/artifacts/Arrays/immutable.py:170
    // assert arr[2], "expected element 2 to be True"
    intc_2 // 2
    dig 4
    <
    assert // index access is out of bounds
    dig 1
    pushint 18 // 18
    getbit
    assert // expected element 2 to be True

test_bool_array_after_if_else@11:
    // tests/artifacts/Arrays/immutable.py:171
    // if length > 3:
    dig 2
    pushint 3 // 3
    >
    bz test_bool_array_after_if_else@13
    // tests/artifacts/Arrays/immutable.py:172
    // assert not arr[length - 1], "expected last element to be False"
    dig 2
    intc_1 // 1
    -
    dup
    dig 5
    <
    assert // index access is out of bounds
    pushint 16 // 16
    +
    dig 2
    swap
    getbit
    !
    assert // expected last element to be False

test_bool_array_after_if_else@13:
    // tests/artifacts/Arrays/immutable.py:174
    // self.g = arr
    pushbytes "g"
    dig 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:175
    // if length:
    dig 2
    bz test_bool_array_after_if_else@15
    dig 3
    intc_1 // 1
    -
    dup
    itob
    extract 6 0
    dig 3
    swap
    replace2 0
    dig 1
    pushint 16 // 16
    +
    intc_0 // 0
    setbit
    swap
    pushint 7 // 7
    +
    intc_3 // 8
    /
    intc_2 // 2
    +
    intc_0 // 0
    swap
    substring3
    // tests/artifacts/Arrays/immutable.py:177
    // assert arr.length == length - 1
    intc_0 // 0
    extract_uint16
    dig 3
    intc_1 // 1
    -
    ==
    assert

test_bool_array_after_if_else@15:
    // tests/artifacts/Arrays/immutable.py:155
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_tuple_array[routing]() -> void:
test_fixed_size_tuple_array:
    // tests/artifacts/Arrays/immutable.py:181
    // arr = ImmutableArray[tuple[UInt64, UInt64]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:184
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_fixed_size_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:185
    // arr = arr.append((i + 1, i + 2))
    dupn 2
    intc_1 // 1
    +
    swap
    intc_2 // 2
    +
    dig 1
    itob
    swap
    itob
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    bury 1
    b test_fixed_size_tuple_array_for_header@2

test_fixed_size_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:187
    // assert arr.length == 5
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:188
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:189
    // assert arr[-1] == (UInt64(5), UInt64(6))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 5 // 5
    ==
    swap
    pushint 6 // 6
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:191
    // arr = arr.pop()
    pushint 16 // 16
    callsub dynamic_array_pop_fixed_size
    bury 1
    // tests/artifacts/Arrays/immutable.py:192
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:193
    // assert arr[0] == (UInt64(1), UInt64(2))
    dig 1
    extract 2 0
    dig 2
    extract 2 16
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    intc_1 // 1
    ==
    swap
    intc_2 // 2
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:194
    // assert arr[-1] == (UInt64(4), UInt64(5))
    swap
    intc_1 // 1
    -
    pushint 16 // 16
    *
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    swap
    intc_3 // 8
    extract_uint64
    swap
    pushint 4 // 4
    ==
    swap
    pushint 5 // 5
    ==
    &&
    assert
    // tests/artifacts/Arrays/immutable.py:195
    // self.c = arr
    pushbytes "c"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:179
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_fixed_size_named_tuple_array[routing]() -> void:
test_fixed_size_named_tuple_array:
    // tests/artifacts/Arrays/immutable.py:199
    // arr = ImmutableArray[MyTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_0 // 0

test_fixed_size_named_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_fixed_size_named_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:203
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i * 3 % 2 == 0))
    dupn 2
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    *
    intc_2 // 2
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:202
    // for i in urange(5):
    intc_1 // 1
    +
    bury 1
    b test_fixed_size_named_tuple_array_for_header@2

test_fixed_size_named_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:205
    // assert arr.length == 5
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:206
    // foo, bar, baz = arr[0]
    dup
    extract 2 9
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    // tests/artifacts/Arrays/immutable.py:207
    // assert foo == 0
    uncover 2
    !
    assert
    // tests/artifacts/Arrays/immutable.py:208
    // assert bar
    swap
    assert
    // tests/artifacts/Arrays/immutable.py:209
    // assert baz
    assert
    // tests/artifacts/Arrays/immutable.py:210
    // self.d = arr
    pushbytes "d"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:197
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_tuple_array[routing]() -> void:
test_dynamic_sized_tuple_array:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:214
    // arr = ImmutableArray[tuple[UInt64, Bytes]]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:217
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:218
    // arr = arr.append((i + 1, op.bzero(i)))
    dupn 2
    intc_1 // 1
    +
    swap
    bzero
    dig 3
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 3
    bury 1
    b test_dynamic_sized_tuple_array_for_header@2

test_dynamic_sized_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:220
    // assert arr.length == 5
    dig 1
    intc_0 // 0
    extract_uint16
    dup
    bury 4
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    intc_0 // 0
    bury 1

test_dynamic_sized_tuple_array_for_header@6:
    // tests/artifacts/Arrays/immutable.py:221
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_tuple_array_after_for@9
    // tests/artifacts/Arrays/immutable.py:222
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    dig 1
    extract 2 0
    dig 1
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    dig 6
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:223
    // assert arr[i][1].length == i, "expected 2nd element to be correct"
    len
    uncover 2
    ==
    assert // expected 2nd element to be correct
    bury 1
    b test_dynamic_sized_tuple_array_for_header@6

test_dynamic_sized_tuple_array_after_for@9:
    // tests/artifacts/Arrays/immutable.py:225
    // arr = arr.pop()
    dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:226
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:227
    // assert arr[0] == (UInt64(1), op.bzero(0)), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    intc_0 // 0
    bzero
    uncover 2
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:228
    // assert arr[-1] == (UInt64(4), op.bzero(3)), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    pushint 3 // 3
    bzero
    uncover 2
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:229
    // self.e = arr
    pushbytes "e"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:212
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_sized_named_tuple_array[routing]() -> void:
test_dynamic_sized_named_tuple_array:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:233
    // arr = ImmutableArray[MyDynamicSizedTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    intc_0 // 0

test_dynamic_sized_named_tuple_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:236
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@5
    // tests/artifacts/Arrays/immutable.py:237
    // arr = arr.append(MyDynamicSizedTuple(foo=i + 1, bar=times(i)))
    dupn 2
    intc_1 // 1
    +
    swap
    callsub times
    dig 3
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 3
    bury 1
    b test_dynamic_sized_named_tuple_array_for_header@2

test_dynamic_sized_named_tuple_array_after_for@5:
    // tests/artifacts/Arrays/immutable.py:239
    // assert arr.length == 5
    dig 1
    intc_0 // 0
    extract_uint16
    dup
    bury 4
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    intc_0 // 0
    bury 1

test_dynamic_sized_named_tuple_array_for_header@6:
    // tests/artifacts/Arrays/immutable.py:240
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_dynamic_sized_named_tuple_array_after_for@9
    // tests/artifacts/Arrays/immutable.py:241
    // assert arr[i][0] == i + 1, "expected 1st element to be correct"
    dig 1
    extract 2 0
    dig 1
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    dig 6
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    dig 2
    ==
    assert // expected 1st element to be correct
    // tests/artifacts/Arrays/immutable.py:242
    // assert arr[i][1] == times(i), "expected 2nd element to be correct"
    uncover 2
    callsub times
    ==
    assert // expected 2nd element to be correct
    bury 1
    b test_dynamic_sized_named_tuple_array_for_header@6

test_dynamic_sized_named_tuple_array_after_for@9:
    // tests/artifacts/Arrays/immutable.py:244
    // arr = arr.pop()
    dig 1
    callsub dynamic_array_pop_dynamic_element
    bury 1
    // tests/artifacts/Arrays/immutable.py:245
    // assert arr.length == 4
    dup
    intc_0 // 0
    extract_uint16
    dup
    pushint 4 // 4
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:246
    // assert arr[0] == MyDynamicSizedTuple(UInt64(1), String()), "expected 1, 0"
    dig 1
    extract 2 0
    dup
    intc_0 // 0
    extract_uint16
    dig 2
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 2
    len
    dig 3
    intc_2 // 2
    extract_uint16
    dig 1
    swap
    dig 3
    select
    dig 4
    uncover 4
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    intc_1 // 1
    ==
    swap
    bytec_0 // ""
    ==
    &&
    assert // expected 1, 0
    // tests/artifacts/Arrays/immutable.py:247
    // assert arr[-1] == MyDynamicSizedTuple(UInt64(4), String("   ")), "expected 4, 3"
    dig 1
    intc_2 // 2
    *
    dig 3
    swap
    extract_uint16
    uncover 2
    intc_1 // 1
    +
    uncover 4
    dig 1
    - // on error: index access is out of bounds
    swap
    intc_2 // 2
    *
    dig 4
    swap
    extract_uint16
    uncover 3
    swap
    uncover 2
    select
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    swap
    pushint 4 // 4
    ==
    swap
    pushbytes "   "
    ==
    &&
    assert // expected 4, 3
    // tests/artifacts/Arrays/immutable.py:248
    // self.f = arr
    pushbytes "f"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:231
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_log[routing]() -> void:
test_implicit_conversion_log:
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:252
    // log(arr)
    log
    // tests/artifacts/Arrays/immutable.py:250
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_implicit_conversion_emit[routing]() -> void:
test_implicit_conversion_emit:
    // tests/artifacts/Arrays/immutable.py:256
    // arc4.emit("emit_test", arr)
    pushbytes 0xfa40c0530002
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:256
    // arc4.emit("emit_test", arr)
    concat
    log
    // tests/artifacts/Arrays/immutable.py:254
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_nested_array[routing]() -> void:
test_nested_array:
    intc_0 // 0
    dupn 2
    bytec_0 // ""
    dupn 5
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    intc_0 // 0

test_nested_array_for_header@2:
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    dup
    dig 3
    <
    bz test_nested_array_after_for@9
    // tests/artifacts/Arrays/immutable.py:264
    // extra_arr = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    bury 12
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_0 // 0
    bury 5

test_nested_array_for_header@4:
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    dig 4
    dig 1
    <
    bz test_nested_array_after_for@7
    // tests/artifacts/Arrays/immutable.py:266
    // extra_arr = extra_arr.append(j)
    dig 4
    dup
    itob
    dig 13
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 13
    // tests/artifacts/Arrays/immutable.py:265
    // for j in urange(i):
    intc_1 // 1
    +
    bury 5
    b test_nested_array_for_header@4

test_nested_array_after_for@7:
    // tests/artifacts/Arrays/immutable.py:267
    // arr = arr.append(extra_arr)
    dig 1
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    bytec 4 // 0x0002
    dig 14
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 2
    // tests/artifacts/Arrays/immutable.py:262-263
    // # add n new arrays
    // for i in urange(arr_to_add):
    dup
    intc_1 // 1
    +
    bury 1
    b test_nested_array_for_header@2

test_nested_array_after_for@9:
    // tests/artifacts/Arrays/immutable.py:269-270
    // # sum inner arrays and return an array containing sums
    // totals = ImmutableArray[UInt64]()
    bytec_2 // 0x0000
    bury 10
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    dig 1
    intc_0 // 0
    extract_uint16
    bury 9
    intc_0 // 0
    bury 7

test_nested_array_for_header@10:
    // tests/artifacts/Arrays/immutable.py:271
    // for inner_arr in arr:
    dig 6
    dig 9
    <
    bz test_nested_array_after_for@13
    dig 1
    extract 2 0
    dig 7
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dup2
    extract_uint16
    intc_3 // 8
    *
    intc_2 // 2
    +
    extract3
    dup
    bury 12
    // tests/artifacts/Arrays/immutable.py:519
    // total = UInt64()
    intc_0 // 0
    bury 5
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    intc_0 // 0
    extract_uint16
    bury 8
    intc_0 // 0
    bury 6

test_nested_array_for_header@15:
    // tests/artifacts/Arrays/immutable.py:520
    // for i in arr:
    dig 5
    dig 8
    <
    bz test_nested_array_after_for@17
    dig 10
    extract 2 0
    dig 6
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:521
    // total += i
    dig 5
    +
    bury 5
    intc_1 // 1
    +
    bury 6
    b test_nested_array_for_header@15

test_nested_array_after_for@17:
    // tests/artifacts/Arrays/immutable.py:272
    // totals = totals.append(sum_arr(inner_arr))
    dig 3
    itob
    dig 10
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 10
    dig 6
    intc_1 // 1
    +
    bury 7
    b test_nested_array_for_header@10

test_nested_array_after_for@13:
    // tests/artifacts/Arrays/immutable.py:258
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 10
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bit_packed_tuples[routing]() -> void:
test_bit_packed_tuples:
    // tests/artifacts/Arrays/immutable.py:278
    // arr2 = ImmutableArray[TwoBoolTuple]()
    bytec_2 // 0x0000
    // tests/artifacts/Arrays/immutable.py:279-281
    // arr7 = ImmutableArray[SevenBoolTuple]()
    // arr8 = ImmutableArray[EightBoolTuple]()
    // arr9 = ImmutableArray[NineBoolTuple]()
    dupn 3
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    intc_0 // 0

test_bit_packed_tuples_for_header@2:
    // tests/artifacts/Arrays/immutable.py:287
    // for i in urange(5):
    dup
    pushint 5 // 5
    <
    bz test_bit_packed_tuples_after_for@5
    // tests/artifacts/Arrays/immutable.py:288
    // arr2 = arr2.append(TwoBoolTuple(a=i == 0, b=i == 1))
    dupn 2
    !
    dig 1
    intc_1 // 1
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    intc_1 // 1
    uncover 2
    setbit
    dig 6
    dup
    cover 2
    dig 1
    concat // on error: max array length exceeded
    uncover 2
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 7
    // tests/artifacts/Arrays/immutable.py:295
    // c=i == 2,
    dig 1
    intc_2 // 2
    ==
    // tests/artifacts/Arrays/immutable.py:296
    // d=i == 3,
    dig 2
    pushint 3 // 3
    ==
    // tests/artifacts/Arrays/immutable.py:297
    // e=i == 4,
    dig 3
    pushint 4 // 4
    ==
    // tests/artifacts/Arrays/immutable.py:298
    // f=i == 5,
    dig 4
    pushint 5 // 5
    ==
    // tests/artifacts/Arrays/immutable.py:299
    // g=i == 6,
    dig 5
    pushint 6 // 6
    ==
    // tests/artifacts/Arrays/immutable.py:292
    // bar=i + 1,
    dig 6
    intc_1 // 1
    +
    // tests/artifacts/Arrays/immutable.py:289-301
    // arr7 = arr7.append(
    //     SevenBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //     )
    // )
    dig 7
    itob
    uncover 7
    intc_2 // 2
    uncover 8
    setbit
    pushint 3 // 3
    uncover 7
    setbit
    pushint 4 // 4
    uncover 6
    setbit
    pushint 5 // 5
    uncover 5
    setbit
    pushint 6 // 6
    uncover 4
    setbit
    dup2
    concat
    dig 3
    itob
    swap
    dig 1
    concat
    dig 9
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 9
    // tests/artifacts/Arrays/immutable.py:313
    // h=i == 7,
    dig 4
    pushint 7 // 7
    ==
    // tests/artifacts/Arrays/immutable.py:302-315
    // arr8 = arr8.append(
    //     EightBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //     )
    // )
    uncover 2
    pushint 7 // 7
    uncover 2
    setbit
    uncover 2
    swap
    concat
    dup
    dig 2
    concat
    dig 7
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 7
    // tests/artifacts/Arrays/immutable.py:328
    // i=i == 8,
    uncover 3
    intc_3 // 8
    ==
    // tests/artifacts/Arrays/immutable.py:316-330
    // arr9 = arr9.append(
    //     NineBoolTuple(
    //         foo=i,
    //         bar=i + 1,
    //         a=i == 0,
    //         b=i == 1,
    //         c=i == 2,
    //         d=i == 3,
    //         e=i == 4,
    //         f=i == 5,
    //         g=i == 6,
    //         h=i == 7,
    //         i=i == 8,
    //     )
    // )
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat
    swap
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    bury 1
    b test_bit_packed_tuples_for_header@2

test_bit_packed_tuples_after_for@5:
    // tests/artifacts/Arrays/immutable.py:332
    // assert arr2.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:333
    // assert arr7.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:334
    // assert arr8.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:335
    // assert arr9.length == 5
    dig 4
    dup
    intc_0 // 0
    extract_uint16
    pushint 5 // 5
    ==
    assert
    // tests/artifacts/Arrays/immutable.py:336
    // self.bool2 = arr2
    pushbytes "bool2"
    uncover 4
    app_global_put
    // tests/artifacts/Arrays/immutable.py:337
    // self.bool7 = arr7
    pushbytes "bool7"
    uncover 3
    app_global_put
    // tests/artifacts/Arrays/immutable.py:338
    // self.bool8 = arr8
    pushbytes "bool8"
    uncover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:339
    // self.bool9 = arr9
    pushbytes "bool9"
    swap
    app_global_put
    // tests/artifacts/Arrays/immutable.py:276
    // @arc4.abimethod()
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.sum_uints_and_lengths_and_trues[routing]() -> void:
sum_uints_and_lengths_and_trues:
    bytec_0 // ""
    dupn 6
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    // tests/artifacts/Arrays/immutable.py:349
    // sum1 = sum2 = sum3 = sum4 = UInt64()
    intc_0 // 0
    dupn 3
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    intc_0 // 0
    extract_uint16
    intc_0 // 0

sum_uints_and_lengths_and_trues_for_header@2:
    // tests/artifacts/Arrays/immutable.py:350
    // for i in arr1:
    dup
    dig 2
    <
    bz sum_uints_and_lengths_and_trues_after_for@5
    dig 9
    extract 2 0
    dig 1
    dup
    cover 2
    intc_3 // 8
    *
    extract_uint64
    // tests/artifacts/Arrays/immutable.py:351
    // sum1 += i
    dig 4
    +
    bury 4
    intc_1 // 1
    +
    bury 1
    b sum_uints_and_lengths_and_trues_for_header@2

sum_uints_and_lengths_and_trues_after_for@5:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    dig 8
    intc_0 // 0
    extract_uint16
    bury 17
    intc_0 // 0
    bury 13

sum_uints_and_lengths_and_trues_for_header@6:
    // tests/artifacts/Arrays/immutable.py:352
    // for b in arr2:
    dig 12
    dig 17
    <
    bz sum_uints_and_lengths_and_trues_after_for@11
    dig 12
    pushint 16 // 16
    +
    dig 9
    swap
    getbit
    // tests/artifacts/Arrays/immutable.py:353
    // if b:
    bz sum_uints_and_lengths_and_trues_after_if_else@9
    // tests/artifacts/Arrays/immutable.py:354
    // sum2 += 1
    dig 3
    intc_1 // 1
    +
    bury 4

sum_uints_and_lengths_and_trues_after_if_else@9:
    dig 12
    intc_1 // 1
    +
    bury 13
    b sum_uints_and_lengths_and_trues_for_header@6

sum_uints_and_lengths_and_trues_after_for@11:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    dig 7
    intc_0 // 0
    extract_uint16
    bury 16
    intc_0 // 0
    bury 12

sum_uints_and_lengths_and_trues_for_header@12:
    // tests/artifacts/Arrays/immutable.py:355
    // for tup in arr3:
    dig 11
    dig 16
    <
    bz sum_uints_and_lengths_and_trues_after_for@19
    dig 7
    extract 2 0
    dig 12
    pushint 9 // 9
    *
    pushint 9 // 9
    extract3 // on error: index access is out of bounds
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 64 // 64
    getbit
    uncover 2
    pushint 65 // 65
    getbit
    bury 13
    // tests/artifacts/Arrays/immutable.py:356
    // sum3 += tup.foo
    dig 6
    uncover 2
    +
    bury 6
    // tests/artifacts/Arrays/immutable.py:357
    // if tup.bar:
    bz sum_uints_and_lengths_and_trues_after_if_else@15
    // tests/artifacts/Arrays/immutable.py:358
    // sum3 += 1
    dig 4
    intc_1 // 1
    +
    bury 5

sum_uints_and_lengths_and_trues_after_if_else@15:
    // tests/artifacts/Arrays/immutable.py:359
    // if tup.baz:
    dig 10
    bz sum_uints_and_lengths_and_trues_after_if_else@17
    // tests/artifacts/Arrays/immutable.py:360
    // sum3 += 1
    dig 4
    intc_1 // 1
    +
    bury 5

sum_uints_and_lengths_and_trues_after_if_else@17:
    dig 11
    intc_1 // 1
    +
    bury 12
    b sum_uints_and_lengths_and_trues_for_header@12

sum_uints_and_lengths_and_trues_after_for@19:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    dig 6
    intc_0 // 0
    extract_uint16
    bury 15
    intc_0 // 0
    bury 14

sum_uints_and_lengths_and_trues_for_header@20:
    // tests/artifacts/Arrays/immutable.py:361
    // for idx, dyn_tup in uenumerate(arr4):
    dig 13
    dig 15
    <
    bz sum_uints_and_lengths_and_trues_after_for@23
    dig 6
    extract 2 0
    dig 14
    dup
    cover 2
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    dig 2
    intc_1 // 1
    +
    dig 18
    dig 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 2
    intc_2 // 2
    *
    dig 5
    swap
    extract_uint16
    uncover 2
    select
    uncover 3
    uncover 3
    uncover 2
    substring3
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    intc_3 // 8
    extract_uint16
    dig 2
    len
    uncover 3
    cover 2
    substring3
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:362
    // sum4 += dyn_tup.foo
    dig 9
    uncover 2
    +
    // tests/artifacts/Arrays/immutable.py:363
    // sum4 += dyn_tup.bar.bytes.length
    swap
    len
    swap
    dig 1
    +
    bury 9
    // tests/artifacts/Arrays/immutable.py:364
    // assert dyn_tup.bar.bytes.length == idx, "expected string length to match index"
    uncover 2
    ==
    assert // expected string length to match index
    bury 14
    b sum_uints_and_lengths_and_trues_for_header@20

sum_uints_and_lengths_and_trues_after_for@23:
    // tests/artifacts/Arrays/immutable.py:341
    // @arc4.abimethod()
    dig 2
    itob
    dig 4
    itob
    concat
    dig 5
    itob
    concat
    dig 6
    itob
    concat
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_uint64_return[routing]() -> void:
test_uint64_return:
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:370
    // arr = ImmutableArray(UInt64(1), UInt64(2), UInt64(3))
    pushbytes 0x0003000000000000000100000000000000020000000000000003
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_0 // 0

test_uint64_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_uint64_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:372
    // arr = arr.append(i)
    dupn 2
    itob
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:371
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_uint64_return_for_header@2

test_uint64_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:368
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_bool_return[routing]() -> void:
test_bool_return:
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:377
    // arr = ImmutableArray(True, False, True, False, True)
    pushbytes 0x0005a8
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_0 // 0

test_bool_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_bool_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:379
    // arr = arr.append(i % 2 == 0)
    dupn 2
    intc_2 // 2
    %
    !
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    swap
    intc_1 // 1
    intc_3 // 8
    callsub dynamic_array_concat_bits
    bury 3
    // tests/artifacts/Arrays/immutable.py:378
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_bool_return_for_header@2

test_bool_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:375
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_tuple_return[routing]() -> void:
test_tuple_return:
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:384
    // arr = ImmutableArray(MyTuple(UInt64(), True, False))
    pushbytes 0x0001000000000000000080
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_0 // 0

test_tuple_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_tuple_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:386
    // arr = arr.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    dupn 2
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    dig 3
    dup
    uncover 2
    concat // on error: max array length exceeded
    swap
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    +
    itob
    extract 6 2
    replace2 0
    bury 3
    // tests/artifacts/Arrays/immutable.py:385
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_tuple_return_for_header@2

test_tuple_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:382
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_tuple_return[routing]() -> void:
test_dynamic_tuple_return:
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/immutable.py:391
    // arr = ImmutableArray(MyDynamicSizedTuple(UInt64(), String("Hello")))
    pushbytes 0x000100020000000000000000000a000548656c6c6f
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_0 // 0

test_dynamic_tuple_return_for_header@2:
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_dynamic_tuple_return_after_for@5
    // tests/artifacts/Arrays/immutable.py:393
    // arr = arr.append(MyDynamicSizedTuple(i, times(i)))
    dupn 2
    callsub times
    dig 3
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    dig 3
    itob
    dig 3
    len
    itob
    extract 6 2
    uncover 4
    concat
    swap
    bytec 6 // 0x000a
    concat
    swap
    concat
    bytec 4 // 0x0002
    swap
    concat
    cover 2
    intc_1 // 1
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    bury 3
    // tests/artifacts/Arrays/immutable.py:392
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_dynamic_tuple_return_for_header@2

test_dynamic_tuple_return_after_for@5:
    // tests/artifacts/Arrays/immutable.py:389
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    dig 2
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_convert_to_array_and_back[routing]() -> void:
test_convert_to_array_and_back:
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    swap
    // tests/artifacts/Arrays/immutable.py:401
    // mutable.extend(arr)
    extract 2 0
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_0 // 0

test_convert_to_array_and_back_for_header@2:
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    dup
    dig 3
    <
    bz test_convert_to_array_and_back_after_for@5
    // tests/artifacts/Arrays/immutable.py:403
    // mutable.append(MyTuple(foo=i, bar=i % 2 == 0, baz=i % 3 == 0))
    dupn 2
    intc_2 // 2
    %
    !
    dig 1
    pushint 3 // 3
    %
    !
    dig 4
    cover 3
    dig 2
    itob
    bytec_3 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    intc_1 // 1
    uncover 3
    setbit
    concat
    uncover 2
    swap
    concat // on error: max array length exceeded
    bury 3
    // tests/artifacts/Arrays/immutable.py:402
    // for i in urange(append):
    intc_1 // 1
    +
    bury 1
    b test_convert_to_array_and_back_for_header@2

test_convert_to_array_and_back_after_for@5:
    dig 1
    // tests/artifacts/Arrays/immutable.py:404
    // return mutable.freeze()
    dup
    len
    pushint 9 // 9
    /
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arrays/immutable.py:396
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_arc4_tuple[routing]() -> void:
test_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:410
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:411
    // result = prefix + arg
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_3 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/immutable.py:406
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_with_native_tuple[routing]() -> void:
test_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    extract 0 8
    swap
    extract 8 8
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    concat
    // tests/artifacts/Arrays/immutable.py:418
    // prefix = ImmutableArray(arc4.UInt64(1), arc4.UInt64(2))
    bytec 8 // 0x000200000000000000010000000000000002
    // tests/artifacts/Arrays/immutable.py:419
    // result = prefix + arg
    swap
    concat // on error: max array length exceeded
    pushbytes 0x0004
    replace2 0
    // tests/artifacts/Arrays/immutable.py:414
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_arc4_tuple[routing]() -> void:
test_dynamic_concat_with_arc4_tuple:
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    extract 4 0
    // tests/artifacts/Arrays/immutable.py:426
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:427
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:422
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_dynamic_concat_with_native_tuple[routing]() -> void:
test_dynamic_concat_with_native_tuple:
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    intc_0 // 0
    extract_uint16
    dig 1
    intc_2 // 2
    extract_uint16
    dig 2
    uncover 2
    dig 2
    substring3
    dig 2
    len
    uncover 3
    uncover 3
    uncover 2
    substring3
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    concat
    // tests/artifacts/Arrays/immutable.py:434
    // prefix = ImmutableArray(arc4.String("a"), arc4.String("b"))
    bytec 9 // 0x000200040007000161000162
    // tests/artifacts/Arrays/immutable.py:435
    // result = prefix + arg
    swap
    intc_2 // 2
    callsub dynamic_array_concat_byte_length_head
    // tests/artifacts/Arrays/immutable.py:430
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_concat_immutable_dynamic[routing]() -> void:
test_concat_immutable_dynamic:
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // tests/artifacts/Arrays/immutable.py:442
    // return imm1 + imm2
    dig 1
    intc_0 // 0
    extract_uint16
    uncover 2
    extract 2 0
    dig 2
    extract 2 0
    uncover 3
    intc_0 // 0
    extract_uint16
    uncover 3
    uncover 3
    uncover 2
    uncover 3
    callsub dynamic_array_concat_dynamic_element
    // tests/artifacts/Arrays/immutable.py:438
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_immutable_arc4[routing]() -> void:
test_immutable_arc4:
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/immutable.py:446
    // assert imm, "expected non empty array"
    dup
    intc_0 // 0
    extract_uint16
    dup
    assert // expected non empty array
    // tests/artifacts/Arrays/immutable.py:447
    // imm = imm.replace(imm.length - 1, imm[0])
    intc_1 // 1
    -
    dig 1
    extract 2 16
    swap
    pushint 16 // 16
    *
    intc_2 // 2
    +
    swap
    replace3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:444
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.immutable.ImmutableArrayContract.test_imm_fixed_arr[routing]() -> void:
test_imm_fixed_arr:
    bytec_0 // ""
    // tests/artifacts/Arrays/immutable.py:452
    // arr1 = zero_bytes(NativeStruct3)
    pushint 48 // 48
    bzero
    dup
    // tests/artifacts/Arrays/immutable.py:453
    // struct12 = NativeStruct(Txn.num_app_args + 1, Txn.num_app_args + 2)
    txn NumAppArgs
    intc_1 // 1
    +
    txn NumAppArgs
    intc_2 // 2
    +
    swap
    itob
    swap
    itob
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:454
    // arr2 = NativeStruct3((struct12, struct12, struct12))
    dup
    dig 1
    concat
    swap
    concat
    dup
    cover 2
    // tests/artifacts/Arrays/immutable.py:456
    // assert arr1 != arr2, "expected arrays to be different"
    !=
    assert // expected arrays to be different
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_0 // 0

test_imm_fixed_arr_for_header@2:
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    dup
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@5
    // tests/artifacts/Arrays/immutable.py:460
    // arr1 = arr1.replace(i, struct12)
    dupn 2
    pushint 16 // 16
    *
    dig 5
    swap
    dig 5
    replace3 // on error: index access is out of bounds
    bury 5
    // tests/artifacts/Arrays/immutable.py:459
    // for i in urange(3):
    intc_1 // 1
    +
    bury 1
    b test_imm_fixed_arr_for_header@2

test_imm_fixed_arr_after_for@5:
    // tests/artifacts/Arrays/immutable.py:462
    // assert arr1 == arr2, "expected arrays to be the same"
    dig 3
    dig 2
    ==
    assert // expected arrays to be the same
    intc_0 // 0
    bury 5

test_imm_fixed_arr_for_header@6:
    // tests/artifacts/Arrays/immutable.py:464
    // for struct_it in arr1:
    dig 4
    pushint 3 // 3
    <
    bz test_imm_fixed_arr_after_for@9
    dig 4
    dup
    pushint 16 // 16
    *
    dig 5
    swap
    pushint 16 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:465
    // assert struct_it == struct12, "expected items on iteration to be the same"
    dig 4
    ==
    assert // expected items on iteration to be the same
    intc_1 // 1
    +
    bury 5
    b test_imm_fixed_arr_for_header@6

test_imm_fixed_arr_after_for@9:
    // tests/artifacts/Arrays/immutable.py:467
    // self.imm_fixed_arr = arr1
    bytec 10 // "imm_fixed_arr"
    dig 4
    dup
    cover 2
    app_global_put
    // tests/artifacts/Arrays/immutable.py:471
    // assert sum_imm_fixed(mut_arr.freeze()) == 15, "expected sum to be 15"
    dup
    callsub sum_imm_fixed
    pushint 15 // 15
    ==
    assert // expected sum to be 15
    // tests/artifacts/Arrays/immutable.py:473
    // mut_arr[0] = NativeStruct(UInt64(), UInt64())
    pushbytes 0x00000000000000000000000000000000
    replace2 0 // on error: index access is out of bounds
    // tests/artifacts/Arrays/immutable.py:474
    // assert sum_imm_fixed(mut_arr.freeze()) == 10, "expected sum to be 10"
    callsub sum_imm_fixed
    pushint 10 // 10
    ==
    assert // expected sum to be 10
    // tests/artifacts/Arrays/immutable.py:476
    // return self.imm_fixed_arr
    intc_0 // 0
    bytec 10 // "imm_fixed_arr"
    app_global_get_ex
    assert // check self.imm_fixed_arr exists
    // tests/artifacts/Arrays/immutable.py:450
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAEAAECCCYLBBUffHUAAgAAAQACAAJA/////////////////////////////////////////////////////////////////////////////////////wIACgdiaWd1aW50EgACAAAAAAAAAAEAAAAAAAAAAgwAAgAEAAcAAWEAAWINaW1tX2ZpeGVkX2FycjEbQQKAghgERNQvmQS36qYLBHQ9cO0EHH4ElASi1YYLBOBfxWQEHgkrgwQBMQJiBMhlSpgEidGW+ARst8mRBJiYvwIE9rYe6ARguGp7BHOtKD8EUp366QQgbVFPBOBkZeIE7AMAogTs3xSvBFEaymQEKYUuTwRtSqNYBLfLlr02GgCOGAHFAbkBqQGdAZEBhQF5AWoBWwFEATgBDgD6AOYA0gC+AKcAlAB5AGYAOwAlABIAAiJDMRkURDEYRIgP0yhMULAjQzEZFEQxGEQ2GgGID6AoTFCwI0MxGRREMRhENhoBNhoCiA9xKExQsCNDMRkURDEYRDYaAUkiWUsBJFlLAk8CSwJSSwIVTwNPA08CUogPNihMULAjQzEZFEQxGEQ2GgGIDw4oTFCwI0MxGRREMRhENhoBSVcACExXCAiIDuAoTFCwI0MxGRREMRhENhoBiA63KExQsCNDMRkURDEYRDYaATYaAheIDlUoTFCwI0MxGRREMRhENhoBF4gN5ihMULAjQzEZFEQxGEQ2GgEXiA2FKExQsCNDMRkURDEYRDYaAReIDUMoTFCwI0MxGRREMRhENhoBF4gM6ChMULAjQzEZFEQxGEQ2GgE2GgI2GgM2GgSIC5JPAxZPAxZQTwIWUEwWUChMULAjQzEZFEQxGESIClIjQzEZFEQxGEQ2GgEXNhoCiAlmKExQsCNDMRkURDEYRDYaAYgJQyNDMRkURDEYRDYaAYgJLSNDMRkURDEYRIgH5yNDMRkURDEYRIgGpCNDMRkURDEYRIgGLyNDMRkURDEYRIgFbyNDMRkURDEYRDYaAReIBKYjQzEZFEQxGESIA2wjQzEZFEQxGESIAnUjQzEZQP4qMRgURCNDigICi/4iWSMJFlcGAIv+TFwASRWL/wlKi/9YTwIiTwNSiYoBAov/IlkjCUkkC0mL/1cCAElOAklPAllJTwJJFUxOAlIpIosGiwEMQQAbiwKLBklOAlkkCRZXBgKLBUxQjAUkCIwGQv/diwAWVwYCiwVQiwEkCIsCTIsDUlCLBIwAjAGJigQBKUcCi/wiWUcCi/4ISRZXBgCL/ExcAElPAk8DgQcIJQpJTgNMgQcIJQpJTgMMQQAMiwaLBQmviwRMUIwHiweMBCKMAIsDgRAISYwCi/4IjAGLAosBDEEAIIv9iwBJTgJTiwSLAklOA08CVIwEIwiMAov/CIwAQv/YiwSMAImKAwGL/SJZSYv/CEwkCyQISwEWVwYCTgKL/SRLAlKL/yQLr1CL/RWL/U8DTwJSUIv+UEwkC0kiTIsDiwIMQQAjiwRJFlcGAosBiwNJTgRPAl1JjAFLAVkkCAiMBCQIjANC/9WLAIsBUIwAiYoEASlJi/4kC4v8JAsiiwSLAwxBAByL/YsESU4CWYsCCBZXBgKLAUxQjAEkCIwEQv/ci/0VjAAijASLBIsCDEEAHIv/iwRJTgJZiwAIFlcGAosBTFCMASQIjARC/9yL/Iv+CBZXBgKLAVCL/YsDiwBSUIv/FYv/iwJPAlJQjACJigEBIkmLAYEDDEEAH4sBSYEQC4v/TIEQWEkiW4sACEwlWwiMACMIjAFC/9mJigEBKSKLAYv/DEEAEYsAgAEgUIwAiwEjCIwBQv/niYoCASKLAIv/DEEAHYsASRaL/kxQi/4iWSMIFlcGAlwAjP4jCIwAQv/bi/5MiYoAAIAKAAEAAAAAAAAAKoEFiP+/SSJZSYEGEkRJIwlLAlcCAEwlC1uBBBJEgSsWTwJMUEwjCBZXBgJcAEcCIllJgQcSRCMJSwFXAgBMJQtbgSsSRCRbgSoSRCKLAYEDDEEAEosAJYj9L4wASIsBIwiMAUL/5osASSJZSYEEEkQjCUsBVwIATCULWyQSRIEKiP9BSSJZSYEOEkRJIwlLAlcCAEwlC1uBCRJEgSwWTwJMUEwjCBZXBgJcAEkiWUmBDxJEIwlLAVcCAEwlC1uBLBJEgRcWXBJJIlmBDxJESYESW4EXEkSAAWFMZ4mKAAAxGyMJFoFAr0lOAqsqTFCAAgABXABHAiJZSSMSRCMJTFcCAEyBQAuBQFgpqEQiiwKBBQxBACGLAkkWiwCriwFJTwJQTCJZIwgWVwYCXACMASMIjAJC/9eLAUkiWUmBBhJESSMJSwJXAgBMgUALgUBYgAEEqEQxGxYnBUyhSRWBQA5EiwCrTwJMUEwjCBZXBgJcAEkiWUmBBxJESSMJSwJXAgBMgUALgUBYgED////////////////////////////////////////////////////////////////////////////////////+qERLAVcCQCmoREwnBVBMIwgWVwYCXABJIllJJRJEIwlLAVcCAEyBQAuBQFgnBahESVcCQCmoRCcHvEgnB0y/iYoBACkqIosCi/8MQQAeMRuLAklPAhIrIk8CVIsBTCMliPvgjAEjCIwCQv/aiwEiWUmMAIv/EkSL/0EACosARIsBgRBTFESL/yMNQQAMI4sADESLAYERUxREi/8kDUEACySLAAxEiwGBElNEi/+BAw1BABKL/yMJSYsADESBEAiLAUxTFESAAWeLAWeL/0EAKIsAIwlJFlcGAIsBTFwASwGBEAgiVEyBBwglCiQIIkxSIlmL/yMJEkSJigAAKiKLAYEFDEEAJosBSSMITCQISwEWTBZQiwBJTwJQTCJZIwgWVwYCXACMAIwBQv/SiwBJIllJgQUSREsBVwIASwJXAhBJIltMJVtMIxJMJBIQREwjCYEQC4EQWEkiW0wlW0yBBRJMgQYSEESBEIj6U0UBSSJZSYEEEkRLAVcCAEsCVwIQSSJbTCVbTCMSTCQSEERMIwmBEAuBEFhJIltMJVtMgQQSTIEFEhBEgAFjTGeJigAAKiKLAYEFDEEANYsBSSQYFEsBgQMLJBgUSwIWKyJPBFQjTwNUUIsASU8CUEwiWSMIFlcGAlwAjAAjCIwBQv/DiwBJIlmBBRJESVcCCUkiW0sBgUBTTwKBQVNPAhRETEREgAFkTGeJigAAKSoiiwKBBQxBADaLAkkjCEyviwFJIllMVwIASwMWSwMVFlcGAk8EUEwnBlBMUCcETFBOAiNPA4j624wBjAJC/8KLASJZSYwAgQUSRCKMAosCgQUMQQBPiwFXAgCLAklOAiQLSwFMWUsCIwiLAEsBCUsDFUsCJAtLBUxZTwJNTwNPA08CUkkiW0sBJVlLAhVPA04CUlcCAExLAhJEFU8CEkSMAkL/qYsBiPkdRQFJIllJgQQSREsBVwIASSJZSwIjCUsCFUsDJFlLAUxLA01LBE8ETwJSSSJbSwElWUsCFU8DTgJSVwIATCMSIq9PAhIQREsBJAtLA0xZTwIjCE8ESwEJTCQLSwRMWU8DTE8CTVJJIltLASVZSwIVTwNOAlJXAgBMgQQSgQOvTwISEESAAWVMZ4mKAAApKiKLAoEFDEEAOIsCSSMITIj6d4sBSSJZTFcCAEsDFksDFRZXBgJPBFBMJwZQTFAnBExQTgIjTwOI+aKMAYwCQv/AiwEiWUmMAIEFEkQijAKLAoEFDEEAUYsBVwIAiwJJTgIkC0sBTFlLAiMIiwBLAQlLAxVLAiQLSwVMWU8CTU8DTwNPAlJJIltLASVZSwIVTwNOAlJXAgBMSwISRE8CiPnoEkSMAkL/p4sBiPfiRQFJIllJgQQSREsBVwIASSJZSwIjCUsCFUsDJFlLAUxLA01LBE8ETwJSSSJbSwElWUsCFU8DTgJSVwIATCMSTCkSEERLASQLSwNMWU8CIwhPBEsBCUwkC0sETFlPA0xPAk1SSSJbSwElWUsCFU8DTgJSVwIATIEEEkyAAyAgIBIQRIABZkxniYoBAIv/sImKAQCABvpAwFMAAov/ULCJigIBIkcCKUcFIosJi/4MQQBNKowAIowHiweLCQxBAB6LB0kWiwBJTwJQTCJZIwgWVwYCXACMACMIjAdC/9qL/yJZi/9XAgAnBIsAUE4CI08DiPg8jP+LCSMIjAlC/6sqjAKL/yJZjAMijAWLBYsDDEEAYYv/VwIAiwUkC0sBTFlKWSULJAhYSYwBIowIIlmMBCKMBosGiwQMQQAZiwFXAgCLBklOAiULW4sICIwIIwiMBkL/34sIFosCSU8CUEwiWSMIFlcGAlwAjAKLBSMIjAVC/5eLAowAiYoAACpHAyKLBIEFDEEAx4sESRRLASMSKyJPA1QjTwJUiwBJTgJLAVBPAiJZIwgWVwYCXACMAEsBJBJLAoEDEksDgQQSSwSBBRJLBYEGEksGIwhLBxZPByRPCFSBA08HVIEETwZUgQVPBVSBBk8EVEpQSwMWTEsBUIsBSU8CUEwiWSMIFlcGAlwAjAFLBIEHEk8CgQdPAlRPAkxQSUsCUIsCSU8CUEwiWSMIFlcGAlwAjAJPAyUSKyJPAlRQTFCLA0lPAlBMIlkjCBZXBgJcAIwDjARC/zGLAEkiWYEFEkSLAUkiWYEFEkSLAkkiWYEFEkSLA0kiWYEFEkSABWJvb2wyTwRngAVib29sN08DZ4AFYm9vbDhPAmeABWJvb2w5TGeJigQEKUcIIkcDi/wiWSKLDosNDEEAGYv8VwIAiw5JTgIlC1uLDAiMDCMIjA5C/9+L/SJZjAAijASLBIsADEEAI4sEgRAIi/1MU4sLjAZBAAaLCyMIjAaLBowLiwQjCIwEQv/Vi/4iWYwBIowFiwWLAQxBAE6L/lcCAIsFgQkLgQlYSSJbSwGBQFNPAoFBU4wIiwpPAghJjAqMB0EABosKIwiMB4sHSYwKjAeLCEEABosKIwiMB4sHjAqLBSMIjAVC/6qL/yJZjAIijAOLA4sCDEEAVov/VwIAiwNJTgIkC0sBTFlLAiMIiwJLAQlLAxVLAiQLSwVMWU8CTU8DTwNPAlJJIltLASVZSwIVTwNOAlJXAgCLCU8CCEwVTEsBCIwJTwISRIwDQv+iiwyLC4sKiwmMA4wCjAGMAImKAQGAGgADAAAAAAAAAAEAAAAAAAAAAgAAAAAAAAADIosBi/8MQQAeiwFJFosASU8CUEwiWSMIFlcGAlwAjAAjCIwBQv/aiYoBAYADAAWoIosBi/8MQQAciwFJJBgUKyJPAlSLAEwjJYj0BYwAIwiMAUL/3ImKAQGACwABAAAAAAAAAACAIosBi/8MQQAziwFJJBgUSwGBAxgUSwIWKyJPBFQjTwNUUIsASU8CUEwiWSMIFlcGAlwAjAAjCIwBQv/FiYoBAYAVAAEAAgAAAAAAAAAAAAoABUhlbGxvIosBi/8MQQA3iwFJiPUdiwBJIllMVwIASwMWSwMVFlcGAk8EUEwnBlBMUCcETFBOAiNPA4j0SIwAIwiMAUL/wYmKAgGL/lcCACKLAYv/DEEAKosBSSQYFEsBgQMYFIsATgNLAhYrIk8EVCNPA1RQTwJMUIwAIwiMAUL/zosASRWBCQoWVwYCTFCMAImKAQEnCIv/UElXAgAVJQoWVwYCXACJigIBi/6L/1AnCExQgAIABFwAiYoBAYv/FYv/gQRPAlInCUwkiPNLiYoCAYv+i/9QJwlMJIjzO4mKAgGL/iJZi/5XAgCL/yJZi/9XAgCI842JigEBi/8iWUlEIwmL/1cCEEyBEAskCIv/TE8CXUmM/4mKAAEpgTCvSTEbIwgxGyQITBZMFlBJTgJJSwFQTFBJTgITRCKLBIEDDEEAFYsESYEQC4sBTIsCXYwBIwiMBEL/44sBiwMSRCKMAIsAgQMMQQAXiwBJgRALiwFMgRBYiwISRCMIjABC/+EnCosBSU4CZ0mI83eBDxJEgBAAAAAAAAAAAAAAAAAAAAAAXACI81yBChJEIicKZUSMAIk=", + "approval": "CiAEAAECCCYLAAQVH3x1AgAAAQACAAJA/////////////////////////////////////////////////////////////////////////////////////wIACgdiaWd1aW50EgACAAAAAAAAAAEAAAAAAAAAAgwAAgAEAAcAAWEAAWINaW1tX2ZpeGVkX2FycjEbQQC3MRkURDEYRIIYBETUL5kEt+qmCwR0PXDtBBx+BJQEotWGCwTgX8VkBB4JK4MEATECYgTIZUqYBInRlvgEbLfJkQSYmL8CBPa2HugEYLhqewRzrSg/BFKd+ukEIG1RTwTgZGXiBOwDAKIE7N8UrwRRGspkBCmFLk8EbUqjWAS3y5a9NhoAjhgCagNRBHsFNgXmBksHfQiyCLgIxwmkCsIL8ww/DHIMxA0kDXMNjA2oDbsN5A4NDioAMRkUMRgUEEOKAgKL/iJZIwkWVwYAi/5MXABJFYv/CUqL/1hPAiJPA1KJigECi/8iWSMJSSQLSYv/VwIASU4CSU8CWUlPAkkVTE4CUigiiwaLAQxBABuLAosGSU4CWSQJFlcGAosFTFCMBSQIjAZC/92LABZXBgKLBVCLASQIiwJMiwNSUIsEjACMAYmKBAEoRwKL/CJZRwKL/ghJFlcGAIv8TFwATgJMgQcIJQpJTwKBBwglCklOAgxBAAyLBosFCa+LBExQjAQijACLA4EQCEmMAov+CIwBiwKLAQxBACCL/YsASU4CU4sEiwJJTgNPAlSMBCMIjAKL/wiMAEL/2IsEjACJigMBi/0iWUmL/whMJAskCEsBFlcGAk4Ci/0kSwJSi/8kC69Qi/0Vi/1PA08CUlCL/lBMJAtJIkyLA4sCDEEAI4sESRZXBgKLAYsDSU4ETwJdSYwBSwFZJAgIjAQkCIwDQv/ViwCLAVCMAImKBAEoSYv+JAuL/CQLIosEiwMMQQAci/2LBElOAlmLAggWVwYCiwFMUIwBJAiMBEL/3Iv9FYwAIowEiwSLAgxBAByL/4sESU4CWYsACBZXBgKLAUxQjAEkCIwEQv/ci/yL/ggWVwYCiwFQi/2LA4sAUlCL/xWL/4sCTwJSUIwAiYoBASJJiwGBAwxBAB+LAUmBEAuL/0yBEFhJIluLAAhMJVsIjAAjCIwBQv/ZiYoBASgiiwGL/wxBABGLAIABIFCMAIsBIwiMAUL/54mKAgEiiwCL/wxBAB2LAEkWi/5MUIv+IlkjCBZXBgJcAIz+IwiMAEL/24v+TImACgABAAAAAAAAACqBBYj/wkkiWUmBBhJESSMJSwJXAgBMJQtbgQQSRIErFk8CTFBMIwgWVwYCXABHAiJZSYEHEkQjCUsBVwIATCULW4ErEkQkW4EqEkQiSYEDDEEAEUsBJYj9OkUDSEkjCEUBQv/oSwFJIllJgQQSRCMJSwFXAgBMJQtbJBJEgQqI/0ZJIllJgQ4SREkjCUsCVwIATCULW4EJEkSBLBZPAkxQTCMIFlcGAlwASSJZSYEPEkQjCUsBVwIATCULW4EsEkSBFxZcEkkiWYEPEkRJgRJbgRcSRIABYUxnI0MxGyMJFoFAr0lOAqsqTFCAAgABXABHAiJZSSMSRCMJTFcCAEyBQAuBQFgoqEQiSYEFDEEAIEcCFksEq0sDSU8CUEwiWSMIFlcGAlwARQMjCEUBQv/ZSwFJIllJgQYSREkjCUsCVwIATIFAC4FAWIABBKhEMRsWJwVMoUkVgUAOREsFq08CTFBMIwgWVwYCXABJIllJgQcSREkjCUsCVwIATIFAC4FAWIBA/////////////////////////////////////////////////////////////////////////////////////qhESwFXAkAoqERMJwVQTCMIFlcGAlwASSJZSSUSRCMJSwFXAgBMgUALgUBYJwWoRElXAkAoqEQnB7xIJwdMvyNDKDYaARcqIklLAwxBAB4xG0sBSU8CEisiTwJUSwNMIyWI++9FAyMIRQFC/9tLASJZSUUFSwNJTgISREEACksDREsBgRBTFERLAiMNQQAMI0sEDERLAYERUxRESwIkDUEACyRLBAxESwGBElNESwKBAw1BABJLAiMJSUsFDESBEAhLAkxTFESAAWdLAmdLAkEAKEsDIwlJFlcGAEsDTFwASwGBEAgiVEyBBwglCiQIIkxSIllLAyMJEkQjQyoiSYEFDEEAJUcCIwhMJAhLARZMFlBLA0lPAlBMIlkjCBZXBgJcAEUDRQFC/9RLAUkiWUmBBRJESwFXAgBLAlcCEEkiW0wlW0wjEkwkEhBETCMJgRALgRBYSSJbTCVbTIEFEkyBBhIQRIEQiPplRQFJIllJgQQSREsBVwIASwJXAhBJIltMJVtMIxJMJBIQREwjCYEQC4EQWEkiW0wlW0yBBBJMgQUSEESAAWNMZyNDKiJJgQUMQQA0RwIkGBRLAYEDCyQYFEsCFisiTwRUI08DVFBLA0lPAlBMIlkjCBZXBgJcAEUDIwhFAUL/xUsBSSJZgQUSRElXAglJIltLAYFAU08CgUFTTwIURExERIABZExnI0MoKiJJgQUMQQA1RwIjCEyvSwNJIllMVwIASwMWSwMVFlcGAk8EUEwnBlBMUCcETFBOAiNPA4j67kUDRQFC/8RLASJZSUUEgQUSRCJFAUmBBQxBAE9LAVcCAEsBSU4CJAtLAUxZSwIjCEsGSwEJSwMVSwIkC0sFTFlPAk1PA08DTwJSSSJbSwElWUsCFU8DTgJSVwIATEsCEkQVTwISREUBQv+qSwGI+ThFAUkiWUmBBBJESwFXAgBJIllLAiMJSwIVSwMkWUsBTEsDTUsETwRPAlJJIltLASVZSwIVTwNOAlJXAgBMIxIir08CEhBESwEkC0sDTFlPAiMITwRLAQlMJAtLBExZTwNMTwJNUkkiW0sBJVlLAhVPA04CUlcCAEyBBBKBA69PAhIQRIABZUxnI0MoKiJJgQUMQQA3RwIjCEyI+o9LA0kiWUxXAgBLAxZLAxUWVwYCTwRQTCcGUExQJwRMUE4CI08DiPm6RQNFAUL/wksBIllJRQSBBRJEIkUBSYEFDEEAUUsBVwIASwFJTgIkC0sBTFlLAiMISwZLAQlLAxVLAiQLSwVMWU8CTU8DTwNPAlJJIltLASVZSwIVTwNOAlJXAgBMSwISRE8CiPoBEkRFAUL/qEsBiPgCRQFJIllJgQQSREsBVwIASSJZSwIjCUsCFUsDJFlLAUxLA01LBE8ETwJSSSJbSwElWUsCFU8DTgJSVwIATCMSTCgSEERLASQLSwNMWU8CIwhPBEsBCUwkC0sETFlPA0xPAk1SSSJbSwElWUsCFU8DTgJSVwIATIEEEkyAAyAgIBIQRIABZkxnI0M2GgGwI0OABvpAwFMAAjYaAVCwI0MiRwIoRwU2GgEXNhoCIklLAwxBAEwqRQwiRQVLBEsBDEEAHksESRZLDUlPAlBMIlkjCBZXBgJcAEUNIwhFBUL/2ksBSSJZTFcCACcESw5QTgIjTwOI+FNFAkkjCEUBQv+tKkUKSwEiWUUJIkUHSwZLCQxBAGFLAVcCAEsHJAtLAUxZSlklCyQIWElFDCJFBSJZRQgiRQZLBUsIDEEAGUsKVwIASwZJTgIlC1tLBQhFBSMIRQZC/99LAxZLCklPAlBMIlkjCBZXBgJcAEUKSwYjCEUHQv+XKUsKULAjQypHAyJJgQUMQQDGRwIUSwEjEisiTwNUI08CVEsGSU4CSwFQTwIiWSMIFlcGAlwARQdLASQSSwKBAxJLA4EEEksEgQUSSwWBBhJLBiMISwcWTwckTwhUgQNPB1SBBE8GVIEFTwVUgQZPBFRKUEsDFkxLAVBLCUlPAlBMIlkjCBZXBgJcAEUJSwSBBxJPAoEHTwJUTwJMUElLAlBLB0lPAlBMIlkjCBZXBgJcAEUHTwMlEisiTwJUUExQSwNJTwJQTCJZIwgWVwYCXABFA0UBQv8zSwRJIlmBBRJESwRJIlmBBRJESwRJIlmBBRJESwRJIlmBBRJEgAVib29sMk8EZ4AFYm9vbDdPA2eABWJvb2w4TwJngAVib29sOUxnI0MoRwY2GgE2GgI2GgM2GgQiRwM2GgEiWSJJSwIMQQAZSwlXAgBLAUlOAiULW0sECEUEIwhFAUL/4EsIIllFESJFDUsMSxEMQQAbSwyBEAhLCUxTQQAGSwMjCEUESwwjCEUNQv/dSwciWUUQIkUMSwtLEAxBAEBLB1cCAEsMgQkLgQlYSSJbSwGBQFNPAoFBU0UNSwZPAghFBkEABksEIwhFBUsKQQAGSwQjCEUFSwsjCEUMQv+4SwYiWUUPIkUOSw1LDwxBAFZLBlcCAEsOSU4CJAtLAUxZSwIjCEsSSwEJSwMVSwIkC0sFTFlPAk1PA08DTwJSSSJbSwElWUsCFU8DTgJSVwIASwlPAghMFUxLAQhFCU8CEkRFDkL/oksCFksEFlBLBRZQSwYWUClMULAjQzYaAReAGgADAAAAAAAAAAEAAAAAAAAAAgAAAAAAAAADIklLAwxBAB1HAhZLA0lPAlBMIlkjCBZXBgJcAEUDIwhFAUL/3ClLAlCwI0M2GgEXgAMABagiSUsDDEEAG0cCJBgUKyJPAlRLA0wjJYj0K0UDIwhFAUL/3ilLAlCwI0M2GgEXgAsAAQAAAAAAAAAAgCJJSwMMQQAyRwIkGBRLAYEDGBRLAhYrIk8EVCNPA1RQSwNJTwJQTCJZIwgWVwYCXABFAyMIRQFC/8cpSwJQsCNDNhoBF4AVAAEAAgAAAAAAAAAAAAoABUhlbGxvIklLAwxBADZHAoj1MksDSSJZTFcCAEsDFksDFRZXBgJPBFBMJwZQTFAnBExQTgIjTwOI9F1FAyMIRQFC/8MpSwJQsCNDNhoBNhoCF0xXAgAiSUsDDEEAKUcCJBgUSwGBAxgUSwROA0sCFisiTwRUI08DVFBPAkxQRQMjCEUBQv/QSwFJFYEJChZXBgJMUClMULAjQycINhoBUElXAgAVJQoWVwYCXAApTFCwI0M2GgFJVwAITFcICFAnCExQgAIABFwAKUxQsCNDNhoBVwQAJwlMJIjzUSlMULAjQzYaAUkiWUsBJFlLAk8CSwJSSwIVTwNPA08CUlAnCUwkiPMoKUxQsCNDNhoBNhoCSwEiWU8CVwIASwJXAgBPAyJZTwNPA08CTwOI82opTFCwI0M2GgFJIllJRCMJSwFXAhBMgRALJAhMXSlMULAjQyiBMK9JMRsjCDEbJAhMFkwWUElOAklLAVBMUElOAhNEIkmBAwxBABRHAoEQC0sFTEsFXUUFIwhFAUL/5UsDSwISRCJFBUsEgQMMQQAXSwRJgRALSwVMgRBYSwQSRCMIRQVC/+EnCksESU4CZ0mI81eBDxJEgBAAAAAAAAAAAAAAAAAAAAAAXACI8zyBChJEIicKZUQpTFCwI0M=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal b/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal index d19fda5..fabbeaf 100644 --- a/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal +++ b/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal @@ -4,12 +4,12 @@ // tests.artifacts.Arrays.static_size.StaticSizeContract.__algopy_entrypoint_with_init() -> uint64: main: intcblock 0 1 8 16 144 - bytecblock 0x151f7c75 "count" 0x00 0x 0x0000 + bytecblock 0x 0x151f7c75 "count" 0x00 0x0000 txn ApplicationID bnz main_after_if_else@2 // tests/artifacts/Arrays/static_size.py:39 // self.count = UInt64(0) - bytec_1 // "count" + bytec_2 // "count" intc_0 // 0 app_global_put @@ -17,189 +17,30 @@ main_after_if_else@2: // tests/artifacts/Arrays/static_size.py:37 // class StaticSizeContract(arc4.ARC4Contract): txn NumAppArgs - bz main_bare_routing@12 - pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]" - txna ApplicationArgs 0 - match main_test_array_route@5 main_test_extend_from_tuple_route@6 main_test_extend_from_arc4_tuple_route@7 main_test_bool_array_route@8 main_test_arc4_conversion_route@9 main_sum_array_route@10 main_test_arc4_bool_route@11 - -main_after_if_else@14: - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - intc_0 // 0 - return - -main_test_arc4_bool_route@11: - // tests/artifacts/Arrays/static_size.py:138 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub test_arc4_bool - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_sum_array_route@10: - // tests/artifacts/Arrays/static_size.py:112 - // @arc4.abimethod() + bz main___algopy_default_create@14 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arrays/static_size.py:112 - // @arc4.abimethod() - callsub sum_array - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_arc4_conversion_route@9: - // tests/artifacts/Arrays/static_size.py:94 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/static_size.py:94 - // @arc4.abimethod() - callsub test_arc4_conversion - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_bool_array_route@8: - // tests/artifacts/Arrays/static_size.py:75 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/Arrays/static_size.py:75 - // @arc4.abimethod() - callsub test_bool_array - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_extend_from_arc4_tuple_route@7: - // tests/artifacts/Arrays/static_size.py:67 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/Arrays/static_size.py:67 - // @arc4.abimethod() - callsub test_extend_from_arc4_tuple - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_test_extend_from_tuple_route@6: - // tests/artifacts/Arrays/static_size.py:57 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - dup - extract 0 16 - swap - extract 16 16 - // tests/artifacts/Arrays/static_size.py:57 - // @arc4.abimethod() - callsub test_extend_from_tuple - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return + assert + pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]" + txna ApplicationArgs 0 + match test_array test_extend_from_tuple test_extend_from_arc4_tuple test_bool_array test_arc4_conversion sum_array test_arc4_bool + err -main_test_array_route@5: - // tests/artifacts/Arrays/static_size.py:41 - // @arc4.abimethod() +main___algopy_default_create@14: txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - btoi - txna ApplicationArgs 3 - txna ApplicationArgs 4 - btoi - // tests/artifacts/Arrays/static_size.py:41 - // @arc4.abimethod() - callsub test_array - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_bare_routing@12: - // tests/artifacts/Arrays/static_size.py:37 - // class StaticSizeContract(arc4.ARC4Contract): - txn OnCompletion - bnz main_after_if_else@14 txn ApplicationID ! - assert // can only call when creating - intc_1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating // _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes: dynamic_array_concat_bits: proto 4 1 - bytec_3 // "" + bytec_0 // "" dupn 2 frame_dig -4 intc_0 // 0 @@ -213,22 +54,20 @@ dynamic_array_concat_bits: frame_dig -4 swap replace2 0 - dup - uncover 2 - uncover 3 + cover 2 + swap pushint 7 // 7 + intc_2 // 8 / dup - cover 3 - swap + uncover 2 pushint 7 // 7 + intc_2 // 8 / dup - cover 3 + cover 2 < bz dynamic_array_concat_bits_after_if_else@2 frame_dig 6 @@ -238,11 +77,9 @@ dynamic_array_concat_bits: frame_dig 4 swap concat - frame_bury 7 + frame_bury 4 dynamic_array_concat_bits_after_if_else@2: - frame_dig 7 - frame_bury 4 intc_0 // 0 frame_bury 0 frame_dig 3 @@ -285,19 +122,23 @@ dynamic_array_concat_bits_after_while@5: retsub -// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array(x1: bytes, y1: uint64, x2: bytes, y2: uint64) -> uint64: +// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array[routing]() -> void: test_array: - // tests/artifacts/Arrays/static_size.py:41-42 - // @arc4.abimethod() - // def test_array(self, x1: arc4.UInt64, y1: UInt64, x2: arc4.UInt64, y2: UInt64) -> UInt64: - proto 4 1 intc_0 // 0 dup - bytec_3 // "" + bytec_0 // "" dupn 5 + // tests/artifacts/Arrays/static_size.py:41 + // @arc4.abimethod() + txna ApplicationArgs 1 + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + txna ApplicationArgs 4 + btoi // tests/artifacts/Arrays/static_size.py:43 // self.count = UInt64(0) - bytec_1 // "count" + bytec_2 // "count" intc_0 // 0 app_global_put // tests/artifacts/Arrays/static_size.py:45 @@ -340,9 +181,9 @@ test_array: pushbytes 0x00000000000000000000000000000000 swap concat - frame_dig -3 + uncover 14 itob - frame_dig -4 + uncover 15 swap concat uncover 12 @@ -365,9 +206,9 @@ test_array: concat concat concat - frame_dig -1 + uncover 7 itob - frame_dig -2 + uncover 8 swap concat uncover 7 @@ -394,17 +235,16 @@ test_array: // for i in urange(3): intc_0 // 0 -test_array_for_header@1: +test_array_for_header@2: // tests/artifacts/Arrays/static_size.py:49 // for i in urange(3): - frame_dig 9 + dup pushint 3 // 3 < - bz test_array_after_for@4 - frame_dig 8 + bz test_array_after_for@5 // tests/artifacts/Arrays/static_size.py:50 // assert path[i].other.b == i + 1 - frame_dig 9 + dup2 dup cover 2 intc 4 // 144 @@ -415,18 +255,18 @@ test_array_for_header@1: dup intc_2 // 8 extract_uint64 - swap - extract 48 16 dig 2 intc_1 // 1 + - uncover 2 + swap dig 1 == assert // tests/artifacts/Arrays/static_size.py:51 // assert path[i].other.d.foo == i + 2 - dig 1 + swap + extract 48 16 + dup extract 0 8 uncover 3 pushint 2 // 2 @@ -436,7 +276,6 @@ test_array_for_header@1: assert // tests/artifacts/Arrays/static_size.py:52 // assert path[i].other.d.bar == (i + 1) * (i + 1) - swap extract 8 8 dig 1 dig 2 @@ -444,11 +283,11 @@ test_array_for_header@1: itob b== assert - frame_bury 9 - b test_array_for_header@1 + bury 1 + b test_array_for_header@2 -test_array_after_for@4: - frame_dig 8 +test_array_after_for@5: + dig 1 // tests/artifacts/Arrays/static_size.py:54 // Box(ImmutableArray[Point], key="a").value = path.freeze() dup @@ -456,7 +295,7 @@ test_array_after_for@4: intc 4 // 144 / dup - frame_bury 2 + bury 10 itob extract 6 2 dig 1 @@ -471,33 +310,33 @@ test_array_after_for@4: // last_point = path[0] extract 0 144 // on error: index access is out of bounds dup - frame_bury 0 + bury 11 dup extract 0 8 - frame_bury 1 + bury 10 intc_2 // 8 extract_uint64 - frame_bury 4 + bury 6 // tests/artifacts/Arrays/static_size.py:168 // length = UInt64() intc_0 // 0 - frame_bury 5 + bury 5 // tests/artifacts/Arrays/static_size.py:169 // for point_idx in urange(1, path.length): intc_1 // 1 - frame_bury 7 + bury 3 -test_array_for_header@6: +test_array_for_header@7: // tests/artifacts/Arrays/static_size.py:169 // for point_idx in urange(1, path.length): - frame_dig 7 - frame_dig 2 + dig 2 + dig 8 < - bz test_array_after_for@14 - frame_dig 8 + bz test_array_after_for@15 + dig 1 // tests/artifacts/Arrays/static_size.py:170 // point = path[point_idx] - frame_dig 7 + dig 3 intc 4 // 144 * intc 4 // 144 @@ -507,48 +346,48 @@ test_array_for_header@6: swap intc_2 // 8 extract_uint64 - frame_bury 6 + bury 6 // tests/artifacts/Arrays/static_size.py:171 // if point.x < last_point.x: - frame_dig 1 + dig 10 b< - bz test_array_else_body@9 + bz test_array_else_body@10 // tests/artifacts/Arrays/static_size.py:172 - // dx = last_point.x.native - point.x.native - frame_dig 0 + // dx = last_point.x.as_uint64() - point.x.as_uint64() + dig 10 // tests/artifacts/Arrays/static_size.py:167 // last_point = path[0] intc_0 // 0 // tests/artifacts/Arrays/static_size.py:172 - // dx = last_point.x.native - point.x.native + // dx = last_point.x.as_uint64() - point.x.as_uint64() extract_uint64 swap // tests/artifacts/Arrays/static_size.py:170 // point = path[point_idx] intc_0 // 0 // tests/artifacts/Arrays/static_size.py:172 - // dx = last_point.x.native - point.x.native + // dx = last_point.x.as_uint64() - point.x.as_uint64() extract_uint64 - - frame_bury 3 + bury 7 -test_array_after_if_else@10: +test_array_after_if_else@11: // tests/artifacts/Arrays/static_size.py:175 // if point.y < last_point.y: - frame_dig 6 - frame_dig 4 + dig 3 + dig 6 < - bz test_array_else_body@12 + bz test_array_else_body@13 // tests/artifacts/Arrays/static_size.py:176 // dy = last_point.y - point.y - frame_dig 4 - frame_dig 6 + dig 5 + dig 4 - -test_array_after_if_else@13: +test_array_after_if_else@14: // tests/artifacts/Arrays/static_size.py:179 // length += op.sqrt(dx * dx + dy * dy) - frame_dig 3 + dig 7 dup * swap @@ -556,61 +395,69 @@ test_array_after_if_else@13: * + sqrt - frame_dig 5 + dig 5 + - frame_bury 5 + bury 5 // tests/artifacts/Arrays/static_size.py:169 // for point_idx in urange(1, path.length): - frame_dig 7 + dig 2 intc_1 // 1 + - frame_bury 7 - b test_array_for_header@6 + bury 3 + b test_array_for_header@7 -test_array_else_body@12: +test_array_else_body@13: // tests/artifacts/Arrays/static_size.py:178 // dy = point.y - last_point.y - frame_dig 6 - frame_dig 4 + dig 3 + dig 6 - - b test_array_after_if_else@13 + b test_array_after_if_else@14 -test_array_else_body@9: +test_array_else_body@10: // tests/artifacts/Arrays/static_size.py:170 // point = path[point_idx] intc_0 // 0 // tests/artifacts/Arrays/static_size.py:174 - // dx = point.x.native - last_point.x.native + // dx = point.x.as_uint64() - last_point.x.as_uint64() extract_uint64 - frame_dig 0 + dig 10 // tests/artifacts/Arrays/static_size.py:167 // last_point = path[0] intc_0 // 0 // tests/artifacts/Arrays/static_size.py:174 - // dx = point.x.native - last_point.x.native + // dx = point.x.as_uint64() - last_point.x.as_uint64() extract_uint64 - - frame_bury 3 - b test_array_after_if_else@10 + bury 7 + b test_array_after_if_else@11 -test_array_after_for@14: - // tests/artifacts/Arrays/static_size.py:55 - // return path_length(path) - frame_dig 5 - frame_bury 0 - retsub +test_array_after_for@15: + // tests/artifacts/Arrays/static_size.py:41 + // @arc4.abimethod() + dig 4 + itob + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple(some_more.0: bytes, some_more.1: bytes) -> bytes: +// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple[routing]() -> void: test_extend_from_tuple: - // tests/artifacts/Arrays/static_size.py:57-58 + // tests/artifacts/Arrays/static_size.py:57 // @arc4.abimethod() - // def test_extend_from_tuple(self, some_more: tuple[More, More]) -> ImmutableArray[More]: - proto 2 1 + txna ApplicationArgs 1 + dup + extract 0 16 + swap + extract 16 16 // tests/artifacts/Arrays/static_size.py:60 // arr.extend(some_more) - frame_dig -2 - frame_dig -1 + swap + dig 1 concat // tests/artifacts/Arrays/static_size.py:61 // last = arr[-1] @@ -630,7 +477,7 @@ test_extend_from_tuple: // tests/artifacts/Arrays/static_size.py:62 // assert last == some_more[1] dup - frame_dig -1 + uncover 4 == assert // tests/artifacts/Arrays/static_size.py:63 @@ -657,89 +504,101 @@ test_extend_from_tuple: uncover 2 == assert - // tests/artifacts/Arrays/static_size.py:65 - // return result - retsub + // tests/artifacts/Arrays/static_size.py:57 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple(some_more: bytes) -> bytes: +// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple[routing]() -> void: test_extend_from_arc4_tuple: - // tests/artifacts/Arrays/static_size.py:67-70 + // tests/artifacts/Arrays/static_size.py:67 // @arc4.abimethod() - // def test_extend_from_arc4_tuple( - // self, some_more: arc4.Tuple[More, More] - // ) -> ImmutableArray[More]: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/Arrays/static_size.py:72 // arr.extend(some_more) - frame_dig -1 + dup pop // tests/artifacts/Arrays/static_size.py:73 // return arr.freeze() - frame_dig -1 + dup len intc_3 // 16 / itob extract 6 2 - frame_dig -1 + swap concat - retsub + // tests/artifacts/Arrays/static_size.py:67 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array(length: uint64) -> uint64: +// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array[routing]() -> void: test_bool_array: - // tests/artifacts/Arrays/static_size.py:75-76 + bytec_0 // "" + dupn 2 + // tests/artifacts/Arrays/static_size.py:75 // @arc4.abimethod() - // def test_bool_array(self, length: UInt64) -> UInt64: - proto 1 1 - bytec_3 // "" + txna ApplicationArgs 1 + btoi + dup // tests/artifacts/Arrays/static_size.py:77 // arr = ReferenceArray[bool]() - dupn 4 + bytec_0 // 0x + swap // tests/artifacts/Arrays/static_size.py:80 // for i in urange(1, length + 1): - frame_dig -1 intc_1 // 1 + intc_1 // 1 -test_bool_array_for_header@1: +test_bool_array_for_header@2: // tests/artifacts/Arrays/static_size.py:80 // for i in urange(1, length + 1): - frame_dig 6 - frame_dig 5 + dup + dig 2 < - bz test_bool_array_after_for@4 + bz test_bool_array_after_for@5 // tests/artifacts/Arrays/static_size.py:81 // arr.append(i % 2 == 0) - frame_dig 6 - dup + dupn 2 pushint 2 // 2 % ! - frame_dig 4 + dig 4 swap - bytec_2 // 0x00 + bytec_3 // 0x00 intc_0 // 0 uncover 2 setbit concat // on error: max array length exceeded - frame_bury 4 + bury 4 // tests/artifacts/Arrays/static_size.py:80 // for i in urange(1, length + 1): intc_1 // 1 + - frame_bury 6 - b test_bool_array_for_header@1 + bury 1 + b test_bool_array_for_header@2 -test_bool_array_after_for@4: - frame_dig 4 +test_bool_array_after_for@5: + dig 2 dupn 2 // tests/artifacts/Arrays/static_size.py:82 // assert arr.length == length, "expected correct length" len - frame_dig -1 + dig 6 + dup + cover 4 == assert // expected correct length dig 1 @@ -749,7 +608,7 @@ test_bool_array_after_for@4: // tests/artifacts/Arrays/static_size.py:86 // assert arr2.length == length * 2, "expected correct length" len - frame_dig -1 + uncover 2 pushint 2 // 2 * == @@ -757,156 +616,154 @@ test_bool_array_after_for@4: // tests/artifacts/Arrays/static_size.py:88 // count = UInt64(0) intc_0 // 0 - frame_bury 1 + bury 7 // tests/artifacts/Arrays/static_size.py:89 // for val in arr: len - frame_bury 0 + bury 7 intc_0 // 0 - frame_bury 3 + bury 5 -test_bool_array_for_header@5: +test_bool_array_for_header@6: // tests/artifacts/Arrays/static_size.py:89 // for val in arr: - frame_dig 3 - frame_dig 0 + dig 4 + dig 7 < - bz test_bool_array_after_for@10 - frame_dig 4 - frame_dig 3 + bz test_bool_array_after_for@11 + dig 2 + dig 5 intc_1 // 1 extract3 // on error: index access is out of bounds intc_0 // 0 getbit - frame_dig 1 - frame_bury 2 // tests/artifacts/Arrays/static_size.py:90 // if val: - bz test_bool_array_after_if_else@8 + bz test_bool_array_after_if_else@9 // tests/artifacts/Arrays/static_size.py:91 // count += 1 - frame_dig 1 + dig 5 intc_1 // 1 + - frame_bury 2 + bury 6 -test_bool_array_after_if_else@8: - frame_dig 2 - frame_bury 1 - frame_dig 3 +test_bool_array_after_if_else@9: + dig 4 intc_1 // 1 + - frame_bury 3 - b test_bool_array_for_header@5 + bury 5 + b test_bool_array_for_header@6 -test_bool_array_after_for@10: - // tests/artifacts/Arrays/static_size.py:92 - // return count - frame_dig 1 - frame_bury 0 - retsub +test_bool_array_after_for@11: + // tests/artifacts/Arrays/static_size.py:75 + // @arc4.abimethod() + dig 5 + itob + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion(length: uint64) -> bytes: +// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion[routing]() -> void: test_arc4_conversion: - // tests/artifacts/Arrays/static_size.py:94-95 + bytec_0 // "" + dupn 2 + // tests/artifacts/Arrays/static_size.py:94 // @arc4.abimethod() - // def test_arc4_conversion(self, length: UInt64) -> arc4.DynamicArray[arc4.UInt64]: - proto 1 1 - bytec_3 // "" + txna ApplicationArgs 1 + btoi + dup // tests/artifacts/Arrays/static_size.py:96 // arr = ReferenceArray[arc4.UInt64]() - dupn 4 + bytec_0 // 0x + swap // tests/artifacts/Arrays/static_size.py:99 // for i in urange(1, length + 1): - frame_dig -1 intc_1 // 1 + intc_1 // 1 -test_arc4_conversion_for_header@1: +test_arc4_conversion_for_header@2: // tests/artifacts/Arrays/static_size.py:99 // for i in urange(1, length + 1): - frame_dig 6 - frame_dig 5 + dup + dig 2 < - bz test_arc4_conversion_after_for@4 + bz test_arc4_conversion_after_for@5 // tests/artifacts/Arrays/static_size.py:100 // arr.append(arc4.UInt64(i)) - frame_dig 6 - dup + dupn 2 itob - frame_dig 4 + dig 4 swap concat // on error: max array length exceeded - frame_bury 4 + bury 4 // tests/artifacts/Arrays/static_size.py:99 // for i in urange(1, length + 1): intc_1 // 1 + - frame_bury 6 - b test_arc4_conversion_for_header@1 + bury 1 + b test_arc4_conversion_for_header@2 -test_arc4_conversion_after_for@4: - frame_dig 4 +test_arc4_conversion_after_for@5: + dig 2 // tests/artifacts/Arrays/static_size.py:101 // assert arr.length == length, "expected correct length" len intc_2 // 8 / dup - frame_bury 0 - frame_dig -1 + bury 8 + dig 4 == assert // expected correct length // tests/artifacts/Arrays/static_size.py:102 // count = UInt64(0) intc_0 // 0 - frame_bury 1 + bury 6 intc_0 // 0 - frame_bury 3 + bury 5 -test_arc4_conversion_for_header@5: +test_arc4_conversion_for_header@6: // tests/artifacts/Arrays/static_size.py:103 // for val in arr: - frame_dig 3 - frame_dig 0 + dig 4 + dig 7 < - bz test_arc4_conversion_after_for@10 - frame_dig 4 - frame_dig 3 + bz test_arc4_conversion_after_for@11 + dig 2 + dig 5 intc_2 // 8 * intc_2 // 8 extract3 // on error: index access is out of bounds // tests/artifacts/Arrays/static_size.py:104 // if val: - bytec_3 // 0x + bytec_0 // 0x b!= - frame_dig 1 - frame_bury 2 - bz test_arc4_conversion_after_if_else@8 + bz test_arc4_conversion_after_if_else@9 // tests/artifacts/Arrays/static_size.py:105 // count += 1 - frame_dig 1 + dig 5 intc_1 // 1 + - frame_bury 2 + bury 6 -test_arc4_conversion_after_if_else@8: - frame_dig 2 - frame_bury 1 - frame_dig 3 +test_arc4_conversion_after_if_else@9: + dig 4 intc_1 // 1 + - frame_bury 3 - b test_arc4_conversion_for_header@5 + bury 5 + b test_arc4_conversion_for_header@6 -test_arc4_conversion_after_for@10: +test_arc4_conversion_after_for@11: // tests/artifacts/Arrays/static_size.py:107 // arc4_arr = arc4.DynamicArray[arc4.UInt64]() bytec 4 // 0x0000 - frame_dig 4 + dig 3 // tests/artifacts/Arrays/static_size.py:108 // arc4_arr.extend(arr) concat // on error: max array length exceeded @@ -918,21 +775,23 @@ test_arc4_conversion_after_for@10: itob extract 6 2 replace2 0 - // tests/artifacts/Arrays/static_size.py:110 - // return arc4_arr - frame_bury 0 - retsub + // tests/artifacts/Arrays/static_size.py:94 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array(arc4_arr: bytes) -> uint64: +// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array[routing]() -> void: sum_array: - // tests/artifacts/Arrays/static_size.py:112-113 + // tests/artifacts/Arrays/static_size.py:112 // @arc4.abimethod() - // def sum_array(self, arc4_arr: arc4.DynamicArray[arc4.UInt64]) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/Arrays/static_size.py:115 // arr.extend(arc4_arr) - frame_dig -1 extract 2 0 dup // tests/artifacts/Arrays/static_size.py:117 @@ -946,112 +805,51 @@ sum_array: / intc_0 // 0 -sum_array_for_header@1: +sum_array_for_header@2: // tests/artifacts/Arrays/static_size.py:118 // for item in arr: - frame_dig 3 - frame_dig 2 + dup + dig 2 < - bz sum_array_after_for@4 - frame_dig 0 - frame_dig 3 + bz sum_array_after_for@5 + dig 3 + dig 1 dup cover 2 intc_2 // 8 * // tests/artifacts/Arrays/static_size.py:119 - // total += item.native + // total += item.as_uint64() extract_uint64 - frame_dig 1 + dig 4 + - frame_bury 1 + bury 4 intc_1 // 1 + - frame_bury 3 - b sum_array_for_header@1 - -sum_array_after_for@4: - // tests/artifacts/Arrays/static_size.py:121 - // return total - frame_dig 1 - frame_bury 0 - retsub - + bury 1 + b sum_array_for_header@2 -// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes: -xtra: - // tests/artifacts/Arrays/static_size.py:125 - // self.count += 1 - intc_0 // 0 - bytec_1 // "count" - app_global_get_ex - assert // check self.count exists - intc_1 // 1 - + - bytec_1 // "count" - dig 1 - app_global_put - // tests/artifacts/Arrays/static_size.py:127 - // a=Txn.num_app_args, - txn NumAppArgs - // tests/artifacts/Arrays/static_size.py:129 - // c=Txn.sender, - txn Sender - // tests/artifacts/Arrays/static_size.py:130 - // d=self.more(), - callsub more - // tests/artifacts/Arrays/static_size.py:131 - // e=BigUInt(self.count), - intc_0 // 0 - bytec_1 // "count" - app_global_get_ex - assert // check self.count exists - itob - // tests/artifacts/Arrays/static_size.py:126-132 - // return Xtra( - // a=Txn.num_app_args, - // b=self.count, - // c=Txn.sender, - // d=self.more(), - // e=BigUInt(self.count), - // ) - uncover 3 - cover 4 - retsub - - -// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes: -more: - // tests/artifacts/Arrays/static_size.py:136 - // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count)) - intc_0 // 0 - bytec_1 // "count" - app_global_get_ex - assert // check self.count exists - dup - intc_1 // 1 - + - itob - dig 1 - uncover 2 - * +sum_array_after_for@5: + // tests/artifacts/Arrays/static_size.py:112 + // @arc4.abimethod() + dig 2 itob + bytec_1 // 0x151f7c75 + swap concat - retsub + log + intc_1 // 1 + return -// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool() -> bytes: +// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool[routing]() -> void: test_arc4_bool: - // tests/artifacts/Arrays/static_size.py:138-139 - // @arc4.abimethod() - // def test_arc4_bool(self) -> ImmutableArray[arc4.Bool]: - proto 0 1 // tests/artifacts/Arrays/static_size.py:141 // arr.append(arc4.Bool(Txn.sender == Txn.receiver)) txn Sender txn Receiver == - bytec_2 // 0x00 + bytec_3 // 0x00 intc_0 // 0 uncover 2 setbit @@ -1060,23 +858,22 @@ test_arc4_bool: txn Sender txn Receiver != - bytec_2 // 0x00 + bytec_3 // 0x00 intc_0 // 0 uncover 2 setbit concat // on error: max array length exceeded dupn 2 - uncover 2 // tests/artifacts/Arrays/static_size.py:145 // dyn_arr.extend(arr) - dup len // tests/artifacts/Arrays/static_size.py:144 // dyn_arr = arc4.DynamicArray[arc4.Bool]() bytec 4 // 0x0000 // tests/artifacts/Arrays/static_size.py:145 // dyn_arr.extend(arr) - cover 2 + dig 2 + uncover 2 intc_2 // 8 callsub dynamic_array_concat_bits dup @@ -1106,7 +903,7 @@ test_arc4_bool: dig 1 intc_3 // 16 getbit - bytec_2 // 0x00 + bytec_3 // 0x00 intc_0 // 0 uncover 2 setbit @@ -1124,7 +921,7 @@ test_arc4_bool: assert // index access is out of bounds pushint 17 // 17 getbit - bytec_2 // 0x00 + bytec_3 // 0x00 intc_0 // 0 uncover 2 setbit @@ -1137,39 +934,38 @@ test_arc4_bool: assert // expected correct value at 1 intc_0 // 0 -test_arc4_bool_for_header@1: +test_arc4_bool_for_header@2: // tests/artifacts/Arrays/static_size.py:152-154 // # note: not supported currently // # arr2.extend(dyn_array) // for b in dyn_arr: - frame_dig 4 - frame_dig 2 - < - bz test_arc4_bool_after_for@4 - frame_dig 4 dup + dig 3 + < + bz test_arc4_bool_after_for@5 + dupn 2 intc_3 // 16 + - frame_dig 1 + dig 5 swap getbit - bytec_2 // 0x00 + bytec_3 // 0x00 intc_0 // 0 uncover 2 setbit - frame_dig 3 + dig 3 // tests/artifacts/Arrays/static_size.py:155 // arr2.append(b) swap concat // on error: max array length exceeded - frame_bury 3 + bury 3 intc_1 // 1 + - frame_bury 4 - b test_arc4_bool_for_header@1 + bury 1 + b test_arc4_bool_for_header@2 -test_arc4_bool_after_for@4: - frame_dig 3 +test_arc4_bool_after_for@5: + dig 1 // tests/artifacts/Arrays/static_size.py:156 // assert arr2.length == 4, "expected correct length" dup @@ -1220,7 +1016,7 @@ test_arc4_bool_after_for@4: != == assert // expected correct value at 3 - frame_dig 0 + dig 4 // tests/artifacts/Arrays/static_size.py:162 // return arr.freeze() dup @@ -1229,5 +1025,73 @@ test_arc4_bool_after_for@4: cover 2 intc_2 // 8 callsub dynamic_array_concat_bits - frame_bury 0 + // tests/artifacts/Arrays/static_size.py:138 + // @arc4.abimethod() + bytec_1 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return + + +// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes: +xtra: + // tests/artifacts/Arrays/static_size.py:125 + // self.count += 1 + intc_0 // 0 + bytec_2 // "count" + app_global_get_ex + assert // check self.count exists + intc_1 // 1 + + + bytec_2 // "count" + dig 1 + app_global_put + // tests/artifacts/Arrays/static_size.py:127 + // a=Txn.num_app_args, + txn NumAppArgs + // tests/artifacts/Arrays/static_size.py:129 + // c=Txn.sender, + txn Sender + // tests/artifacts/Arrays/static_size.py:130 + // d=self.more(), + callsub more + // tests/artifacts/Arrays/static_size.py:131 + // e=BigUInt(self.count), + intc_0 // 0 + bytec_2 // "count" + app_global_get_ex + assert // check self.count exists + itob + // tests/artifacts/Arrays/static_size.py:126-132 + // return Xtra( + // a=Txn.num_app_args, + // b=self.count, + // c=Txn.sender, + // d=self.more(), + // e=BigUInt(self.count), + // ) + uncover 3 + cover 4 + retsub + + +// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes: +more: + // tests/artifacts/Arrays/static_size.py:136 + // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count)) + intc_0 // 0 + bytec_2 // "count" + app_global_get_ex + assert // check self.count exists + dup + intc_1 // 1 + + + itob + dig 1 + uncover 2 + * + itob + concat retsub diff --git a/tests/artifacts/Arrays/data/StaticSizeContract.arc32.json b/tests/artifacts/Arrays/data/StaticSizeContract.arc32.json index c3d1657..8b3618a 100644 --- a/tests/artifacts/Arrays/data/StaticSizeContract.arc32.json +++ b/tests/artifacts/Arrays/data/StaticSizeContract.arc32.json @@ -37,7 +37,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.Arrays.static_size.StaticSizeContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 8 16 144
    bytecblock 0x151f7c75 "count" 0x00 0x 0x0000
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/Arrays/static_size.py:39
    // self.count = UInt64(0)
    bytec_1 // "count"
    intc_0 // 0
    app_global_put

main_after_if_else@2:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@12
    pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]"
    txna ApplicationArgs 0
    match main_test_array_route@5 main_test_extend_from_tuple_route@6 main_test_extend_from_arc4_tuple_route@7 main_test_bool_array_route@8 main_test_arc4_conversion_route@9 main_sum_array_route@10 main_test_arc4_bool_route@11

main_after_if_else@14:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    intc_0 // 0
    return

main_test_arc4_bool_route@11:
    // tests/artifacts/Arrays/static_size.py:138
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_sum_array_route@10:
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    callsub sum_array
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_arc4_conversion_route@9:
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    callsub test_arc4_conversion
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_bool_array_route@8:
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    callsub test_bool_array
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_extend_from_arc4_tuple_route@7:
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    callsub test_extend_from_arc4_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_extend_from_tuple_route@6:
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    dup
    extract 0 16
    swap
    extract 16 16
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    callsub test_extend_from_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_array_route@5:
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    callsub test_array
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_bare_routing@12:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@14
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_3 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    dup
    uncover 2
    uncover 3
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    cover 3
    swap
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    cover 3
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 7

dynamic_array_concat_bits_after_if_else@2:
    frame_dig 7
    frame_bury 4
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    intc_3 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array(x1: bytes, y1: uint64, x2: bytes, y2: uint64) -> uint64:
test_array:
    // tests/artifacts/Arrays/static_size.py:41-42
    // @arc4.abimethod()
    // def test_array(self, x1: arc4.UInt64, y1: UInt64, x2: arc4.UInt64, y2: UInt64) -> UInt64:
    proto 4 1
    intc_0 // 0
    dup
    bytec_3 // ""
    dupn 5
    // tests/artifacts/Arrays/static_size.py:43
    // self.count = UInt64(0)
    bytec_1 // "count"
    intc_0 // 0
    app_global_put
    // tests/artifacts/Arrays/static_size.py:45
    // Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:46
    // Point(x=x1, y=y1, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:47
    // Point(x=x2, y=y2, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:44-48
    // path = ReferenceArray(
    //     Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    //     Point(x=x1, y=y1, other=self.xtra()),
    //     Point(x=x2, y=y2, other=self.xtra()),
    // )
    uncover 14
    itob
    uncover 14
    itob
    concat
    uncover 13
    concat
    uncover 12
    concat
    dig 11
    len
    pushint 64 // 64
    <=
    assert // overflow
    pushint 64 // 64
    bzero
    uncover 12
    dig 1
    b|
    uncover 2
    swap
    concat
    pushbytes 0x00000000000000000000000000000000
    swap
    concat
    frame_dig -3
    itob
    frame_dig -4
    swap
    concat
    uncover 12
    itob
    uncover 12
    itob
    concat
    uncover 11
    concat
    uncover 10
    concat
    dig 9
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 9
    dig 4
    b|
    concat
    concat
    concat
    frame_dig -1
    itob
    frame_dig -2
    swap
    concat
    uncover 7
    itob
    uncover 7
    itob
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 4
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 4
    uncover 4
    b|
    concat
    concat
    concat
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    intc_0 // 0

test_array_for_header@1:
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    frame_dig 9
    pushint 3 // 3
    <
    bz test_array_after_for@4
    frame_dig 8
    // tests/artifacts/Arrays/static_size.py:50
    // assert path[i].other.b == i + 1
    frame_dig 9
    dup
    cover 2
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    extract 16 128
    dup
    intc_2 // 8
    extract_uint64
    swap
    extract 48 16
    dig 2
    intc_1 // 1
    +
    uncover 2
    dig 1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:51
    // assert path[i].other.d.foo == i + 2
    dig 1
    extract 0 8
    uncover 3
    pushint 2 // 2
    +
    itob
    b==
    assert
    // tests/artifacts/Arrays/static_size.py:52
    // assert path[i].other.d.bar == (i + 1) * (i + 1)
    swap
    extract 8 8
    dig 1
    dig 2
    *
    itob
    b==
    assert
    frame_bury 9
    b test_array_for_header@1

test_array_after_for@4:
    frame_dig 8
    // tests/artifacts/Arrays/static_size.py:54
    // Box(ImmutableArray[Point], key="a").value = path.freeze()
    dup
    len
    intc 4 // 144
    /
    dup
    frame_bury 2
    itob
    extract 6 2
    dig 1
    concat
    pushbytes "a"
    box_del
    pop
    pushbytes "a"
    swap
    box_put
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    extract 0 144 // on error: index access is out of bounds
    dup
    frame_bury 0
    dup
    extract 0 8
    frame_bury 1
    intc_2 // 8
    extract_uint64
    frame_bury 4
    // tests/artifacts/Arrays/static_size.py:168
    // length = UInt64()
    intc_0 // 0
    frame_bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    intc_1 // 1
    frame_bury 7

test_array_for_header@6:
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    frame_dig 7
    frame_dig 2
    <
    bz test_array_after_for@14
    frame_dig 8
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    frame_dig 7
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    dupn 2
    extract 0 8
    swap
    intc_2 // 8
    extract_uint64
    frame_bury 6
    // tests/artifacts/Arrays/static_size.py:171
    // if point.x < last_point.x:
    frame_dig 1
    b<
    bz test_array_else_body@9
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.native - point.x.native
    frame_dig 0
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.native - point.x.native
    extract_uint64
    swap
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.native - point.x.native
    extract_uint64
    -
    frame_bury 3

test_array_after_if_else@10:
    // tests/artifacts/Arrays/static_size.py:175
    // if point.y < last_point.y:
    frame_dig 6
    frame_dig 4
    <
    bz test_array_else_body@12
    // tests/artifacts/Arrays/static_size.py:176
    // dy = last_point.y - point.y
    frame_dig 4
    frame_dig 6
    -

test_array_after_if_else@13:
    // tests/artifacts/Arrays/static_size.py:179
    // length += op.sqrt(dx * dx + dy * dy)
    frame_dig 3
    dup
    *
    swap
    dup
    *
    +
    sqrt
    frame_dig 5
    +
    frame_bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    frame_dig 7
    intc_1 // 1
    +
    frame_bury 7
    b test_array_for_header@6

test_array_else_body@12:
    // tests/artifacts/Arrays/static_size.py:178
    // dy = point.y - last_point.y
    frame_dig 6
    frame_dig 4
    -
    b test_array_after_if_else@13

test_array_else_body@9:
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.native - last_point.x.native
    extract_uint64
    frame_dig 0
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.native - last_point.x.native
    extract_uint64
    -
    frame_bury 3
    b test_array_after_if_else@10

test_array_after_for@14:
    // tests/artifacts/Arrays/static_size.py:55
    // return path_length(path)
    frame_dig 5
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple(some_more.0: bytes, some_more.1: bytes) -> bytes:
test_extend_from_tuple:
    // tests/artifacts/Arrays/static_size.py:57-58
    // @arc4.abimethod()
    // def test_extend_from_tuple(self, some_more: tuple[More, More]) -> ImmutableArray[More]:
    proto 2 1
    // tests/artifacts/Arrays/static_size.py:60
    // arr.extend(some_more)
    frame_dig -2
    frame_dig -1
    concat
    // tests/artifacts/Arrays/static_size.py:61
    // last = arr[-1]
    dup
    len
    intc_3 // 16
    /
    dup
    intc_1 // 1
    -
    intc_3 // 16
    *
    dig 2
    swap
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:62
    // assert last == some_more[1]
    dup
    frame_dig -1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:63
    // result = arr.freeze()
    swap
    itob
    extract 6 2
    uncover 2
    concat
    // tests/artifacts/Arrays/static_size.py:64
    // assert result[-1] == last
    dup
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 16
    *
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    uncover 2
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:65
    // return result
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple(some_more: bytes) -> bytes:
test_extend_from_arc4_tuple:
    // tests/artifacts/Arrays/static_size.py:67-70
    // @arc4.abimethod()
    // def test_extend_from_arc4_tuple(
    //     self, some_more: arc4.Tuple[More, More]
    // ) -> ImmutableArray[More]:
    proto 1 1
    // tests/artifacts/Arrays/static_size.py:72
    // arr.extend(some_more)
    frame_dig -1
    pop
    // tests/artifacts/Arrays/static_size.py:73
    // return arr.freeze()
    frame_dig -1
    len
    intc_3 // 16
    /
    itob
    extract 6 2
    frame_dig -1
    concat
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array(length: uint64) -> uint64:
test_bool_array:
    // tests/artifacts/Arrays/static_size.py:75-76
    // @arc4.abimethod()
    // def test_bool_array(self, length: UInt64) -> UInt64:
    proto 1 1
    bytec_3 // ""
    // tests/artifacts/Arrays/static_size.py:77
    // arr = ReferenceArray[bool]()
    dupn 4
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    frame_dig -1
    intc_1 // 1
    +
    intc_1 // 1

test_bool_array_for_header@1:
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    frame_dig 6
    frame_dig 5
    <
    bz test_bool_array_after_for@4
    // tests/artifacts/Arrays/static_size.py:81
    // arr.append(i % 2 == 0)
    frame_dig 6
    dup
    pushint 2 // 2
    %
    !
    frame_dig 4
    swap
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    frame_bury 4
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    frame_bury 6
    b test_bool_array_for_header@1

test_bool_array_after_for@4:
    frame_dig 4
    dupn 2
    // tests/artifacts/Arrays/static_size.py:82
    // assert arr.length == length, "expected correct length"
    len
    frame_dig -1
    ==
    assert // expected correct length
    dig 1
    // tests/artifacts/Arrays/static_size.py:85
    // arr2.extend(arr)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/static_size.py:86
    // assert arr2.length == length * 2, "expected correct length"
    len
    frame_dig -1
    pushint 2 // 2
    *
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:88
    // count = UInt64(0)
    intc_0 // 0
    frame_bury 1
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 3

test_bool_array_for_header@5:
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    frame_dig 3
    frame_dig 0
    <
    bz test_bool_array_after_for@10
    frame_dig 4
    frame_dig 3
    intc_1 // 1
    extract3 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    frame_dig 1
    frame_bury 2
    // tests/artifacts/Arrays/static_size.py:90
    // if val:
    bz test_bool_array_after_if_else@8
    // tests/artifacts/Arrays/static_size.py:91
    // count += 1
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 2

test_bool_array_after_if_else@8:
    frame_dig 2
    frame_bury 1
    frame_dig 3
    intc_1 // 1
    +
    frame_bury 3
    b test_bool_array_for_header@5

test_bool_array_after_for@10:
    // tests/artifacts/Arrays/static_size.py:92
    // return count
    frame_dig 1
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion(length: uint64) -> bytes:
test_arc4_conversion:
    // tests/artifacts/Arrays/static_size.py:94-95
    // @arc4.abimethod()
    // def test_arc4_conversion(self, length: UInt64) -> arc4.DynamicArray[arc4.UInt64]:
    proto 1 1
    bytec_3 // ""
    // tests/artifacts/Arrays/static_size.py:96
    // arr = ReferenceArray[arc4.UInt64]()
    dupn 4
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    frame_dig -1
    intc_1 // 1
    +
    intc_1 // 1

test_arc4_conversion_for_header@1:
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    frame_dig 6
    frame_dig 5
    <
    bz test_arc4_conversion_after_for@4
    // tests/artifacts/Arrays/static_size.py:100
    // arr.append(arc4.UInt64(i))
    frame_dig 6
    dup
    itob
    frame_dig 4
    swap
    concat // on error: max array length exceeded
    frame_bury 4
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    frame_bury 6
    b test_arc4_conversion_for_header@1

test_arc4_conversion_after_for@4:
    frame_dig 4
    // tests/artifacts/Arrays/static_size.py:101
    // assert arr.length == length, "expected correct length"
    len
    intc_2 // 8
    /
    dup
    frame_bury 0
    frame_dig -1
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:102
    // count = UInt64(0)
    intc_0 // 0
    frame_bury 1
    intc_0 // 0
    frame_bury 3

test_arc4_conversion_for_header@5:
    // tests/artifacts/Arrays/static_size.py:103
    // for val in arr:
    frame_dig 3
    frame_dig 0
    <
    bz test_arc4_conversion_after_for@10
    frame_dig 4
    frame_dig 3
    intc_2 // 8
    *
    intc_2 // 8
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:104
    // if val:
    bytec_3 // 0x
    b!=
    frame_dig 1
    frame_bury 2
    bz test_arc4_conversion_after_if_else@8
    // tests/artifacts/Arrays/static_size.py:105
    // count += 1
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 2

test_arc4_conversion_after_if_else@8:
    frame_dig 2
    frame_bury 1
    frame_dig 3
    intc_1 // 1
    +
    frame_bury 3
    b test_arc4_conversion_for_header@5

test_arc4_conversion_after_for@10:
    // tests/artifacts/Arrays/static_size.py:107
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    bytec 4 // 0x0000
    frame_dig 4
    // tests/artifacts/Arrays/static_size.py:108
    // arc4_arr.extend(arr)
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_2 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/static_size.py:110
    // return arc4_arr
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array(arc4_arr: bytes) -> uint64:
sum_array:
    // tests/artifacts/Arrays/static_size.py:112-113
    // @arc4.abimethod()
    // def sum_array(self, arc4_arr: arc4.DynamicArray[arc4.UInt64]) -> UInt64:
    proto 1 1
    // tests/artifacts/Arrays/static_size.py:115
    // arr.extend(arc4_arr)
    frame_dig -1
    extract 2 0
    dup
    // tests/artifacts/Arrays/static_size.py:117
    // total = UInt64(0)
    intc_0 // 0
    swap
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    len
    intc_2 // 8
    /
    intc_0 // 0

sum_array_for_header@1:
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    frame_dig 3
    frame_dig 2
    <
    bz sum_array_after_for@4
    frame_dig 0
    frame_dig 3
    dup
    cover 2
    intc_2 // 8
    *
    // tests/artifacts/Arrays/static_size.py:119
    // total += item.native
    extract_uint64
    frame_dig 1
    +
    frame_bury 1
    intc_1 // 1
    +
    frame_bury 3
    b sum_array_for_header@1

sum_array_after_for@4:
    // tests/artifacts/Arrays/static_size.py:121
    // return total
    frame_dig 1
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes:
xtra:
    // tests/artifacts/Arrays/static_size.py:125
    // self.count += 1
    intc_0 // 0
    bytec_1 // "count"
    app_global_get_ex
    assert // check self.count exists
    intc_1 // 1
    +
    bytec_1 // "count"
    dig 1
    app_global_put
    // tests/artifacts/Arrays/static_size.py:127
    // a=Txn.num_app_args,
    txn NumAppArgs
    // tests/artifacts/Arrays/static_size.py:129
    // c=Txn.sender,
    txn Sender
    // tests/artifacts/Arrays/static_size.py:130
    // d=self.more(),
    callsub more
    // tests/artifacts/Arrays/static_size.py:131
    // e=BigUInt(self.count),
    intc_0 // 0
    bytec_1 // "count"
    app_global_get_ex
    assert // check self.count exists
    itob
    // tests/artifacts/Arrays/static_size.py:126-132
    // return Xtra(
    //     a=Txn.num_app_args,
    //     b=self.count,
    //     c=Txn.sender,
    //     d=self.more(),
    //     e=BigUInt(self.count),
    // )
    uncover 3
    cover 4
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes:
more:
    // tests/artifacts/Arrays/static_size.py:136
    // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count))
    intc_0 // 0
    bytec_1 // "count"
    app_global_get_ex
    assert // check self.count exists
    dup
    intc_1 // 1
    +
    itob
    dig 1
    uncover 2
    *
    itob
    concat
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool() -> bytes:
test_arc4_bool:
    // tests/artifacts/Arrays/static_size.py:138-139
    // @arc4.abimethod()
    // def test_arc4_bool(self) -> ImmutableArray[arc4.Bool]:
    proto 0 1
    // tests/artifacts/Arrays/static_size.py:141
    // arr.append(arc4.Bool(Txn.sender == Txn.receiver))
    txn Sender
    txn Receiver
    ==
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/Arrays/static_size.py:142
    // arr.append(arc4.Bool(Txn.sender != Txn.receiver))
    txn Sender
    txn Receiver
    !=
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    dupn 2
    uncover 2
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    dup
    len
    // tests/artifacts/Arrays/static_size.py:144
    // dyn_arr = arc4.DynamicArray[arc4.Bool]()
    bytec 4 // 0x0000
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    dup
    cover 2
    // tests/artifacts/Arrays/static_size.py:146
    // assert dyn_arr.length == 2, "expected correct length"
    dup
    intc_0 // 0
    extract_uint16
    dup
    cover 3
    dup
    pushint 2 // 2
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:147
    // assert dyn_arr.bytes.length == 3, "expected 3 bytes"
    dig 1
    len
    pushint 3 // 3
    ==
    assert // expected 3 bytes
    // tests/artifacts/Arrays/static_size.py:148
    // assert dyn_arr[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    assert // index access is out of bounds
    dig 1
    intc_3 // 16
    getbit
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:149
    // assert dyn_arr[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    intc_1 // 1
    >
    assert // index access is out of bounds
    pushint 17 // 17
    getbit
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    intc_0 // 0

test_arc4_bool_for_header@1:
    // tests/artifacts/Arrays/static_size.py:152-154
    // # note: not supported currently
    // # arr2.extend(dyn_array)
    // for b in dyn_arr:
    frame_dig 4
    frame_dig 2
    <
    bz test_arc4_bool_after_for@4
    frame_dig 4
    dup
    intc_3 // 16
    +
    frame_dig 1
    swap
    getbit
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    frame_dig 3
    // tests/artifacts/Arrays/static_size.py:155
    // arr2.append(b)
    swap
    concat // on error: max array length exceeded
    frame_bury 3
    intc_1 // 1
    +
    frame_bury 4
    b test_arc4_bool_for_header@1

test_arc4_bool_after_for@4:
    frame_dig 3
    // tests/artifacts/Arrays/static_size.py:156
    // assert arr2.length == 4, "expected correct length"
    dup
    len
    pushint 4 // 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:157
    // assert arr2[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    extract 0 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:158
    // assert arr2[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    dup
    extract 1 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    // tests/artifacts/Arrays/static_size.py:159
    // assert arr2[2] == (Txn.sender == Txn.receiver), "expected correct value at 2"
    dup
    extract 2 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 2
    // tests/artifacts/Arrays/static_size.py:160
    // assert arr2[3] == (Txn.sender != Txn.receiver), "expected correct value at 3"
    extract 3 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 3
    frame_dig 0
    // tests/artifacts/Arrays/static_size.py:162
    // return arr.freeze()
    dup
    len
    bytec 4 // 0x0000
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    frame_bury 0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.Arrays.static_size.StaticSizeContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 8 16 144
    bytecblock 0x 0x151f7c75 "count" 0x00 0x0000
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/Arrays/static_size.py:39
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put

main_after_if_else@2:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@14
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]"
    txna ApplicationArgs 0
    match test_array test_extend_from_tuple test_extend_from_arc4_tuple test_bool_array test_arc4_conversion sum_array test_arc4_bool
    err

main___algopy_default_create@14:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_0 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    cover 2
    swap
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    uncover 2
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    cover 2
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 4

dynamic_array_concat_bits_after_if_else@2:
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    intc_3 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array[routing]() -> void:
test_array:
    intc_0 // 0
    dup
    bytec_0 // ""
    dupn 5
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/Arrays/static_size.py:43
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put
    // tests/artifacts/Arrays/static_size.py:45
    // Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:46
    // Point(x=x1, y=y1, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:47
    // Point(x=x2, y=y2, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:44-48
    // path = ReferenceArray(
    //     Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    //     Point(x=x1, y=y1, other=self.xtra()),
    //     Point(x=x2, y=y2, other=self.xtra()),
    // )
    uncover 14
    itob
    uncover 14
    itob
    concat
    uncover 13
    concat
    uncover 12
    concat
    dig 11
    len
    pushint 64 // 64
    <=
    assert // overflow
    pushint 64 // 64
    bzero
    uncover 12
    dig 1
    b|
    uncover 2
    swap
    concat
    pushbytes 0x00000000000000000000000000000000
    swap
    concat
    uncover 14
    itob
    uncover 15
    swap
    concat
    uncover 12
    itob
    uncover 12
    itob
    concat
    uncover 11
    concat
    uncover 10
    concat
    dig 9
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 9
    dig 4
    b|
    concat
    concat
    concat
    uncover 7
    itob
    uncover 8
    swap
    concat
    uncover 7
    itob
    uncover 7
    itob
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 4
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 4
    uncover 4
    b|
    concat
    concat
    concat
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    intc_0 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    dup
    pushint 3 // 3
    <
    bz test_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:50
    // assert path[i].other.b == i + 1
    dup2
    dup
    cover 2
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    extract 16 128
    dup
    intc_2 // 8
    extract_uint64
    dig 2
    intc_1 // 1
    +
    swap
    dig 1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:51
    // assert path[i].other.d.foo == i + 2
    swap
    extract 48 16
    dup
    extract 0 8
    uncover 3
    pushint 2 // 2
    +
    itob
    b==
    assert
    // tests/artifacts/Arrays/static_size.py:52
    // assert path[i].other.d.bar == (i + 1) * (i + 1)
    extract 8 8
    dig 1
    dig 2
    *
    itob
    b==
    assert
    bury 1
    b test_array_for_header@2

test_array_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:54
    // Box(ImmutableArray[Point], key="a").value = path.freeze()
    dup
    len
    intc 4 // 144
    /
    dup
    bury 10
    itob
    extract 6 2
    dig 1
    concat
    pushbytes "a"
    box_del
    pop
    pushbytes "a"
    swap
    box_put
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    extract 0 144 // on error: index access is out of bounds
    dup
    bury 11
    dup
    extract 0 8
    bury 10
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:168
    // length = UInt64()
    intc_0 // 0
    bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    intc_1 // 1
    bury 3

test_array_for_header@7:
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    dig 2
    dig 8
    <
    bz test_array_after_for@15
    dig 1
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    dig 3
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    dupn 2
    extract 0 8
    swap
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:171
    // if point.x < last_point.x:
    dig 10
    b<
    bz test_array_else_body@10
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    dig 10
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    swap
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    -
    bury 7

test_array_after_if_else@11:
    // tests/artifacts/Arrays/static_size.py:175
    // if point.y < last_point.y:
    dig 3
    dig 6
    <
    bz test_array_else_body@13
    // tests/artifacts/Arrays/static_size.py:176
    // dy = last_point.y - point.y
    dig 5
    dig 4
    -

test_array_after_if_else@14:
    // tests/artifacts/Arrays/static_size.py:179
    // length += op.sqrt(dx * dx + dy * dy)
    dig 7
    dup
    *
    swap
    dup
    *
    +
    sqrt
    dig 5
    +
    bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    dig 2
    intc_1 // 1
    +
    bury 3
    b test_array_for_header@7

test_array_else_body@13:
    // tests/artifacts/Arrays/static_size.py:178
    // dy = point.y - last_point.y
    dig 3
    dig 6
    -
    b test_array_after_if_else@14

test_array_else_body@10:
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    dig 10
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    -
    bury 7
    b test_array_after_if_else@11

test_array_after_for@15:
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    dig 4
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple[routing]() -> void:
test_extend_from_tuple:
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    extract 0 16
    swap
    extract 16 16
    // tests/artifacts/Arrays/static_size.py:60
    // arr.extend(some_more)
    swap
    dig 1
    concat
    // tests/artifacts/Arrays/static_size.py:61
    // last = arr[-1]
    dup
    len
    intc_3 // 16
    /
    dup
    intc_1 // 1
    -
    intc_3 // 16
    *
    dig 2
    swap
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:62
    // assert last == some_more[1]
    dup
    uncover 4
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:63
    // result = arr.freeze()
    swap
    itob
    extract 6 2
    uncover 2
    concat
    // tests/artifacts/Arrays/static_size.py:64
    // assert result[-1] == last
    dup
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 16
    *
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    uncover 2
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple[routing]() -> void:
test_extend_from_arc4_tuple:
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:72
    // arr.extend(some_more)
    dup
    pop
    // tests/artifacts/Arrays/static_size.py:73
    // return arr.freeze()
    dup
    len
    intc_3 // 16
    /
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array[routing]() -> void:
test_bool_array:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:77
    // arr = ReferenceArray[bool]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_bool_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_bool_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:81
    // arr.append(i % 2 == 0)
    dupn 2
    pushint 2 // 2
    %
    !
    dig 4
    swap
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_bool_array_for_header@2

test_bool_array_after_for@5:
    dig 2
    dupn 2
    // tests/artifacts/Arrays/static_size.py:82
    // assert arr.length == length, "expected correct length"
    len
    dig 6
    dup
    cover 4
    ==
    assert // expected correct length
    dig 1
    // tests/artifacts/Arrays/static_size.py:85
    // arr2.extend(arr)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/static_size.py:86
    // assert arr2.length == length * 2, "expected correct length"
    len
    uncover 2
    pushint 2 // 2
    *
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:88
    // count = UInt64(0)
    intc_0 // 0
    bury 7
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    len
    bury 7
    intc_0 // 0
    bury 5

test_bool_array_for_header@6:
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_bool_array_after_for@11
    dig 2
    dig 5
    intc_1 // 1
    extract3 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    // tests/artifacts/Arrays/static_size.py:90
    // if val:
    bz test_bool_array_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:91
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_bool_array_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_bool_array_for_header@6

test_bool_array_after_for@11:
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    dig 5
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion[routing]() -> void:
test_arc4_conversion:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:96
    // arr = ReferenceArray[arc4.UInt64]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_arc4_conversion_for_header@2:
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_arc4_conversion_after_for@5
    // tests/artifacts/Arrays/static_size.py:100
    // arr.append(arc4.UInt64(i))
    dupn 2
    itob
    dig 4
    swap
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_arc4_conversion_for_header@2

test_arc4_conversion_after_for@5:
    dig 2
    // tests/artifacts/Arrays/static_size.py:101
    // assert arr.length == length, "expected correct length"
    len
    intc_2 // 8
    /
    dup
    bury 8
    dig 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:102
    // count = UInt64(0)
    intc_0 // 0
    bury 6
    intc_0 // 0
    bury 5

test_arc4_conversion_for_header@6:
    // tests/artifacts/Arrays/static_size.py:103
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_arc4_conversion_after_for@11
    dig 2
    dig 5
    intc_2 // 8
    *
    intc_2 // 8
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:104
    // if val:
    bytec_0 // 0x
    b!=
    bz test_arc4_conversion_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:105
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_arc4_conversion_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_arc4_conversion_for_header@6

test_arc4_conversion_after_for@11:
    // tests/artifacts/Arrays/static_size.py:107
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    bytec 4 // 0x0000
    dig 3
    // tests/artifacts/Arrays/static_size.py:108
    // arc4_arr.extend(arr)
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_2 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array[routing]() -> void:
sum_array:
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:115
    // arr.extend(arc4_arr)
    extract 2 0
    dup
    // tests/artifacts/Arrays/static_size.py:117
    // total = UInt64(0)
    intc_0 // 0
    swap
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    len
    intc_2 // 8
    /
    intc_0 // 0

sum_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    dup
    dig 2
    <
    bz sum_array_after_for@5
    dig 3
    dig 1
    dup
    cover 2
    intc_2 // 8
    *
    // tests/artifacts/Arrays/static_size.py:119
    // total += item.as_uint64()
    extract_uint64
    dig 4
    +
    bury 4
    intc_1 // 1
    +
    bury 1
    b sum_array_for_header@2

sum_array_after_for@5:
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    dig 2
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool[routing]() -> void:
test_arc4_bool:
    // tests/artifacts/Arrays/static_size.py:141
    // arr.append(arc4.Bool(Txn.sender == Txn.receiver))
    txn Sender
    txn Receiver
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/Arrays/static_size.py:142
    // arr.append(arc4.Bool(Txn.sender != Txn.receiver))
    txn Sender
    txn Receiver
    !=
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    dupn 2
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    len
    // tests/artifacts/Arrays/static_size.py:144
    // dyn_arr = arc4.DynamicArray[arc4.Bool]()
    bytec 4 // 0x0000
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    dig 2
    uncover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    dup
    cover 2
    // tests/artifacts/Arrays/static_size.py:146
    // assert dyn_arr.length == 2, "expected correct length"
    dup
    intc_0 // 0
    extract_uint16
    dup
    cover 3
    dup
    pushint 2 // 2
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:147
    // assert dyn_arr.bytes.length == 3, "expected 3 bytes"
    dig 1
    len
    pushint 3 // 3
    ==
    assert // expected 3 bytes
    // tests/artifacts/Arrays/static_size.py:148
    // assert dyn_arr[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    assert // index access is out of bounds
    dig 1
    intc_3 // 16
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:149
    // assert dyn_arr[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    intc_1 // 1
    >
    assert // index access is out of bounds
    pushint 17 // 17
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    intc_0 // 0

test_arc4_bool_for_header@2:
    // tests/artifacts/Arrays/static_size.py:152-154
    // # note: not supported currently
    // # arr2.extend(dyn_array)
    // for b in dyn_arr:
    dup
    dig 3
    <
    bz test_arc4_bool_after_for@5
    dupn 2
    intc_3 // 16
    +
    dig 5
    swap
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    // tests/artifacts/Arrays/static_size.py:155
    // arr2.append(b)
    swap
    concat // on error: max array length exceeded
    bury 3
    intc_1 // 1
    +
    bury 1
    b test_arc4_bool_for_header@2

test_arc4_bool_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:156
    // assert arr2.length == 4, "expected correct length"
    dup
    len
    pushint 4 // 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:157
    // assert arr2[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    extract 0 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:158
    // assert arr2[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    dup
    extract 1 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    // tests/artifacts/Arrays/static_size.py:159
    // assert arr2[2] == (Txn.sender == Txn.receiver), "expected correct value at 2"
    dup
    extract 2 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 2
    // tests/artifacts/Arrays/static_size.py:160
    // assert arr2[3] == (Txn.sender != Txn.receiver), "expected correct value at 3"
    extract 3 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 3
    dig 4
    // tests/artifacts/Arrays/static_size.py:162
    // return arr.freeze()
    dup
    len
    bytec 4 // 0x0000
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    // tests/artifacts/Arrays/static_size.py:138
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes:
xtra:
    // tests/artifacts/Arrays/static_size.py:125
    // self.count += 1
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    intc_1 // 1
    +
    bytec_2 // "count"
    dig 1
    app_global_put
    // tests/artifacts/Arrays/static_size.py:127
    // a=Txn.num_app_args,
    txn NumAppArgs
    // tests/artifacts/Arrays/static_size.py:129
    // c=Txn.sender,
    txn Sender
    // tests/artifacts/Arrays/static_size.py:130
    // d=self.more(),
    callsub more
    // tests/artifacts/Arrays/static_size.py:131
    // e=BigUInt(self.count),
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    itob
    // tests/artifacts/Arrays/static_size.py:126-132
    // return Xtra(
    //     a=Txn.num_app_args,
    //     b=self.count,
    //     c=Txn.sender,
    //     d=self.more(),
    //     e=BigUInt(self.count),
    // )
    uncover 3
    cover 4
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes:
more:
    // tests/artifacts/Arrays/static_size.py:136
    // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count))
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    dup
    intc_1 // 1
    +
    itob
    dig 1
    uncover 2
    *
    itob
    concat
    retsub
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json b/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json index 3120e6a..9e637ef 100644 --- a/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json +++ b/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json @@ -201,118 +201,100 @@ "sourceInfo": [ { "pc": [ - 102, - 118, - 138, - 158, - 179, - 198, - 225 + 44 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 261 + 112 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 105, - 121, - 141, - 161, - 182, - 201, - 228 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 1125, - 1142, - 1152 + 1190, + 1207, + 1217 ], "errorMessage": "check self.count exists" }, { "pc": [ - 1223 + 1035 ], "errorMessage": "expected 3 bytes" }, { "pc": [ - 885, - 896, - 1000, - 1216, - 1307 + 752, + 763, + 863, + 1028, + 1117 ], "errorMessage": "expected correct length" }, { "pc": [ - 1243, - 1320 + 1055, + 1130 ], "errorMessage": "expected correct value at 0" }, { "pc": [ - 1263, - 1333 + 1075, + 1143 ], "errorMessage": "expected correct value at 1" }, { "pc": [ - 1346 + 1156 ], "errorMessage": "expected correct value at 2" }, { "pc": [ - 1358 + 1168 ], "errorMessage": "expected correct value at 3" }, { "pc": [ - 554, - 632, - 671, - 780, - 808, - 919, - 1022, - 1225, - 1246, - 1309, - 1322, - 1335, - 1347 + 403, + 478, + 517, + 637, + 665, + 786, + 885, + 1037, + 1058, + 1119, + 1132, + 1145, + 1157 ], "errorMessage": "index access is out of bounds" }, { "pc": [ - 867, - 888, - 979, - 1055, - 1188, - 1290 + 731, + 755, + 842, + 910, + 1001, + 1100 ], "errorMessage": "max array length exceeded" }, { "pc": [ - 430, - 489, - 524 + 283, + 342, + 377 ], "errorMessage": "overflow" } @@ -325,18 +307,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.Arrays.static_size.StaticSizeContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 8 16 144
    bytecblock 0x151f7c75 "count" 0x00 0x 0x0000
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/Arrays/static_size.py:39
    // self.count = UInt64(0)
    bytec_1 // "count"
    intc_0 // 0
    app_global_put

main_after_if_else@2:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@12
    pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]"
    txna ApplicationArgs 0
    match main_test_array_route@5 main_test_extend_from_tuple_route@6 main_test_extend_from_arc4_tuple_route@7 main_test_bool_array_route@8 main_test_arc4_conversion_route@9 main_sum_array_route@10 main_test_arc4_bool_route@11

main_after_if_else@14:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    intc_0 // 0
    return

main_test_arc4_bool_route@11:
    // tests/artifacts/Arrays/static_size.py:138
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub test_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_sum_array_route@10:
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    callsub sum_array
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_arc4_conversion_route@9:
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    callsub test_arc4_conversion
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_bool_array_route@8:
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    callsub test_bool_array
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_extend_from_arc4_tuple_route@7:
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    callsub test_extend_from_arc4_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_extend_from_tuple_route@6:
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    dup
    extract 0 16
    swap
    extract 16 16
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    callsub test_extend_from_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_test_array_route@5:
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    callsub test_array
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_bare_routing@12:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@14
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_3 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    dup
    uncover 2
    uncover 3
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    cover 3
    swap
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    cover 3
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 7

dynamic_array_concat_bits_after_if_else@2:
    frame_dig 7
    frame_bury 4
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    intc_3 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array(x1: bytes, y1: uint64, x2: bytes, y2: uint64) -> uint64:
test_array:
    // tests/artifacts/Arrays/static_size.py:41-42
    // @arc4.abimethod()
    // def test_array(self, x1: arc4.UInt64, y1: UInt64, x2: arc4.UInt64, y2: UInt64) -> UInt64:
    proto 4 1
    intc_0 // 0
    dup
    bytec_3 // ""
    dupn 5
    // tests/artifacts/Arrays/static_size.py:43
    // self.count = UInt64(0)
    bytec_1 // "count"
    intc_0 // 0
    app_global_put
    // tests/artifacts/Arrays/static_size.py:45
    // Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:46
    // Point(x=x1, y=y1, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:47
    // Point(x=x2, y=y2, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:44-48
    // path = ReferenceArray(
    //     Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    //     Point(x=x1, y=y1, other=self.xtra()),
    //     Point(x=x2, y=y2, other=self.xtra()),
    // )
    uncover 14
    itob
    uncover 14
    itob
    concat
    uncover 13
    concat
    uncover 12
    concat
    dig 11
    len
    pushint 64 // 64
    <=
    assert // overflow
    pushint 64 // 64
    bzero
    uncover 12
    dig 1
    b|
    uncover 2
    swap
    concat
    pushbytes 0x00000000000000000000000000000000
    swap
    concat
    frame_dig -3
    itob
    frame_dig -4
    swap
    concat
    uncover 12
    itob
    uncover 12
    itob
    concat
    uncover 11
    concat
    uncover 10
    concat
    dig 9
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 9
    dig 4
    b|
    concat
    concat
    concat
    frame_dig -1
    itob
    frame_dig -2
    swap
    concat
    uncover 7
    itob
    uncover 7
    itob
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 4
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 4
    uncover 4
    b|
    concat
    concat
    concat
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    intc_0 // 0

test_array_for_header@1:
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    frame_dig 9
    pushint 3 // 3
    <
    bz test_array_after_for@4
    frame_dig 8
    // tests/artifacts/Arrays/static_size.py:50
    // assert path[i].other.b == i + 1
    frame_dig 9
    dup
    cover 2
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    extract 16 128
    dup
    intc_2 // 8
    extract_uint64
    swap
    extract 48 16
    dig 2
    intc_1 // 1
    +
    uncover 2
    dig 1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:51
    // assert path[i].other.d.foo == i + 2
    dig 1
    extract 0 8
    uncover 3
    pushint 2 // 2
    +
    itob
    b==
    assert
    // tests/artifacts/Arrays/static_size.py:52
    // assert path[i].other.d.bar == (i + 1) * (i + 1)
    swap
    extract 8 8
    dig 1
    dig 2
    *
    itob
    b==
    assert
    frame_bury 9
    b test_array_for_header@1

test_array_after_for@4:
    frame_dig 8
    // tests/artifacts/Arrays/static_size.py:54
    // Box(ImmutableArray[Point], key="a").value = path.freeze()
    dup
    len
    intc 4 // 144
    /
    dup
    frame_bury 2
    itob
    extract 6 2
    dig 1
    concat
    pushbytes "a"
    box_del
    pop
    pushbytes "a"
    swap
    box_put
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    extract 0 144 // on error: index access is out of bounds
    dup
    frame_bury 0
    dup
    extract 0 8
    frame_bury 1
    intc_2 // 8
    extract_uint64
    frame_bury 4
    // tests/artifacts/Arrays/static_size.py:168
    // length = UInt64()
    intc_0 // 0
    frame_bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    intc_1 // 1
    frame_bury 7

test_array_for_header@6:
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    frame_dig 7
    frame_dig 2
    <
    bz test_array_after_for@14
    frame_dig 8
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    frame_dig 7
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    dupn 2
    extract 0 8
    swap
    intc_2 // 8
    extract_uint64
    frame_bury 6
    // tests/artifacts/Arrays/static_size.py:171
    // if point.x < last_point.x:
    frame_dig 1
    b<
    bz test_array_else_body@9
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.native - point.x.native
    frame_dig 0
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.native - point.x.native
    extract_uint64
    swap
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.native - point.x.native
    extract_uint64
    -
    frame_bury 3

test_array_after_if_else@10:
    // tests/artifacts/Arrays/static_size.py:175
    // if point.y < last_point.y:
    frame_dig 6
    frame_dig 4
    <
    bz test_array_else_body@12
    // tests/artifacts/Arrays/static_size.py:176
    // dy = last_point.y - point.y
    frame_dig 4
    frame_dig 6
    -

test_array_after_if_else@13:
    // tests/artifacts/Arrays/static_size.py:179
    // length += op.sqrt(dx * dx + dy * dy)
    frame_dig 3
    dup
    *
    swap
    dup
    *
    +
    sqrt
    frame_dig 5
    +
    frame_bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    frame_dig 7
    intc_1 // 1
    +
    frame_bury 7
    b test_array_for_header@6

test_array_else_body@12:
    // tests/artifacts/Arrays/static_size.py:178
    // dy = point.y - last_point.y
    frame_dig 6
    frame_dig 4
    -
    b test_array_after_if_else@13

test_array_else_body@9:
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.native - last_point.x.native
    extract_uint64
    frame_dig 0
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.native - last_point.x.native
    extract_uint64
    -
    frame_bury 3
    b test_array_after_if_else@10

test_array_after_for@14:
    // tests/artifacts/Arrays/static_size.py:55
    // return path_length(path)
    frame_dig 5
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple(some_more.0: bytes, some_more.1: bytes) -> bytes:
test_extend_from_tuple:
    // tests/artifacts/Arrays/static_size.py:57-58
    // @arc4.abimethod()
    // def test_extend_from_tuple(self, some_more: tuple[More, More]) -> ImmutableArray[More]:
    proto 2 1
    // tests/artifacts/Arrays/static_size.py:60
    // arr.extend(some_more)
    frame_dig -2
    frame_dig -1
    concat
    // tests/artifacts/Arrays/static_size.py:61
    // last = arr[-1]
    dup
    len
    intc_3 // 16
    /
    dup
    intc_1 // 1
    -
    intc_3 // 16
    *
    dig 2
    swap
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:62
    // assert last == some_more[1]
    dup
    frame_dig -1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:63
    // result = arr.freeze()
    swap
    itob
    extract 6 2
    uncover 2
    concat
    // tests/artifacts/Arrays/static_size.py:64
    // assert result[-1] == last
    dup
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 16
    *
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    uncover 2
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:65
    // return result
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple(some_more: bytes) -> bytes:
test_extend_from_arc4_tuple:
    // tests/artifacts/Arrays/static_size.py:67-70
    // @arc4.abimethod()
    // def test_extend_from_arc4_tuple(
    //     self, some_more: arc4.Tuple[More, More]
    // ) -> ImmutableArray[More]:
    proto 1 1
    // tests/artifacts/Arrays/static_size.py:72
    // arr.extend(some_more)
    frame_dig -1
    pop
    // tests/artifacts/Arrays/static_size.py:73
    // return arr.freeze()
    frame_dig -1
    len
    intc_3 // 16
    /
    itob
    extract 6 2
    frame_dig -1
    concat
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array(length: uint64) -> uint64:
test_bool_array:
    // tests/artifacts/Arrays/static_size.py:75-76
    // @arc4.abimethod()
    // def test_bool_array(self, length: UInt64) -> UInt64:
    proto 1 1
    bytec_3 // ""
    // tests/artifacts/Arrays/static_size.py:77
    // arr = ReferenceArray[bool]()
    dupn 4
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    frame_dig -1
    intc_1 // 1
    +
    intc_1 // 1

test_bool_array_for_header@1:
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    frame_dig 6
    frame_dig 5
    <
    bz test_bool_array_after_for@4
    // tests/artifacts/Arrays/static_size.py:81
    // arr.append(i % 2 == 0)
    frame_dig 6
    dup
    pushint 2 // 2
    %
    !
    frame_dig 4
    swap
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    frame_bury 4
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    frame_bury 6
    b test_bool_array_for_header@1

test_bool_array_after_for@4:
    frame_dig 4
    dupn 2
    // tests/artifacts/Arrays/static_size.py:82
    // assert arr.length == length, "expected correct length"
    len
    frame_dig -1
    ==
    assert // expected correct length
    dig 1
    // tests/artifacts/Arrays/static_size.py:85
    // arr2.extend(arr)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/static_size.py:86
    // assert arr2.length == length * 2, "expected correct length"
    len
    frame_dig -1
    pushint 2 // 2
    *
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:88
    // count = UInt64(0)
    intc_0 // 0
    frame_bury 1
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 3

test_bool_array_for_header@5:
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    frame_dig 3
    frame_dig 0
    <
    bz test_bool_array_after_for@10
    frame_dig 4
    frame_dig 3
    intc_1 // 1
    extract3 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    frame_dig 1
    frame_bury 2
    // tests/artifacts/Arrays/static_size.py:90
    // if val:
    bz test_bool_array_after_if_else@8
    // tests/artifacts/Arrays/static_size.py:91
    // count += 1
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 2

test_bool_array_after_if_else@8:
    frame_dig 2
    frame_bury 1
    frame_dig 3
    intc_1 // 1
    +
    frame_bury 3
    b test_bool_array_for_header@5

test_bool_array_after_for@10:
    // tests/artifacts/Arrays/static_size.py:92
    // return count
    frame_dig 1
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion(length: uint64) -> bytes:
test_arc4_conversion:
    // tests/artifacts/Arrays/static_size.py:94-95
    // @arc4.abimethod()
    // def test_arc4_conversion(self, length: UInt64) -> arc4.DynamicArray[arc4.UInt64]:
    proto 1 1
    bytec_3 // ""
    // tests/artifacts/Arrays/static_size.py:96
    // arr = ReferenceArray[arc4.UInt64]()
    dupn 4
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    frame_dig -1
    intc_1 // 1
    +
    intc_1 // 1

test_arc4_conversion_for_header@1:
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    frame_dig 6
    frame_dig 5
    <
    bz test_arc4_conversion_after_for@4
    // tests/artifacts/Arrays/static_size.py:100
    // arr.append(arc4.UInt64(i))
    frame_dig 6
    dup
    itob
    frame_dig 4
    swap
    concat // on error: max array length exceeded
    frame_bury 4
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    frame_bury 6
    b test_arc4_conversion_for_header@1

test_arc4_conversion_after_for@4:
    frame_dig 4
    // tests/artifacts/Arrays/static_size.py:101
    // assert arr.length == length, "expected correct length"
    len
    intc_2 // 8
    /
    dup
    frame_bury 0
    frame_dig -1
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:102
    // count = UInt64(0)
    intc_0 // 0
    frame_bury 1
    intc_0 // 0
    frame_bury 3

test_arc4_conversion_for_header@5:
    // tests/artifacts/Arrays/static_size.py:103
    // for val in arr:
    frame_dig 3
    frame_dig 0
    <
    bz test_arc4_conversion_after_for@10
    frame_dig 4
    frame_dig 3
    intc_2 // 8
    *
    intc_2 // 8
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:104
    // if val:
    bytec_3 // 0x
    b!=
    frame_dig 1
    frame_bury 2
    bz test_arc4_conversion_after_if_else@8
    // tests/artifacts/Arrays/static_size.py:105
    // count += 1
    frame_dig 1
    intc_1 // 1
    +
    frame_bury 2

test_arc4_conversion_after_if_else@8:
    frame_dig 2
    frame_bury 1
    frame_dig 3
    intc_1 // 1
    +
    frame_bury 3
    b test_arc4_conversion_for_header@5

test_arc4_conversion_after_for@10:
    // tests/artifacts/Arrays/static_size.py:107
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    bytec 4 // 0x0000
    frame_dig 4
    // tests/artifacts/Arrays/static_size.py:108
    // arc4_arr.extend(arr)
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_2 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/static_size.py:110
    // return arc4_arr
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array(arc4_arr: bytes) -> uint64:
sum_array:
    // tests/artifacts/Arrays/static_size.py:112-113
    // @arc4.abimethod()
    // def sum_array(self, arc4_arr: arc4.DynamicArray[arc4.UInt64]) -> UInt64:
    proto 1 1
    // tests/artifacts/Arrays/static_size.py:115
    // arr.extend(arc4_arr)
    frame_dig -1
    extract 2 0
    dup
    // tests/artifacts/Arrays/static_size.py:117
    // total = UInt64(0)
    intc_0 // 0
    swap
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    len
    intc_2 // 8
    /
    intc_0 // 0

sum_array_for_header@1:
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    frame_dig 3
    frame_dig 2
    <
    bz sum_array_after_for@4
    frame_dig 0
    frame_dig 3
    dup
    cover 2
    intc_2 // 8
    *
    // tests/artifacts/Arrays/static_size.py:119
    // total += item.native
    extract_uint64
    frame_dig 1
    +
    frame_bury 1
    intc_1 // 1
    +
    frame_bury 3
    b sum_array_for_header@1

sum_array_after_for@4:
    // tests/artifacts/Arrays/static_size.py:121
    // return total
    frame_dig 1
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes:
xtra:
    // tests/artifacts/Arrays/static_size.py:125
    // self.count += 1
    intc_0 // 0
    bytec_1 // "count"
    app_global_get_ex
    assert // check self.count exists
    intc_1 // 1
    +
    bytec_1 // "count"
    dig 1
    app_global_put
    // tests/artifacts/Arrays/static_size.py:127
    // a=Txn.num_app_args,
    txn NumAppArgs
    // tests/artifacts/Arrays/static_size.py:129
    // c=Txn.sender,
    txn Sender
    // tests/artifacts/Arrays/static_size.py:130
    // d=self.more(),
    callsub more
    // tests/artifacts/Arrays/static_size.py:131
    // e=BigUInt(self.count),
    intc_0 // 0
    bytec_1 // "count"
    app_global_get_ex
    assert // check self.count exists
    itob
    // tests/artifacts/Arrays/static_size.py:126-132
    // return Xtra(
    //     a=Txn.num_app_args,
    //     b=self.count,
    //     c=Txn.sender,
    //     d=self.more(),
    //     e=BigUInt(self.count),
    // )
    uncover 3
    cover 4
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes:
more:
    // tests/artifacts/Arrays/static_size.py:136
    // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count))
    intc_0 // 0
    bytec_1 // "count"
    app_global_get_ex
    assert // check self.count exists
    dup
    intc_1 // 1
    +
    itob
    dig 1
    uncover 2
    *
    itob
    concat
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool() -> bytes:
test_arc4_bool:
    // tests/artifacts/Arrays/static_size.py:138-139
    // @arc4.abimethod()
    // def test_arc4_bool(self) -> ImmutableArray[arc4.Bool]:
    proto 0 1
    // tests/artifacts/Arrays/static_size.py:141
    // arr.append(arc4.Bool(Txn.sender == Txn.receiver))
    txn Sender
    txn Receiver
    ==
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/Arrays/static_size.py:142
    // arr.append(arc4.Bool(Txn.sender != Txn.receiver))
    txn Sender
    txn Receiver
    !=
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    dupn 2
    uncover 2
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    dup
    len
    // tests/artifacts/Arrays/static_size.py:144
    // dyn_arr = arc4.DynamicArray[arc4.Bool]()
    bytec 4 // 0x0000
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    dup
    cover 2
    // tests/artifacts/Arrays/static_size.py:146
    // assert dyn_arr.length == 2, "expected correct length"
    dup
    intc_0 // 0
    extract_uint16
    dup
    cover 3
    dup
    pushint 2 // 2
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:147
    // assert dyn_arr.bytes.length == 3, "expected 3 bytes"
    dig 1
    len
    pushint 3 // 3
    ==
    assert // expected 3 bytes
    // tests/artifacts/Arrays/static_size.py:148
    // assert dyn_arr[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    assert // index access is out of bounds
    dig 1
    intc_3 // 16
    getbit
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:149
    // assert dyn_arr[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    intc_1 // 1
    >
    assert // index access is out of bounds
    pushint 17 // 17
    getbit
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    intc_0 // 0

test_arc4_bool_for_header@1:
    // tests/artifacts/Arrays/static_size.py:152-154
    // # note: not supported currently
    // # arr2.extend(dyn_array)
    // for b in dyn_arr:
    frame_dig 4
    frame_dig 2
    <
    bz test_arc4_bool_after_for@4
    frame_dig 4
    dup
    intc_3 // 16
    +
    frame_dig 1
    swap
    getbit
    bytec_2 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    frame_dig 3
    // tests/artifacts/Arrays/static_size.py:155
    // arr2.append(b)
    swap
    concat // on error: max array length exceeded
    frame_bury 3
    intc_1 // 1
    +
    frame_bury 4
    b test_arc4_bool_for_header@1

test_arc4_bool_after_for@4:
    frame_dig 3
    // tests/artifacts/Arrays/static_size.py:156
    // assert arr2.length == 4, "expected correct length"
    dup
    len
    pushint 4 // 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:157
    // assert arr2[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    extract 0 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:158
    // assert arr2[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    dup
    extract 1 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    // tests/artifacts/Arrays/static_size.py:159
    // assert arr2[2] == (Txn.sender == Txn.receiver), "expected correct value at 2"
    dup
    extract 2 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 2
    // tests/artifacts/Arrays/static_size.py:160
    // assert arr2[3] == (Txn.sender != Txn.receiver), "expected correct value at 3"
    extract 3 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 3
    frame_dig 0
    // tests/artifacts/Arrays/static_size.py:162
    // return arr.freeze()
    dup
    len
    bytec 4 // 0x0000
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    frame_bury 0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.Arrays.static_size.StaticSizeContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 8 16 144
    bytecblock 0x 0x151f7c75 "count" 0x00 0x0000
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/Arrays/static_size.py:39
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put

main_after_if_else@2:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@14
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]"
    txna ApplicationArgs 0
    match test_array test_extend_from_tuple test_extend_from_arc4_tuple test_bool_array test_arc4_conversion sum_array test_arc4_bool
    err

main___algopy_default_create@14:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_0 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    cover 2
    swap
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    uncover 2
    pushint 7 // 7
    +
    intc_2 // 8
    /
    dup
    cover 2
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 4

dynamic_array_concat_bits_after_if_else@2:
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    intc_3 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array[routing]() -> void:
test_array:
    intc_0 // 0
    dup
    bytec_0 // ""
    dupn 5
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/Arrays/static_size.py:43
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put
    // tests/artifacts/Arrays/static_size.py:45
    // Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:46
    // Point(x=x1, y=y1, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:47
    // Point(x=x2, y=y2, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:44-48
    // path = ReferenceArray(
    //     Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    //     Point(x=x1, y=y1, other=self.xtra()),
    //     Point(x=x2, y=y2, other=self.xtra()),
    // )
    uncover 14
    itob
    uncover 14
    itob
    concat
    uncover 13
    concat
    uncover 12
    concat
    dig 11
    len
    pushint 64 // 64
    <=
    assert // overflow
    pushint 64 // 64
    bzero
    uncover 12
    dig 1
    b|
    uncover 2
    swap
    concat
    pushbytes 0x00000000000000000000000000000000
    swap
    concat
    uncover 14
    itob
    uncover 15
    swap
    concat
    uncover 12
    itob
    uncover 12
    itob
    concat
    uncover 11
    concat
    uncover 10
    concat
    dig 9
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 9
    dig 4
    b|
    concat
    concat
    concat
    uncover 7
    itob
    uncover 8
    swap
    concat
    uncover 7
    itob
    uncover 7
    itob
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 4
    len
    pushint 64 // 64
    <=
    assert // overflow
    uncover 4
    uncover 4
    b|
    concat
    concat
    concat
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    intc_0 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:49
    // for i in urange(3):
    dup
    pushint 3 // 3
    <
    bz test_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:50
    // assert path[i].other.b == i + 1
    dup2
    dup
    cover 2
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    extract 16 128
    dup
    intc_2 // 8
    extract_uint64
    dig 2
    intc_1 // 1
    +
    swap
    dig 1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:51
    // assert path[i].other.d.foo == i + 2
    swap
    extract 48 16
    dup
    extract 0 8
    uncover 3
    pushint 2 // 2
    +
    itob
    b==
    assert
    // tests/artifacts/Arrays/static_size.py:52
    // assert path[i].other.d.bar == (i + 1) * (i + 1)
    extract 8 8
    dig 1
    dig 2
    *
    itob
    b==
    assert
    bury 1
    b test_array_for_header@2

test_array_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:54
    // Box(ImmutableArray[Point], key="a").value = path.freeze()
    dup
    len
    intc 4 // 144
    /
    dup
    bury 10
    itob
    extract 6 2
    dig 1
    concat
    pushbytes "a"
    box_del
    pop
    pushbytes "a"
    swap
    box_put
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    extract 0 144 // on error: index access is out of bounds
    dup
    bury 11
    dup
    extract 0 8
    bury 10
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:168
    // length = UInt64()
    intc_0 // 0
    bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    intc_1 // 1
    bury 3

test_array_for_header@7:
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    dig 2
    dig 8
    <
    bz test_array_after_for@15
    dig 1
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    dig 3
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    dupn 2
    extract 0 8
    swap
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:171
    // if point.x < last_point.x:
    dig 10
    b<
    bz test_array_else_body@10
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    dig 10
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    swap
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:172
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    -
    bury 7

test_array_after_if_else@11:
    // tests/artifacts/Arrays/static_size.py:175
    // if point.y < last_point.y:
    dig 3
    dig 6
    <
    bz test_array_else_body@13
    // tests/artifacts/Arrays/static_size.py:176
    // dy = last_point.y - point.y
    dig 5
    dig 4
    -

test_array_after_if_else@14:
    // tests/artifacts/Arrays/static_size.py:179
    // length += op.sqrt(dx * dx + dy * dy)
    dig 7
    dup
    *
    swap
    dup
    *
    +
    sqrt
    dig 5
    +
    bury 5
    // tests/artifacts/Arrays/static_size.py:169
    // for point_idx in urange(1, path.length):
    dig 2
    intc_1 // 1
    +
    bury 3
    b test_array_for_header@7

test_array_else_body@13:
    // tests/artifacts/Arrays/static_size.py:178
    // dy = point.y - last_point.y
    dig 3
    dig 6
    -
    b test_array_after_if_else@14

test_array_else_body@10:
    // tests/artifacts/Arrays/static_size.py:170
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    dig 10
    // tests/artifacts/Arrays/static_size.py:167
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    -
    bury 7
    b test_array_after_if_else@11

test_array_after_for@15:
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    dig 4
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple[routing]() -> void:
test_extend_from_tuple:
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    extract 0 16
    swap
    extract 16 16
    // tests/artifacts/Arrays/static_size.py:60
    // arr.extend(some_more)
    swap
    dig 1
    concat
    // tests/artifacts/Arrays/static_size.py:61
    // last = arr[-1]
    dup
    len
    intc_3 // 16
    /
    dup
    intc_1 // 1
    -
    intc_3 // 16
    *
    dig 2
    swap
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:62
    // assert last == some_more[1]
    dup
    uncover 4
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:63
    // result = arr.freeze()
    swap
    itob
    extract 6 2
    uncover 2
    concat
    // tests/artifacts/Arrays/static_size.py:64
    // assert result[-1] == last
    dup
    intc_0 // 0
    extract_uint16
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 16
    *
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    uncover 2
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:57
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple[routing]() -> void:
test_extend_from_arc4_tuple:
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:72
    // arr.extend(some_more)
    dup
    pop
    // tests/artifacts/Arrays/static_size.py:73
    // return arr.freeze()
    dup
    len
    intc_3 // 16
    /
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arrays/static_size.py:67
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array[routing]() -> void:
test_bool_array:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:77
    // arr = ReferenceArray[bool]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_bool_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_bool_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:81
    // arr.append(i % 2 == 0)
    dupn 2
    pushint 2 // 2
    %
    !
    dig 4
    swap
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:80
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_bool_array_for_header@2

test_bool_array_after_for@5:
    dig 2
    dupn 2
    // tests/artifacts/Arrays/static_size.py:82
    // assert arr.length == length, "expected correct length"
    len
    dig 6
    dup
    cover 4
    ==
    assert // expected correct length
    dig 1
    // tests/artifacts/Arrays/static_size.py:85
    // arr2.extend(arr)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/static_size.py:86
    // assert arr2.length == length * 2, "expected correct length"
    len
    uncover 2
    pushint 2 // 2
    *
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:88
    // count = UInt64(0)
    intc_0 // 0
    bury 7
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    len
    bury 7
    intc_0 // 0
    bury 5

test_bool_array_for_header@6:
    // tests/artifacts/Arrays/static_size.py:89
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_bool_array_after_for@11
    dig 2
    dig 5
    intc_1 // 1
    extract3 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    // tests/artifacts/Arrays/static_size.py:90
    // if val:
    bz test_bool_array_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:91
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_bool_array_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_bool_array_for_header@6

test_bool_array_after_for@11:
    // tests/artifacts/Arrays/static_size.py:75
    // @arc4.abimethod()
    dig 5
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion[routing]() -> void:
test_arc4_conversion:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:96
    // arr = ReferenceArray[arc4.UInt64]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_arc4_conversion_for_header@2:
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_arc4_conversion_after_for@5
    // tests/artifacts/Arrays/static_size.py:100
    // arr.append(arc4.UInt64(i))
    dupn 2
    itob
    dig 4
    swap
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:99
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_arc4_conversion_for_header@2

test_arc4_conversion_after_for@5:
    dig 2
    // tests/artifacts/Arrays/static_size.py:101
    // assert arr.length == length, "expected correct length"
    len
    intc_2 // 8
    /
    dup
    bury 8
    dig 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:102
    // count = UInt64(0)
    intc_0 // 0
    bury 6
    intc_0 // 0
    bury 5

test_arc4_conversion_for_header@6:
    // tests/artifacts/Arrays/static_size.py:103
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_arc4_conversion_after_for@11
    dig 2
    dig 5
    intc_2 // 8
    *
    intc_2 // 8
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:104
    // if val:
    bytec_0 // 0x
    b!=
    bz test_arc4_conversion_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:105
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_arc4_conversion_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_arc4_conversion_for_header@6

test_arc4_conversion_after_for@11:
    // tests/artifacts/Arrays/static_size.py:107
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    bytec 4 // 0x0000
    dig 3
    // tests/artifacts/Arrays/static_size.py:108
    // arc4_arr.extend(arr)
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_2 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/static_size.py:94
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array[routing]() -> void:
sum_array:
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:115
    // arr.extend(arc4_arr)
    extract 2 0
    dup
    // tests/artifacts/Arrays/static_size.py:117
    // total = UInt64(0)
    intc_0 // 0
    swap
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    len
    intc_2 // 8
    /
    intc_0 // 0

sum_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:118
    // for item in arr:
    dup
    dig 2
    <
    bz sum_array_after_for@5
    dig 3
    dig 1
    dup
    cover 2
    intc_2 // 8
    *
    // tests/artifacts/Arrays/static_size.py:119
    // total += item.as_uint64()
    extract_uint64
    dig 4
    +
    bury 4
    intc_1 // 1
    +
    bury 1
    b sum_array_for_header@2

sum_array_after_for@5:
    // tests/artifacts/Arrays/static_size.py:112
    // @arc4.abimethod()
    dig 2
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool[routing]() -> void:
test_arc4_bool:
    // tests/artifacts/Arrays/static_size.py:141
    // arr.append(arc4.Bool(Txn.sender == Txn.receiver))
    txn Sender
    txn Receiver
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/Arrays/static_size.py:142
    // arr.append(arc4.Bool(Txn.sender != Txn.receiver))
    txn Sender
    txn Receiver
    !=
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    dupn 2
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    len
    // tests/artifacts/Arrays/static_size.py:144
    // dyn_arr = arc4.DynamicArray[arc4.Bool]()
    bytec 4 // 0x0000
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr.extend(arr)
    dig 2
    uncover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    dup
    cover 2
    // tests/artifacts/Arrays/static_size.py:146
    // assert dyn_arr.length == 2, "expected correct length"
    dup
    intc_0 // 0
    extract_uint16
    dup
    cover 3
    dup
    pushint 2 // 2
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:147
    // assert dyn_arr.bytes.length == 3, "expected 3 bytes"
    dig 1
    len
    pushint 3 // 3
    ==
    assert // expected 3 bytes
    // tests/artifacts/Arrays/static_size.py:148
    // assert dyn_arr[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    assert // index access is out of bounds
    dig 1
    intc_3 // 16
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:149
    // assert dyn_arr[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    intc_1 // 1
    >
    assert // index access is out of bounds
    pushint 17 // 17
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    intc_0 // 0

test_arc4_bool_for_header@2:
    // tests/artifacts/Arrays/static_size.py:152-154
    // # note: not supported currently
    // # arr2.extend(dyn_array)
    // for b in dyn_arr:
    dup
    dig 3
    <
    bz test_arc4_bool_after_for@5
    dupn 2
    intc_3 // 16
    +
    dig 5
    swap
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    // tests/artifacts/Arrays/static_size.py:155
    // arr2.append(b)
    swap
    concat // on error: max array length exceeded
    bury 3
    intc_1 // 1
    +
    bury 1
    b test_arc4_bool_for_header@2

test_arc4_bool_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:156
    // assert arr2.length == 4, "expected correct length"
    dup
    len
    pushint 4 // 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:157
    // assert arr2[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    extract 0 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:158
    // assert arr2[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    dup
    extract 1 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    // tests/artifacts/Arrays/static_size.py:159
    // assert arr2[2] == (Txn.sender == Txn.receiver), "expected correct value at 2"
    dup
    extract 2 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 2
    // tests/artifacts/Arrays/static_size.py:160
    // assert arr2[3] == (Txn.sender != Txn.receiver), "expected correct value at 3"
    extract 3 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 3
    dig 4
    // tests/artifacts/Arrays/static_size.py:162
    // return arr.freeze()
    dup
    len
    bytec 4 // 0x0000
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    // tests/artifacts/Arrays/static_size.py:138
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes:
xtra:
    // tests/artifacts/Arrays/static_size.py:125
    // self.count += 1
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    intc_1 // 1
    +
    bytec_2 // "count"
    dig 1
    app_global_put
    // tests/artifacts/Arrays/static_size.py:127
    // a=Txn.num_app_args,
    txn NumAppArgs
    // tests/artifacts/Arrays/static_size.py:129
    // c=Txn.sender,
    txn Sender
    // tests/artifacts/Arrays/static_size.py:130
    // d=self.more(),
    callsub more
    // tests/artifacts/Arrays/static_size.py:131
    // e=BigUInt(self.count),
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    itob
    // tests/artifacts/Arrays/static_size.py:126-132
    // return Xtra(
    //     a=Txn.num_app_args,
    //     b=self.count,
    //     c=Txn.sender,
    //     d=self.more(),
    //     e=BigUInt(self.count),
    // )
    uncover 3
    cover 4
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes:
more:
    // tests/artifacts/Arrays/static_size.py:136
    // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count))
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    dup
    intc_1 // 1
    +
    itob
    dig 1
    uncover 2
    *
    itob
    concat
    retsub
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAFAAEIEJABJgUEFR98dQVjb3VudAEAAAIAADEYQAADKSJnMRtBANSCBwQo18G4BPqcuXMEYDmiQAT4/WinBB8CjbEECWs6WQSNbjolNhoAjgcAfQBiAE8AOgAmABIAAiJDMRkURDEYRIgEIChMULAjQzEZFEQxGEQ2GgGIA7AWKExQsCNDMRkURDEYRDYaAReIAyQoTFCwI0MxGRREMRhENhoBF4gCmBYoTFCwI0MxGRREMRhENhoBiAJxKExQsCNDMRkURDEYRDYaAUlXABBMVxAQiAIfKExQsCNDMRkURDEYRDYaATYaAhc2GgM2GgQXiACRFihMULAjQzEZQP9fMRgURCNDigQBK0cCi/wiWUcCi/4ISRZXBgCL/ExcAElPAk8DgQcIJApJTgNMgQcIJApJTgMMQQAMiwaLBQmviwRMUIwHiweMBCKMAIsDJQhJjAKL/giMAYsCiwEMQQAgi/2LAElOAlOLBIsCSU4DTwJUjAQjCIwCi/8IjABC/9iLBIwAiYoEASJJK0cFKSJniALNiALKiALHTw4WTw4WUE8NUE8MUEsLFYFADkSBQK9PDEsBq08CTFCAEAAAAAAAAAAAAAAAAAAAAABMUIv9Fov8TFBPDBZPDBZQTwtQTwpQSwkVgUAORE8JSwSrUFBQi/8Wi/5MUE8HFk8HFlBPBlBPBVBLBBWBQA5ETwRPBKtQUFAiiwmBAwxBAD+LCIsJSU4CIQQLIQRYVxCASSRbTFcwEEsCIwhPAksBEkRLAVcACE8DgQIIFqhETFcICEsBSwILFqhEjAlC/7mLCEkVIQQKSYwCFlcGAksBUIABYbxIgAFhTL9XAJBJjABJVwAIjAEkW4wEIowFI4wHiweLAgxBAFyLCIsHIQQLIQRYRwJXAAhMJFuMBosBpEEANosAIltMIlsJjAOLBosEDEEAHIsEiwYJiwNJC0xJCwiSiwUIjAWLByMIjAdC/7CLBosECUL/4SJbiwAiWwmMA0L/yIsFjACJigIBi/6L/1BJFSUKSSMJJQtLAkwlWEmL/xJETBZXBgJPAlBJIlkjCUsBVwIATCULJVhPAhJEiYoBAYv/SIv/FSUKFlcGAov/UImKAQErRwSL/yMII4sGiwUMQQAZiwZJgQIYFIsETCoiTwJUUIwEIwiMBkL/34sERwIVi/8SREsBUBWL/4ECCxJEIowBFYwAIowDiwOLAAxBACKLBIsDI1giU4sBjAJBAAaLASMIjAKLAowBiwMjCIwDQv/WiwGMAImKAQErRwSL/yMII4sGiwUMQQARiwZJFosETFCMBCMIjAZC/+eLBBUkCkmMAIv/EkQijAEijAOLA4sADEEAJIsEiwMkCyRYK6mLAYwCQQAGiwEjCIwCiwKMAYsDIwiMA0L/1CcEiwRQSVcCABUkChZXBgJcAIwAiYoBAYv/VwIASSJMFSQKIosDiwIMQQAWiwCLA0lOAiQLW4sBCIwBIwiMA0L/4osBjACJIillRCMIKUsBZzEbMQCIAAoiKWVEFk8DTgSJIillREkjCBZLAU8CCxZQiYoAATEAMQcSKiJPAlQxADEHEyoiTwJUUEcCTwJJFScETgIkiPxVSU4CSSJZSU4DSYECEkRLARWBAxJESURLASVTKiJPAlQiUzEAMQcSEkQjDUSBEVMqIk8CVCJTMQAxBxMSRCKLBIsCDEEAG4sESSUIiwFMUyoiTwJUiwNMUIwDIwiMBEL/3YsDSRWBBBJESVcAASJTMQAxBxISRElXAQEiUzEAMQcTEkRJVwIBIlMxADEHEhJEVwMBIlMxADEHExJEiwBJFScETgIkiPutjACJ", + "approval": "CiAFAAEIEJABJgUABBUffHUFY291bnQBAAIAADEYQAADKiJnMRtBAEAxGRREMRhEggcEKNfBuAT6nLlzBGA5okAE+P1opwQfAo2xBAlrOlkEjW46JTYaAI4HAIEB+QI8AlECyAM6A20AMRkUMRgUEEOKBAEoRwKL/CJZRwKL/ghJFlcGAIv8TFwATgJMgQcIJApJTwKBBwgkCklOAgxBAAyLBosFCa+LBExQjAQijACLAyUISYwCi/4IjAGLAosBDEEAIIv9iwBJTgJTiwSLAklOA08CVIwEIwiMAov/CIwAQv/YiwSMAIkiSShHBTYaATYaAhc2GgM2GgQXKiJniAOhiAOeiAObTw4WTw4WUE8NUE8MUEsLFYFADkSBQK9PDEsBq08CTFCAEAAAAAAAAAAAAAAAAAAAAABMUE8OFk8PTFBPDBZPDBZQTwtQTwpQSwkVgUAORE8JSwSrUFBQTwcWTwhMUE8HFk8HFlBPBlBPBVBLBBWBQA5ETwRPBKtQUFAiSYEDDEEAOUpJTgIhBAshBFhXEIBJJFtLAiMITEsBEkRMVzAQSVcACE8DgQIIFqhEVwgISwFLAgsWqERFAUL/wEsBSRUhBApJRQoWVwYCSwFQgAFhvEiAAWFMv1cAkElFC0lXAAhFCiRbRQYiRQUjRQNLAksIDEEAXEsBSwMhBAshBFhHAlcACEwkW0UGSwqkQQA2SwoiW0wiWwlFB0sDSwYMQQAcSwVLBAlLB0kLTEkLCJJLBQhFBUsCIwhFA0L/sEsDSwYJQv/hIltLCiJbCUUHQv/ISwQWKUxQsCNDNhoBSVcAEExXEBBMSwFQSRUlCkkjCSULSwJMJVhJTwQSREwWVwYCTwJQSSJZIwlLAVcCAEwlCyVYTwISRClMULAjQzYaAUlISRUlChZXBgJMUClMULAjQyhHAjYaARdJKEwjCCNJSwIMQQAYRwKBAhgUSwRMKyJPAlRQRQQjCEUBQv/hSwJHAhVLBklOBBJESwFQFU8CgQILEkQiRQcVRQciRQVLBEsHDEEAGksCSwUjWCJTQQAGSwUjCEUGSwQjCEUFQv/eSwUWKUxQsCNDKEcCNhoBF0koTCMII0lLAgxBABBHAhZLBExQRQQjCEUBQv/pSwIVJApJRQhLBBJEIkUGIkUFSwRLBwxBABxLAksFJAskWCipQQAGSwUjCEUGSwQjCEUFQv/cJwRLA1BJVwIAFSQKFlcGAlwAKUxQsCNDNhoBVwIASSJMFSQKIklLAgxBABZLA0sBSU4CJAtbSwQIRQQjCEUBQv/jSwIWKUxQsCNDMQAxBxIrIk8CVDEAMQcTKyJPAlRQRwIVJwRLAk8CJIj8eklOAkkiWUlOA0mBAhJESwEVgQMSRElESwElUysiTwJUIlMxADEHEhJEIw1EgRFTKyJPAlQiUzEAMQcTEkQiSUsDDEEAGkcCJQhLBUxTKyJPAlRLA0xQRQMjCEUBQv/fSwFJFYEEEkRJVwABIlMxADEHEhJESVcBASJTMQAxBxMSRElXAgEiUzEAMQcSEkRXAwEiUzEAMQcTEkRLBEkVJwROAiSI+9QpTFCwI0MiKmVEIwgqSwFnMRsxAIgACiIqZUQWTwNOBIkiKmVESSMIFksBTwILFlCJ", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/Arrays/static_size.py b/tests/artifacts/Arrays/static_size.py index 864c077..c10834b 100644 --- a/tests/artifacts/Arrays/static_size.py +++ b/tests/artifacts/Arrays/static_size.py @@ -116,7 +116,7 @@ def sum_array(self, arc4_arr: arc4.DynamicArray[arc4.UInt64]) -> UInt64: total = UInt64(0) for item in arr: - total += item.native + total += item.as_uint64() return total @@ -169,9 +169,9 @@ def path_length(path: ReferenceArray[Point]) -> UInt64: for point_idx in urange(1, path.length): point = path[point_idx] if point.x < last_point.x: - dx = last_point.x.native - point.x.native + dx = last_point.x.as_uint64() - point.x.as_uint64() else: - dx = point.x.native - last_point.x.native + dx = point.x.as_uint64() - last_point.x.as_uint64() if point.y < last_point.y: dy = last_point.y - point.y else: diff --git a/tests/artifacts/BoxContract/data/BoxContract.approval.teal b/tests/artifacts/BoxContract/data/BoxContract.approval.teal index c21197d..fc3aa2c 100644 --- a/tests/artifacts/BoxContract/data/BoxContract.approval.teal +++ b/tests/artifacts/BoxContract/data/BoxContract.approval.teal @@ -3,67 +3,35 @@ // tests.artifacts.BoxContract.contract.BoxContract.__algopy_entrypoint_with_init() -> uint64: main: - intcblock 1 bytecblock 0x6f6361 0x74786e // tests/artifacts/BoxContract/contract.py:4 // class BoxContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@7 - pushbytess 0xf26c6d42 0xef186cf7 // method "store_enums()void", method "read_enums()(uint64,uint64)" - txna ApplicationArgs 0 - match main_store_enums_route@5 main_read_enums_route@6 - -main_after_if_else@9: - // tests/artifacts/BoxContract/contract.py:4 - // class BoxContract(ARC4Contract): - pushint 0 // 0 - return - -main_read_enums_route@6: - // tests/artifacts/BoxContract/contract.py:14 - // @arc4.abimethod() + bz main___algopy_default_create@9 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - callsub read_enums - pushbytes 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + assert + pushbytess 0xf26c6d42 0xef186cf7 // method "store_enums()void", method "read_enums()(uint64,uint64)" + txna ApplicationArgs 0 + match store_enums read_enums + err -main_store_enums_route@5: - // tests/artifacts/BoxContract/contract.py:9 - // @arc4.abimethod() +main___algopy_default_create@9: txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub store_enums - intc_0 // 1 - return - -main_bare_routing@7: - // tests/artifacts/BoxContract/contract.py:4 - // class BoxContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@9 txn ApplicationID ! - assert // can only call when creating - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.BoxContract.contract.BoxContract.store_enums() -> void: +// tests.artifacts.BoxContract.contract.BoxContract.store_enums[routing]() -> void: store_enums: // tests/artifacts/BoxContract/contract.py:11 // self.oca.value = OnCompleteAction.OptIn - intc_0 // OptIn + pushint 1 // OptIn itob bytec_0 // "oca" swap @@ -75,10 +43,13 @@ store_enums: bytec_1 // "txn" swap box_put - retsub + // tests/artifacts/BoxContract/contract.py:9 + // @arc4.abimethod() + pushint 1 // 1 + return -// tests.artifacts.BoxContract.contract.BoxContract.read_enums() -> bytes: +// tests.artifacts.BoxContract.contract.BoxContract.read_enums[routing]() -> void: read_enums: // tests/artifacts/BoxContract/contract.py:16 // assert op.Box.get(b"oca")[0] == op.itob(self.oca.value) @@ -107,4 +78,11 @@ read_enums: // tests/artifacts/BoxContract/contract.py:19 // return arc4.Tuple((arc4.UInt64(self.oca.value), arc4.UInt64(self.txn.value))) concat - retsub + // tests/artifacts/BoxContract/contract.py:14 + // @arc4.abimethod() + pushbytes 0x151f7c75 + swap + concat + log + pushint 1 // 1 + return diff --git a/tests/artifacts/BoxContract/data/BoxContract.arc32.json b/tests/artifacts/BoxContract/data/BoxContract.arc32.json index b235540..56ce841 100644 --- a/tests/artifacts/BoxContract/data/BoxContract.arc32.json +++ b/tests/artifacts/BoxContract/data/BoxContract.arc32.json @@ -12,7 +12,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICBpbnRjYmxvY2sgMQogICAgYnl0ZWNibG9jayAweDZmNjM2MSAweDc0Nzg2ZQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEJveENvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9iYXJlX3JvdXRpbmdANwogICAgcHVzaGJ5dGVzcyAweGYyNmM2ZDQyIDB4ZWYxODZjZjcgLy8gbWV0aG9kICJzdG9yZV9lbnVtcygpdm9pZCIsIG1ldGhvZCAicmVhZF9lbnVtcygpKHVpbnQ2NCx1aW50NjQpIgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl9zdG9yZV9lbnVtc19yb3V0ZUA1IG1haW5fcmVhZF9lbnVtc19yb3V0ZUA2CgptYWluX2FmdGVyX2lmX2Vsc2VAOToKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBCb3hDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl9yZWFkX2VudW1zX3JvdXRlQDY6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTQKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICBhc3NlcnQgLy8gT25Db21wbGV0aW9uIGlzIG5vdCBOb09wCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGNhbGxzdWIgcmVhZF9lbnVtcwogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBpbnRjXzAgLy8gMQogICAgcmV0dXJuCgptYWluX3N0b3JlX2VudW1zX3JvdXRlQDU6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgY2FsbHN1YiBzdG9yZV9lbnVtcwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKbWFpbl9iYXJlX3JvdXRpbmdANzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBCb3hDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgYm56IG1haW5fYWZ0ZXJfaWZfZWxzZUA5CiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5Cb3hDb250cmFjdC5jb250cmFjdC5Cb3hDb250cmFjdC5zdG9yZV9lbnVtcygpIC0+IHZvaWQ6CnN0b3JlX2VudW1zOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjExCiAgICAvLyBzZWxmLm9jYS52YWx1ZSA9IE9uQ29tcGxldGVBY3Rpb24uT3B0SW4KICAgIGludGNfMCAvLyBPcHRJbgogICAgaXRvYgogICAgYnl0ZWNfMCAvLyAib2NhIgogICAgc3dhcAogICAgYm94X3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjEyCiAgICAvLyBzZWxmLnR4bi52YWx1ZSA9IFRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwKICAgIHB1c2hpbnQgNiAvLyBhcHBsCiAgICBpdG9iCiAgICBieXRlY18xIC8vICJ0eG4iCiAgICBzd2FwCiAgICBib3hfcHV0CiAgICByZXRzdWIKCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QucmVhZF9lbnVtcygpIC0+IGJ5dGVzOgpyZWFkX2VudW1zOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjE2CiAgICAvLyBhc3NlcnQgb3AuQm94LmdldChiIm9jYSIpWzBdID09IG9wLml0b2Ioc2VsZi5vY2EudmFsdWUpCiAgICBieXRlY18wIC8vIDB4NmY2MzYxCiAgICBib3hfZ2V0CiAgICBhc3NlcnQgLy8gY2hlY2sgc2VsZi5vY2EgZXhpc3RzCiAgICBkdXAKICAgIGJ0b2kKICAgIGl0b2IKICAgIHN3YXAKICAgIGRpZyAxCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTcKICAgIC8vIGFzc2VydCBvcC5Cb3guZ2V0KGIidHhuIilbMF0gPT0gb3AuaXRvYihzZWxmLnR4bi52YWx1ZSkKICAgIGJ5dGVjXzEgLy8gMHg3NDc4NmUKICAgIGJveF9nZXQKICAgIGFzc2VydCAvLyBjaGVjayBzZWxmLnR4biBleGlzdHMKICAgIGR1cAogICAgYnRvaQogICAgaXRvYgogICAgc3dhcAogICAgZGlnIDEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weToxOQogICAgLy8gcmV0dXJuIGFyYzQuVHVwbGUoKGFyYzQuVUludDY0KHNlbGYub2NhLnZhbHVlKSwgYXJjNC5VSW50NjQoc2VsZi50eG4udmFsdWUpKSkKICAgIGNvbmNhdAogICAgcmV0c3ViCg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICBieXRlY2Jsb2NrIDB4NmY2MzYxIDB4NzQ3ODZlCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6NAogICAgLy8gY2xhc3MgQm94Q29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHR4biBOdW1BcHBBcmdzCiAgICBieiBtYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0CiAgICBwdXNoYnl0ZXNzIDB4ZjI2YzZkNDIgMHhlZjE4NmNmNyAvLyBtZXRob2QgInN0b3JlX2VudW1zKCl2b2lkIiwgbWV0aG9kICJyZWFkX2VudW1zKCkodWludDY0LHVpbnQ2NCkiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBzdG9yZV9lbnVtcyByZWFkX2VudW1zCiAgICBlcnIKCm1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVAOToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5Cb3hDb250cmFjdC5jb250cmFjdC5Cb3hDb250cmFjdC5zdG9yZV9lbnVtc1tyb3V0aW5nXSgpIC0+IHZvaWQ6CnN0b3JlX2VudW1zOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjExCiAgICAvLyBzZWxmLm9jYS52YWx1ZSA9IE9uQ29tcGxldGVBY3Rpb24uT3B0SW4KICAgIHB1c2hpbnQgMSAvLyBPcHRJbgogICAgaXRvYgogICAgYnl0ZWNfMCAvLyAib2NhIgogICAgc3dhcAogICAgYm94X3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjEyCiAgICAvLyBzZWxmLnR4bi52YWx1ZSA9IFRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwKICAgIHB1c2hpbnQgNiAvLyBhcHBsCiAgICBpdG9iCiAgICBieXRlY18xIC8vICJ0eG4iCiAgICBzd2FwCiAgICBib3hfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QucmVhZF9lbnVtc1tyb3V0aW5nXSgpIC0+IHZvaWQ6CnJlYWRfZW51bXM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTYKICAgIC8vIGFzc2VydCBvcC5Cb3guZ2V0KGIib2NhIilbMF0gPT0gb3AuaXRvYihzZWxmLm9jYS52YWx1ZSkKICAgIGJ5dGVjXzAgLy8gMHg2ZjYzNjEKICAgIGJveF9nZXQKICAgIGFzc2VydCAvLyBjaGVjayBzZWxmLm9jYSBleGlzdHMKICAgIGR1cAogICAgYnRvaQogICAgaXRvYgogICAgc3dhcAogICAgZGlnIDEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weToxNwogICAgLy8gYXNzZXJ0IG9wLkJveC5nZXQoYiJ0eG4iKVswXSA9PSBvcC5pdG9iKHNlbGYudHhuLnZhbHVlKQogICAgYnl0ZWNfMSAvLyAweDc0Nzg2ZQogICAgYm94X2dldAogICAgYXNzZXJ0IC8vIGNoZWNrIHNlbGYudHhuIGV4aXN0cwogICAgZHVwCiAgICBidG9pCiAgICBpdG9iCiAgICBzd2FwCiAgICBkaWcgMQogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjE5CiAgICAvLyByZXR1cm4gYXJjNC5UdXBsZSgoYXJjNC5VSW50NjQoc2VsZi5vY2EudmFsdWUpLCBhcmM0LlVJbnQ2NChzZWxmLnR4bi52YWx1ZSkpKQogICAgY29uY2F0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTQKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICBwdXNoYnl0ZXMgMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/BoxContract/data/BoxContract.arc56.json b/tests/artifacts/BoxContract/data/BoxContract.arc56.json index 0368c56..52a5d47 100644 --- a/tests/artifacts/BoxContract/data/BoxContract.arc56.json +++ b/tests/artifacts/BoxContract/data/BoxContract.arc56.json @@ -84,33 +84,25 @@ "sourceInfo": [ { "pc": [ - 46, - 67 + 19 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 84 + 52 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 49, 70 ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 101 - ], "errorMessage": "check self.oca exists" }, { "pc": [ - 112 + 81 ], "errorMessage": "check self.txn exists" } @@ -123,18 +115,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICBpbnRjYmxvY2sgMQogICAgYnl0ZWNibG9jayAweDZmNjM2MSAweDc0Nzg2ZQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEJveENvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9iYXJlX3JvdXRpbmdANwogICAgcHVzaGJ5dGVzcyAweGYyNmM2ZDQyIDB4ZWYxODZjZjcgLy8gbWV0aG9kICJzdG9yZV9lbnVtcygpdm9pZCIsIG1ldGhvZCAicmVhZF9lbnVtcygpKHVpbnQ2NCx1aW50NjQpIgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl9zdG9yZV9lbnVtc19yb3V0ZUA1IG1haW5fcmVhZF9lbnVtc19yb3V0ZUA2CgptYWluX2FmdGVyX2lmX2Vsc2VAOToKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBCb3hDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl9yZWFkX2VudW1zX3JvdXRlQDY6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTQKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICBhc3NlcnQgLy8gT25Db21wbGV0aW9uIGlzIG5vdCBOb09wCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGNhbGxzdWIgcmVhZF9lbnVtcwogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBpbnRjXzAgLy8gMQogICAgcmV0dXJuCgptYWluX3N0b3JlX2VudW1zX3JvdXRlQDU6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgY2FsbHN1YiBzdG9yZV9lbnVtcwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKbWFpbl9iYXJlX3JvdXRpbmdANzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBCb3hDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgYm56IG1haW5fYWZ0ZXJfaWZfZWxzZUA5CiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5Cb3hDb250cmFjdC5jb250cmFjdC5Cb3hDb250cmFjdC5zdG9yZV9lbnVtcygpIC0+IHZvaWQ6CnN0b3JlX2VudW1zOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjExCiAgICAvLyBzZWxmLm9jYS52YWx1ZSA9IE9uQ29tcGxldGVBY3Rpb24uT3B0SW4KICAgIGludGNfMCAvLyBPcHRJbgogICAgaXRvYgogICAgYnl0ZWNfMCAvLyAib2NhIgogICAgc3dhcAogICAgYm94X3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjEyCiAgICAvLyBzZWxmLnR4bi52YWx1ZSA9IFRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwKICAgIHB1c2hpbnQgNiAvLyBhcHBsCiAgICBpdG9iCiAgICBieXRlY18xIC8vICJ0eG4iCiAgICBzd2FwCiAgICBib3hfcHV0CiAgICByZXRzdWIKCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QucmVhZF9lbnVtcygpIC0+IGJ5dGVzOgpyZWFkX2VudW1zOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjE2CiAgICAvLyBhc3NlcnQgb3AuQm94LmdldChiIm9jYSIpWzBdID09IG9wLml0b2Ioc2VsZi5vY2EudmFsdWUpCiAgICBieXRlY18wIC8vIDB4NmY2MzYxCiAgICBib3hfZ2V0CiAgICBhc3NlcnQgLy8gY2hlY2sgc2VsZi5vY2EgZXhpc3RzCiAgICBkdXAKICAgIGJ0b2kKICAgIGl0b2IKICAgIHN3YXAKICAgIGRpZyAxCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTcKICAgIC8vIGFzc2VydCBvcC5Cb3guZ2V0KGIidHhuIilbMF0gPT0gb3AuaXRvYihzZWxmLnR4bi52YWx1ZSkKICAgIGJ5dGVjXzEgLy8gMHg3NDc4NmUKICAgIGJveF9nZXQKICAgIGFzc2VydCAvLyBjaGVjayBzZWxmLnR4biBleGlzdHMKICAgIGR1cAogICAgYnRvaQogICAgaXRvYgogICAgc3dhcAogICAgZGlnIDEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weToxOQogICAgLy8gcmV0dXJuIGFyYzQuVHVwbGUoKGFyYzQuVUludDY0KHNlbGYub2NhLnZhbHVlKSwgYXJjNC5VSW50NjQoc2VsZi50eG4udmFsdWUpKSkKICAgIGNvbmNhdAogICAgcmV0c3ViCg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICBieXRlY2Jsb2NrIDB4NmY2MzYxIDB4NzQ3ODZlCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6NAogICAgLy8gY2xhc3MgQm94Q29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHR4biBOdW1BcHBBcmdzCiAgICBieiBtYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0CiAgICBwdXNoYnl0ZXNzIDB4ZjI2YzZkNDIgMHhlZjE4NmNmNyAvLyBtZXRob2QgInN0b3JlX2VudW1zKCl2b2lkIiwgbWV0aG9kICJyZWFkX2VudW1zKCkodWludDY0LHVpbnQ2NCkiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBzdG9yZV9lbnVtcyByZWFkX2VudW1zCiAgICBlcnIKCm1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVAOToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5Cb3hDb250cmFjdC5jb250cmFjdC5Cb3hDb250cmFjdC5zdG9yZV9lbnVtc1tyb3V0aW5nXSgpIC0+IHZvaWQ6CnN0b3JlX2VudW1zOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjExCiAgICAvLyBzZWxmLm9jYS52YWx1ZSA9IE9uQ29tcGxldGVBY3Rpb24uT3B0SW4KICAgIHB1c2hpbnQgMSAvLyBPcHRJbgogICAgaXRvYgogICAgYnl0ZWNfMCAvLyAib2NhIgogICAgc3dhcAogICAgYm94X3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjEyCiAgICAvLyBzZWxmLnR4bi52YWx1ZSA9IFRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwKICAgIHB1c2hpbnQgNiAvLyBhcHBsCiAgICBpdG9iCiAgICBieXRlY18xIC8vICJ0eG4iCiAgICBzd2FwCiAgICBib3hfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuQm94Q29udHJhY3QuY29udHJhY3QuQm94Q29udHJhY3QucmVhZF9lbnVtc1tyb3V0aW5nXSgpIC0+IHZvaWQ6CnJlYWRfZW51bXM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTYKICAgIC8vIGFzc2VydCBvcC5Cb3guZ2V0KGIib2NhIilbMF0gPT0gb3AuaXRvYihzZWxmLm9jYS52YWx1ZSkKICAgIGJ5dGVjXzAgLy8gMHg2ZjYzNjEKICAgIGJveF9nZXQKICAgIGFzc2VydCAvLyBjaGVjayBzZWxmLm9jYSBleGlzdHMKICAgIGR1cAogICAgYnRvaQogICAgaXRvYgogICAgc3dhcAogICAgZGlnIDEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9Cb3hDb250cmFjdC9jb250cmFjdC5weToxNwogICAgLy8gYXNzZXJ0IG9wLkJveC5nZXQoYiJ0eG4iKVswXSA9PSBvcC5pdG9iKHNlbGYudHhuLnZhbHVlKQogICAgYnl0ZWNfMSAvLyAweDc0Nzg2ZQogICAgYm94X2dldAogICAgYXNzZXJ0IC8vIGNoZWNrIHNlbGYudHhuIGV4aXN0cwogICAgZHVwCiAgICBidG9pCiAgICBpdG9iCiAgICBzd2FwCiAgICBkaWcgMQogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0JveENvbnRyYWN0L2NvbnRyYWN0LnB5OjE5CiAgICAvLyByZXR1cm4gYXJjNC5UdXBsZSgoYXJjNC5VSW50NjQoc2VsZi5vY2EudmFsdWUpLCBhcmM0LlVJbnQ2NChzZWxmLnR4bi52YWx1ZSkpKQogICAgY29uY2F0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQm94Q29udHJhY3QvY29udHJhY3QucHk6MTQKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICBwdXNoYnl0ZXMgMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiABASYCA29jYQN0eG4xG0EAOYICBPJsbUIE7xhs9zYaAI4CABgAA4EAQzEZFEQxGESIAC6ABBUffHVMULAiQzEZFEQxGESIAA0iQzEZQP/XMRgURCJDIhYoTL+BBhYpTL+JKL5ESRcWTEsBEkQpvkRJFxZMSwESRFCJ", + "approval": "CiYCA29jYQN0eG4xG0EAHTEZFEQxGESCAgTybG1CBO8YbPc2GgCOAgAJABgAMRkUMRgUEEOBARYoTL+BBhYpTL+BAUMovkRJFxZMSwESRCm+REkXFkxLARJEUIAEFR98dUxQsIEBQw==", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/Contains/data/MyContract.approval.teal b/tests/artifacts/Contains/data/MyContract.approval.teal index 58b9125..d4888d9 100644 --- a/tests/artifacts/Contains/data/MyContract.approval.teal +++ b/tests/artifacts/Contains/data/MyContract.approval.teal @@ -95,11 +95,9 @@ main: // tests/artifacts/Contains/contract.py:32 // assert not three_false, "Should be false" ! - assert // Should be false // tests/artifacts/Contains/contract.py:37 // return UInt64(1) - intc_1 // 1 - return + return // on error: Should be false // tests.artifacts.Contains.contract.MyContract.is_in_tuple_1(x: uint64, y.0: uint64, y.1: uint64, y.2: bytes) -> uint64: diff --git a/tests/artifacts/CreatedAppAsset/data/AppCall.approval.teal b/tests/artifacts/CreatedAppAsset/data/AppCall.approval.teal index 2d7352c..4ef87a8 100644 --- a/tests/artifacts/CreatedAppAsset/data/AppCall.approval.teal +++ b/tests/artifacts/CreatedAppAsset/data/AppCall.approval.teal @@ -6,47 +6,32 @@ main: // tests/artifacts/CreatedAppAsset/other.py:4 // class AppCall(ARC4Contract): txn NumAppArgs - bz main_bare_routing@6 + bz main___algopy_default_create@5 pushbytes 0xd3479e65 // method "some_value()uint64" txna ApplicationArgs 0 match main_some_value_route@3 - -main_after_if_else@10: - // tests/artifacts/CreatedAppAsset/other.py:4 - // class AppCall(ARC4Contract): - pushint 0 // 0 - return + err main_some_value_route@3: // tests/artifacts/CreatedAppAsset/other.py:5 // @arc4.abimethod() txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - callsub some_value - itob - pushbytes 0x151f7c75 - swap - concat - log - pushint 1 // 1 - return + && + assert // OnCompletion must be NoOp && can only call when not creating + b some_value -main_bare_routing@6: - // tests/artifacts/CreatedAppAsset/other.py:4 - // class AppCall(ARC4Contract): +main___algopy_default_create@5: txn OnCompletion - bnz main_after_if_else@10 + ! txn ApplicationID ! - assert // can only call when creating - pushint 1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.CreatedAppAsset.other.AppCall.some_value() -> uint64: +// tests.artifacts.CreatedAppAsset.other.AppCall.some_value[routing]() -> void: some_value: // tests/artifacts/CreatedAppAsset/other.py:7 // return Global.group_size * (Txn.group_index + 1) @@ -55,4 +40,12 @@ some_value: pushint 1 // 1 + * - retsub + // tests/artifacts/CreatedAppAsset/other.py:5 + // @arc4.abimethod() + itob + pushbytes 0x151f7c75 + swap + concat + log + pushint 1 // 1 + return diff --git a/tests/artifacts/CreatedAppAsset/data/AppCall.arc32.json b/tests/artifacts/CreatedAppAsset/data/AppCall.arc32.json index cc5d3ba..bec26e9 100644 --- a/tests/artifacts/CreatedAppAsset/data/AppCall.arc32.json +++ b/tests/artifacts/CreatedAppAsset/data/AppCall.arc32.json @@ -7,7 +7,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NAogICAgLy8gY2xhc3MgQXBwQ2FsbChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIHB1c2hieXRlcyAweGQzNDc5ZTY1IC8vIG1ldGhvZCAic29tZV92YWx1ZSgpdWludDY0IgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl9zb21lX3ZhbHVlX3JvdXRlQDMKCm1haW5fYWZ0ZXJfaWZfZWxzZUAxMDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NAogICAgLy8gY2xhc3MgQXBwQ2FsbChBUkM0Q29udHJhY3QpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl9zb21lX3ZhbHVlX3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L290aGVyLnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICBhc3NlcnQgLy8gT25Db21wbGV0aW9uIGlzIG5vdCBOb09wCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGNhbGxzdWIgc29tZV92YWx1ZQogICAgaXRvYgogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCgptYWluX2JhcmVfcm91dGluZ0A2OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9vdGhlci5weTo0CiAgICAvLyBjbGFzcyBBcHBDYWxsKEFSQzRDb250cmFjdCk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDEwCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5DcmVhdGVkQXBwQXNzZXQub3RoZXIuQXBwQ2FsbC5zb21lX3ZhbHVlKCkgLT4gdWludDY0Ogpzb21lX3ZhbHVlOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9vdGhlci5weTo3CiAgICAvLyByZXR1cm4gR2xvYmFsLmdyb3VwX3NpemUgKiAoVHhuLmdyb3VwX2luZGV4ICsgMSkKICAgIGdsb2JhbCBHcm91cFNpemUKICAgIHR4biBHcm91cEluZGV4CiAgICBwdXNoaW50IDEgLy8gMQogICAgKwogICAgKgogICAgcmV0c3ViCg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NAogICAgLy8gY2xhc3MgQXBwQ2FsbChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANQogICAgcHVzaGJ5dGVzIDB4ZDM0NzllNjUgLy8gbWV0aG9kICJzb21lX3ZhbHVlKCl1aW50NjQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3NvbWVfdmFsdWVfcm91dGVAMwogICAgZXJyCgptYWluX3NvbWVfdmFsdWVfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgYiBzb21lX3ZhbHVlCgptYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDU6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgJiYKICAgIHJldHVybiAvLyBvbiBlcnJvcjogT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcCAmJiBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKCgovLyB0ZXN0cy5hcnRpZmFjdHMuQ3JlYXRlZEFwcEFzc2V0Lm90aGVyLkFwcENhbGwuc29tZV92YWx1ZVtyb3V0aW5nXSgpIC0+IHZvaWQ6CnNvbWVfdmFsdWU6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L290aGVyLnB5OjcKICAgIC8vIHJldHVybiBHbG9iYWwuZ3JvdXBfc2l6ZSAqIChUeG4uZ3JvdXBfaW5kZXggKyAxKQogICAgZ2xvYmFsIEdyb3VwU2l6ZQogICAgdHhuIEdyb3VwSW5kZXgKICAgIHB1c2hpbnQgMSAvLyAxCiAgICArCiAgICAqCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L290aGVyLnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICBpdG9iCiAgICBwdXNoYnl0ZXMgMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/CreatedAppAsset/data/AppCall.arc56.json b/tests/artifacts/CreatedAppAsset/data/AppCall.arc56.json index bf5b39b..31f2aeb 100644 --- a/tests/artifacts/CreatedAppAsset/data/AppCall.arc56.json +++ b/tests/artifacts/CreatedAppAsset/data/AppCall.arc56.json @@ -57,21 +57,15 @@ "sourceInfo": [ { "pc": [ - 25 + 37 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 53 + 26 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 28 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when not creating" } ], "pcOffsetMethod": "none" @@ -82,18 +76,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NAogICAgLy8gY2xhc3MgQXBwQ2FsbChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIHB1c2hieXRlcyAweGQzNDc5ZTY1IC8vIG1ldGhvZCAic29tZV92YWx1ZSgpdWludDY0IgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl9zb21lX3ZhbHVlX3JvdXRlQDMKCm1haW5fYWZ0ZXJfaWZfZWxzZUAxMDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NAogICAgLy8gY2xhc3MgQXBwQ2FsbChBUkM0Q29udHJhY3QpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl9zb21lX3ZhbHVlX3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L290aGVyLnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICBhc3NlcnQgLy8gT25Db21wbGV0aW9uIGlzIG5vdCBOb09wCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGNhbGxzdWIgc29tZV92YWx1ZQogICAgaXRvYgogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCgptYWluX2JhcmVfcm91dGluZ0A2OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9vdGhlci5weTo0CiAgICAvLyBjbGFzcyBBcHBDYWxsKEFSQzRDb250cmFjdCk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDEwCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5DcmVhdGVkQXBwQXNzZXQub3RoZXIuQXBwQ2FsbC5zb21lX3ZhbHVlKCkgLT4gdWludDY0Ogpzb21lX3ZhbHVlOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9vdGhlci5weTo3CiAgICAvLyByZXR1cm4gR2xvYmFsLmdyb3VwX3NpemUgKiAoVHhuLmdyb3VwX2luZGV4ICsgMSkKICAgIGdsb2JhbCBHcm91cFNpemUKICAgIHR4biBHcm91cEluZGV4CiAgICBwdXNoaW50IDEgLy8gMQogICAgKwogICAgKgogICAgcmV0c3ViCg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NAogICAgLy8gY2xhc3MgQXBwQ2FsbChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANQogICAgcHVzaGJ5dGVzIDB4ZDM0NzllNjUgLy8gbWV0aG9kICJzb21lX3ZhbHVlKCl1aW50NjQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3NvbWVfdmFsdWVfcm91dGVAMwogICAgZXJyCgptYWluX3NvbWVfdmFsdWVfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvb3RoZXIucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgYiBzb21lX3ZhbHVlCgptYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDU6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgJiYKICAgIHJldHVybiAvLyBvbiBlcnJvcjogT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcCAmJiBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKCgovLyB0ZXN0cy5hcnRpZmFjdHMuQ3JlYXRlZEFwcEFzc2V0Lm90aGVyLkFwcENhbGwuc29tZV92YWx1ZVtyb3V0aW5nXSgpIC0+IHZvaWQ6CnNvbWVfdmFsdWU6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L290aGVyLnB5OjcKICAgIC8vIHJldHVybiBHbG9iYWwuZ3JvdXBfc2l6ZSAqIChUeG4uZ3JvdXBfaW5kZXggKyAxKQogICAgZ2xvYmFsIEdyb3VwU2l6ZQogICAgdHhuIEdyb3VwSW5kZXgKICAgIHB1c2hpbnQgMSAvLyAxCiAgICArCiAgICAqCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L290aGVyLnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICBpdG9iCiAgICBwdXNoYnl0ZXMgMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CjEbQQAngATTR55lNhoAjgEAA4EAQzEZFEQxGESIABkWgAQVH3x1TFCwgQFDMRlA/+ExGBREgQFDMgQxFoEBCAuJ", + "approval": "CjEbQQAYgATTR55lNhoAjgEAAQAxGRQxGBBEQgAIMRkUMRgUEEMyBDEWgQEICxaABBUffHVMULCBAUM=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.approval.teal b/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.approval.teal index fc11d8a..c4c3900 100644 --- a/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.approval.teal +++ b/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.approval.teal @@ -3,56 +3,35 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 0 6 + intcblock 1 6 bytecblock 0x151f7c75 // tests/artifacts/CreatedAppAsset/contract.py:4 // class AppExpectingEffects(ARC4Contract): txn NumAppArgs - bz main_bare_routing@7 + bz main___algopy_default_create@9 + txn OnCompletion + ! + assert // OnCompletion must be NoOp + txn ApplicationID + assert pushbytess 0x6d3a0439 0x62a0ef62 // method "create_group(acfg,appl)(uint64,uint64)", method "log_group(appl)void" txna ApplicationArgs 0 - match main_create_group_route@3 main_log_group_route@4 + match create_group log_group + err -main_after_if_else@11: - // tests/artifacts/CreatedAppAsset/contract.py:4 - // class AppExpectingEffects(ARC4Contract): - intc_1 // 0 - return - -main_log_group_route@4: - // tests/artifacts/CreatedAppAsset/contract.py:22 - // @arc4.abimethod +main___algopy_default_create@9: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CreatedAppAsset/contract.py:4 - // class AppExpectingEffects(ARC4Contract): - txn GroupIndex - intc_0 // 1 - - - dup - gtxns TypeEnum - intc_2 // appl - == - assert // transaction type is appl - // tests/artifacts/CreatedAppAsset/contract.py:22 - // @arc4.abimethod - callsub log_group - intc_0 // 1 - return + ! + && + return // on error: OnCompletion must be NoOp && can only call when creating + -main_create_group_route@3: +// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.create_group[routing]() -> void: +create_group: // tests/artifacts/CreatedAppAsset/contract.py:5 // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CreatedAppAsset/contract.py:4 - // class AppExpectingEffects(ARC4Contract): txn GroupIndex pushint 2 // 2 - @@ -66,55 +45,18 @@ main_create_group_route@3: - dup gtxns TypeEnum - intc_2 // appl + intc_1 // appl == assert // transaction type is appl - // tests/artifacts/CreatedAppAsset/contract.py:5 - // @arc4.abimethod - callsub create_group - swap - itob - swap - itob - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_bare_routing@7: - // tests/artifacts/CreatedAppAsset/contract.py:4 - // class AppExpectingEffects(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@11 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.create_group(asset_create: uint64, app_create: uint64) -> uint64, uint64: -create_group: - // tests/artifacts/CreatedAppAsset/contract.py:5-10 - // @arc4.abimethod - // def create_group( - // self, - // asset_create: gtxn.AssetConfigTransaction, - // app_create: gtxn.ApplicationCallTransaction, - // ) -> tuple[UInt64, UInt64]: - proto 2 2 // tests/artifacts/CreatedAppAsset/contract.py:11 // assert asset_create.created_asset.id, "expected asset created" - frame_dig -2 + dig 1 gtxns CreatedAssetID dup assert // expected asset created // tests/artifacts/CreatedAppAsset/contract.py:13 // op.gaid(asset_create.group_index) == asset_create.created_asset.id - frame_dig -2 + uncover 2 gtxns GroupIndex gaids dig 1 @@ -126,13 +68,13 @@ create_group: assert // expected correct asset id // tests/artifacts/CreatedAppAsset/contract.py:15 // assert app_create.created_app.id, "expected app created" - frame_dig -1 + dig 1 gtxns CreatedApplicationID dup assert // expected app created // tests/artifacts/CreatedAppAsset/contract.py:17 // op.gaid(app_create.group_index) == app_create.created_app.id - frame_dig -1 + uncover 2 gtxns GroupIndex gaids dig 1 @@ -142,21 +84,37 @@ create_group: // op.gaid(app_create.group_index) == app_create.created_app.id // ), "expected correct app id" assert // expected correct app id - // tests/artifacts/CreatedAppAsset/contract.py:20 - // return asset_create.created_asset.id, app_create.created_app.id - retsub + // tests/artifacts/CreatedAppAsset/contract.py:5 + // @arc4.abimethod + swap + itob + swap + itob + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.log_group(app_call: uint64) -> void: +// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.log_group[routing]() -> void: log_group: - // tests/artifacts/CreatedAppAsset/contract.py:22-23 + // tests/artifacts/CreatedAppAsset/contract.py:22 // @arc4.abimethod - // def log_group(self, app_call: gtxn.ApplicationCallTransaction) -> None: - proto 1 0 + txn GroupIndex + intc_0 // 1 + - + dup + gtxns TypeEnum + intc_1 // appl + == + assert // transaction type is appl // tests/artifacts/CreatedAppAsset/contract.py:24 // assert app_call.app_args(0) == arc4.arc4_signature( - frame_dig -1 - intc_1 // 0 + dup + pushint 0 // 0 gtxnsas ApplicationArgs // tests/artifacts/CreatedAppAsset/contract.py:24-26 // assert app_call.app_args(0) == arc4.arc4_signature( @@ -167,14 +125,14 @@ log_group: assert // expected correct method called // tests/artifacts/CreatedAppAsset/contract.py:27 // assert app_call.num_logs == 1, "expected logs" - frame_dig -1 + dup gtxns NumLogs intc_0 // 1 == assert // expected logs // tests/artifacts/CreatedAppAsset/contract.py:29 // arc4.UInt64.from_log(app_call.last_log) - frame_dig -1 + dup gtxns LastLog dup extract 4 0 @@ -185,7 +143,7 @@ log_group: assert // application log value is not the result of an ABI return // tests/artifacts/CreatedAppAsset/contract.py:30 // == (app_call.group_index + 1) * Global.group_size - frame_dig -1 + swap gtxns GroupIndex intc_0 // 1 + @@ -196,10 +154,6 @@ log_group: // == (app_call.group_index + 1) * Global.group_size itob b== - // tests/artifacts/CreatedAppAsset/contract.py:28-31 - // assert ( - // arc4.UInt64.from_log(app_call.last_log) - // == (app_call.group_index + 1) * Global.group_size - // ) - assert - retsub + // tests/artifacts/CreatedAppAsset/contract.py:22 + // @arc4.abimethod + return diff --git a/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc32.json b/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc32.json index 1783a49..602f1c0 100644 --- a/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc32.json +++ b/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc32.json @@ -12,7 +12,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0 6
    bytecblock 0x151f7c75
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@7
    pushbytess 0x6d3a0439 0x62a0ef62 // method "create_group(acfg,appl)(uint64,uint64)", method "log_group(appl)void"
    txna ApplicationArgs 0
    match main_create_group_route@3 main_log_group_route@4

main_after_if_else@11:
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    intc_1 // 0
    return

main_log_group_route@4:
    // tests/artifacts/CreatedAppAsset/contract.py:22
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    // tests/artifacts/CreatedAppAsset/contract.py:22
    // @arc4.abimethod
    callsub log_group
    intc_0 // 1
    return

main_create_group_route@3:
    // tests/artifacts/CreatedAppAsset/contract.py:5
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn GroupIndex
    pushint 2 // 2
    -
    dup
    gtxns TypeEnum
    pushint 3 // acfg
    ==
    assert // transaction type is acfg
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    // tests/artifacts/CreatedAppAsset/contract.py:5
    // @arc4.abimethod
    callsub create_group
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@7:
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@11
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.create_group(asset_create: uint64, app_create: uint64) -> uint64, uint64:
create_group:
    // tests/artifacts/CreatedAppAsset/contract.py:5-10
    // @arc4.abimethod
    // def create_group(
    //     self,
    //     asset_create: gtxn.AssetConfigTransaction,
    //     app_create: gtxn.ApplicationCallTransaction,
    // ) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/CreatedAppAsset/contract.py:11
    // assert asset_create.created_asset.id, "expected asset created"
    frame_dig -2
    gtxns CreatedAssetID
    dup
    assert // expected asset created
    // tests/artifacts/CreatedAppAsset/contract.py:13
    // op.gaid(asset_create.group_index) == asset_create.created_asset.id
    frame_dig -2
    gtxns GroupIndex
    gaids
    dig 1
    ==
    // tests/artifacts/CreatedAppAsset/contract.py:12-14
    // assert (
    //     op.gaid(asset_create.group_index) == asset_create.created_asset.id
    // ), "expected correct asset id"
    assert // expected correct asset id
    // tests/artifacts/CreatedAppAsset/contract.py:15
    // assert app_create.created_app.id, "expected app created"
    frame_dig -1
    gtxns CreatedApplicationID
    dup
    assert // expected app created
    // tests/artifacts/CreatedAppAsset/contract.py:17
    // op.gaid(app_create.group_index) == app_create.created_app.id
    frame_dig -1
    gtxns GroupIndex
    gaids
    dig 1
    ==
    // tests/artifacts/CreatedAppAsset/contract.py:16-18
    // assert (
    //     op.gaid(app_create.group_index) == app_create.created_app.id
    // ), "expected correct app id"
    assert // expected correct app id
    // tests/artifacts/CreatedAppAsset/contract.py:20
    // return asset_create.created_asset.id, app_create.created_app.id
    retsub


// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.log_group(app_call: uint64) -> void:
log_group:
    // tests/artifacts/CreatedAppAsset/contract.py:22-23
    // @arc4.abimethod
    // def log_group(self, app_call: gtxn.ApplicationCallTransaction) -> None:
    proto 1 0
    // tests/artifacts/CreatedAppAsset/contract.py:24
    // assert app_call.app_args(0) == arc4.arc4_signature(
    frame_dig -1
    intc_1 // 0
    gtxnsas ApplicationArgs
    // tests/artifacts/CreatedAppAsset/contract.py:24-26
    // assert app_call.app_args(0) == arc4.arc4_signature(
    //     "some_value()uint64"
    // ), "expected correct method called"
    pushbytes 0xd3479e65 // method "some_value()uint64"
    ==
    assert // expected correct method called
    // tests/artifacts/CreatedAppAsset/contract.py:27
    // assert app_call.num_logs == 1, "expected logs"
    frame_dig -1
    gtxns NumLogs
    intc_0 // 1
    ==
    assert // expected logs
    // tests/artifacts/CreatedAppAsset/contract.py:29
    // arc4.UInt64.from_log(app_call.last_log)
    frame_dig -1
    gtxns LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/CreatedAppAsset/contract.py:30
    // == (app_call.group_index + 1) * Global.group_size
    frame_dig -1
    gtxns GroupIndex
    intc_0 // 1
    +
    global GroupSize
    *
    // tests/artifacts/CreatedAppAsset/contract.py:29-30
    // arc4.UInt64.from_log(app_call.last_log)
    // == (app_call.group_index + 1) * Global.group_size
    itob
    b==
    // tests/artifacts/CreatedAppAsset/contract.py:28-31
    // assert (
    //     arc4.UInt64.from_log(app_call.last_log)
    //     == (app_call.group_index + 1) * Global.group_size
    // )
    assert
    retsub
", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDYKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBBcHBFeHBlY3RpbmdFZmZlY3RzKEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA5CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICBhc3NlcnQgLy8gT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydAogICAgcHVzaGJ5dGVzcyAweDZkM2EwNDM5IDB4NjJhMGVmNjIgLy8gbWV0aG9kICJjcmVhdGVfZ3JvdXAoYWNmZyxhcHBsKSh1aW50NjQsdWludDY0KSIsIG1ldGhvZCAibG9nX2dyb3VwKGFwcGwpdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIGNyZWF0ZV9ncm91cCBsb2dfZ3JvdXAKICAgIGVycgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA5OgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLkNyZWF0ZWRBcHBBc3NldC5jb250cmFjdC5BcHBFeHBlY3RpbmdFZmZlY3RzLmNyZWF0ZV9ncm91cFtyb3V0aW5nXSgpIC0+IHZvaWQ6CmNyZWF0ZV9ncm91cDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kCiAgICB0eG4gR3JvdXBJbmRleAogICAgcHVzaGludCAyIC8vIDIKICAgIC0KICAgIGR1cAogICAgZ3R4bnMgVHlwZUVudW0KICAgIHB1c2hpbnQgMyAvLyBhY2ZnCiAgICA9PQogICAgYXNzZXJ0IC8vIHRyYW5zYWN0aW9uIHR5cGUgaXMgYWNmZwogICAgdHhuIEdyb3VwSW5kZXgKICAgIGludGNfMCAvLyAxCiAgICAtCiAgICBkdXAKICAgIGd0eG5zIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydCAvLyB0cmFuc2FjdGlvbiB0eXBlIGlzIGFwcGwKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MTEKICAgIC8vIGFzc2VydCBhc3NldF9jcmVhdGUuY3JlYXRlZF9hc3NldC5pZCwgImV4cGVjdGVkIGFzc2V0IGNyZWF0ZWQiCiAgICBkaWcgMQogICAgZ3R4bnMgQ3JlYXRlZEFzc2V0SUQKICAgIGR1cAogICAgYXNzZXJ0IC8vIGV4cGVjdGVkIGFzc2V0IGNyZWF0ZWQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MTMKICAgIC8vIG9wLmdhaWQoYXNzZXRfY3JlYXRlLmdyb3VwX2luZGV4KSA9PSBhc3NldF9jcmVhdGUuY3JlYXRlZF9hc3NldC5pZAogICAgdW5jb3ZlciAyCiAgICBndHhucyBHcm91cEluZGV4CiAgICBnYWlkcwogICAgZGlnIDEKICAgID09CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjEyLTE0CiAgICAvLyBhc3NlcnQgKAogICAgLy8gICAgIG9wLmdhaWQoYXNzZXRfY3JlYXRlLmdyb3VwX2luZGV4KSA9PSBhc3NldF9jcmVhdGUuY3JlYXRlZF9hc3NldC5pZAogICAgLy8gKSwgImV4cGVjdGVkIGNvcnJlY3QgYXNzZXQgaWQiCiAgICBhc3NlcnQgLy8gZXhwZWN0ZWQgY29ycmVjdCBhc3NldCBpZAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weToxNQogICAgLy8gYXNzZXJ0IGFwcF9jcmVhdGUuY3JlYXRlZF9hcHAuaWQsICJleHBlY3RlZCBhcHAgY3JlYXRlZCIKICAgIGRpZyAxCiAgICBndHhucyBDcmVhdGVkQXBwbGljYXRpb25JRAogICAgZHVwCiAgICBhc3NlcnQgLy8gZXhwZWN0ZWQgYXBwIGNyZWF0ZWQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MTcKICAgIC8vIG9wLmdhaWQoYXBwX2NyZWF0ZS5ncm91cF9pbmRleCkgPT0gYXBwX2NyZWF0ZS5jcmVhdGVkX2FwcC5pZAogICAgdW5jb3ZlciAyCiAgICBndHhucyBHcm91cEluZGV4CiAgICBnYWlkcwogICAgZGlnIDEKICAgID09CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjE2LTE4CiAgICAvLyBhc3NlcnQgKAogICAgLy8gICAgIG9wLmdhaWQoYXBwX2NyZWF0ZS5ncm91cF9pbmRleCkgPT0gYXBwX2NyZWF0ZS5jcmVhdGVkX2FwcC5pZAogICAgLy8gKSwgImV4cGVjdGVkIGNvcnJlY3QgYXBwIGlkIgogICAgYXNzZXJ0IC8vIGV4cGVjdGVkIGNvcnJlY3QgYXBwIGlkCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgc3dhcAogICAgaXRvYgogICAgc3dhcAogICAgaXRvYgogICAgY29uY2F0CiAgICBieXRlY18wIC8vIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBpbnRjXzAgLy8gMQogICAgcmV0dXJuCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLkNyZWF0ZWRBcHBBc3NldC5jb250cmFjdC5BcHBFeHBlY3RpbmdFZmZlY3RzLmxvZ19ncm91cFtyb3V0aW5nXSgpIC0+IHZvaWQ6CmxvZ19ncm91cDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjIKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgdHhuIEdyb3VwSW5kZXgKICAgIGludGNfMCAvLyAxCiAgICAtCiAgICBkdXAKICAgIGd0eG5zIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydCAvLyB0cmFuc2FjdGlvbiB0eXBlIGlzIGFwcGwKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjQKICAgIC8vIGFzc2VydCBhcHBfY2FsbC5hcHBfYXJncygwKSA9PSBhcmM0LmFyYzRfc2lnbmF0dXJlKAogICAgZHVwCiAgICBwdXNoaW50IDAgLy8gMAogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjQtMjYKICAgIC8vIGFzc2VydCBhcHBfY2FsbC5hcHBfYXJncygwKSA9PSBhcmM0LmFyYzRfc2lnbmF0dXJlKAogICAgLy8gICAgICJzb21lX3ZhbHVlKCl1aW50NjQiCiAgICAvLyApLCAiZXhwZWN0ZWQgY29ycmVjdCBtZXRob2QgY2FsbGVkIgogICAgcHVzaGJ5dGVzIDB4ZDM0NzllNjUgLy8gbWV0aG9kICJzb21lX3ZhbHVlKCl1aW50NjQiCiAgICA9PQogICAgYXNzZXJ0IC8vIGV4cGVjdGVkIGNvcnJlY3QgbWV0aG9kIGNhbGxlZAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weToyNwogICAgLy8gYXNzZXJ0IGFwcF9jYWxsLm51bV9sb2dzID09IDEsICJleHBlY3RlZCBsb2dzIgogICAgZHVwCiAgICBndHhucyBOdW1Mb2dzCiAgICBpbnRjXzAgLy8gMQogICAgPT0KICAgIGFzc2VydCAvLyBleHBlY3RlZCBsb2dzCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjI5CiAgICAvLyBhcmM0LlVJbnQ2NC5mcm9tX2xvZyhhcHBfY2FsbC5sYXN0X2xvZykKICAgIGR1cAogICAgZ3R4bnMgTGFzdExvZwogICAgZHVwCiAgICBleHRyYWN0IDQgMAogICAgc3dhcAogICAgZXh0cmFjdCAwIDQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgPT0KICAgIGFzc2VydCAvLyBhcHBsaWNhdGlvbiBsb2cgdmFsdWUgaXMgbm90IHRoZSByZXN1bHQgb2YgYW4gQUJJIHJldHVybgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weTozMAogICAgLy8gPT0gKGFwcF9jYWxsLmdyb3VwX2luZGV4ICsgMSkgKiBHbG9iYWwuZ3JvdXBfc2l6ZQogICAgc3dhcAogICAgZ3R4bnMgR3JvdXBJbmRleAogICAgaW50Y18wIC8vIDEKICAgICsKICAgIGdsb2JhbCBHcm91cFNpemUKICAgICoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjktMzAKICAgIC8vIGFyYzQuVUludDY0LmZyb21fbG9nKGFwcF9jYWxsLmxhc3RfbG9nKQogICAgLy8gPT0gKGFwcF9jYWxsLmdyb3VwX2luZGV4ICsgMSkgKiBHbG9iYWwuZ3JvdXBfc2l6ZQogICAgaXRvYgogICAgYj09CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjIyCiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc56.json b/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc56.json index b0406d6..a358d5c 100644 --- a/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc56.json +++ b/tests/artifacts/CreatedAppAsset/data/AppExpectingEffects.arc56.json @@ -87,76 +87,68 @@ "sourceInfo": [ { "pc": [ - 44, - 66 + 20 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 188 + 53 ], - "errorMessage": "application log value is not the result of an ABI return" - }, - { - "pc": [ - 114 - ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 47, - 69 + 159 ], - "errorMessage": "can only call when not creating" + "errorMessage": "application log value is not the result of an ABI return" }, { "pc": [ - 140 + 96 ], "errorMessage": "expected app created" }, { "pc": [ - 125 + 81 ], "errorMessage": "expected asset created" }, { "pc": [ - 149 + 105 ], "errorMessage": "expected correct app id" }, { "pc": [ - 134 + 90 ], "errorMessage": "expected correct asset id" }, { "pc": [ - 166 + 139 ], "errorMessage": "expected correct method called" }, { "pc": [ - 173 + 145 ], "errorMessage": "expected logs" }, { "pc": [ - 81 + 65 ], "errorMessage": "transaction type is acfg" }, { "pc": [ - 57, - 91 + 75, + 126 ], "errorMessage": "transaction type is appl" } @@ -169,18 +161,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0 6
    bytecblock 0x151f7c75
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@7
    pushbytess 0x6d3a0439 0x62a0ef62 // method "create_group(acfg,appl)(uint64,uint64)", method "log_group(appl)void"
    txna ApplicationArgs 0
    match main_create_group_route@3 main_log_group_route@4

main_after_if_else@11:
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    intc_1 // 0
    return

main_log_group_route@4:
    // tests/artifacts/CreatedAppAsset/contract.py:22
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    // tests/artifacts/CreatedAppAsset/contract.py:22
    // @arc4.abimethod
    callsub log_group
    intc_0 // 1
    return

main_create_group_route@3:
    // tests/artifacts/CreatedAppAsset/contract.py:5
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn GroupIndex
    pushint 2 // 2
    -
    dup
    gtxns TypeEnum
    pushint 3 // acfg
    ==
    assert // transaction type is acfg
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_2 // appl
    ==
    assert // transaction type is appl
    // tests/artifacts/CreatedAppAsset/contract.py:5
    // @arc4.abimethod
    callsub create_group
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@7:
    // tests/artifacts/CreatedAppAsset/contract.py:4
    // class AppExpectingEffects(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@11
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.create_group(asset_create: uint64, app_create: uint64) -> uint64, uint64:
create_group:
    // tests/artifacts/CreatedAppAsset/contract.py:5-10
    // @arc4.abimethod
    // def create_group(
    //     self,
    //     asset_create: gtxn.AssetConfigTransaction,
    //     app_create: gtxn.ApplicationCallTransaction,
    // ) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/CreatedAppAsset/contract.py:11
    // assert asset_create.created_asset.id, "expected asset created"
    frame_dig -2
    gtxns CreatedAssetID
    dup
    assert // expected asset created
    // tests/artifacts/CreatedAppAsset/contract.py:13
    // op.gaid(asset_create.group_index) == asset_create.created_asset.id
    frame_dig -2
    gtxns GroupIndex
    gaids
    dig 1
    ==
    // tests/artifacts/CreatedAppAsset/contract.py:12-14
    // assert (
    //     op.gaid(asset_create.group_index) == asset_create.created_asset.id
    // ), "expected correct asset id"
    assert // expected correct asset id
    // tests/artifacts/CreatedAppAsset/contract.py:15
    // assert app_create.created_app.id, "expected app created"
    frame_dig -1
    gtxns CreatedApplicationID
    dup
    assert // expected app created
    // tests/artifacts/CreatedAppAsset/contract.py:17
    // op.gaid(app_create.group_index) == app_create.created_app.id
    frame_dig -1
    gtxns GroupIndex
    gaids
    dig 1
    ==
    // tests/artifacts/CreatedAppAsset/contract.py:16-18
    // assert (
    //     op.gaid(app_create.group_index) == app_create.created_app.id
    // ), "expected correct app id"
    assert // expected correct app id
    // tests/artifacts/CreatedAppAsset/contract.py:20
    // return asset_create.created_asset.id, app_create.created_app.id
    retsub


// tests.artifacts.CreatedAppAsset.contract.AppExpectingEffects.log_group(app_call: uint64) -> void:
log_group:
    // tests/artifacts/CreatedAppAsset/contract.py:22-23
    // @arc4.abimethod
    // def log_group(self, app_call: gtxn.ApplicationCallTransaction) -> None:
    proto 1 0
    // tests/artifacts/CreatedAppAsset/contract.py:24
    // assert app_call.app_args(0) == arc4.arc4_signature(
    frame_dig -1
    intc_1 // 0
    gtxnsas ApplicationArgs
    // tests/artifacts/CreatedAppAsset/contract.py:24-26
    // assert app_call.app_args(0) == arc4.arc4_signature(
    //     "some_value()uint64"
    // ), "expected correct method called"
    pushbytes 0xd3479e65 // method "some_value()uint64"
    ==
    assert // expected correct method called
    // tests/artifacts/CreatedAppAsset/contract.py:27
    // assert app_call.num_logs == 1, "expected logs"
    frame_dig -1
    gtxns NumLogs
    intc_0 // 1
    ==
    assert // expected logs
    // tests/artifacts/CreatedAppAsset/contract.py:29
    // arc4.UInt64.from_log(app_call.last_log)
    frame_dig -1
    gtxns LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // application log value is not the result of an ABI return
    // tests/artifacts/CreatedAppAsset/contract.py:30
    // == (app_call.group_index + 1) * Global.group_size
    frame_dig -1
    gtxns GroupIndex
    intc_0 // 1
    +
    global GroupSize
    *
    // tests/artifacts/CreatedAppAsset/contract.py:29-30
    // arc4.UInt64.from_log(app_call.last_log)
    // == (app_call.group_index + 1) * Global.group_size
    itob
    b==
    // tests/artifacts/CreatedAppAsset/contract.py:28-31
    // assert (
    //     arc4.UInt64.from_log(app_call.last_log)
    //     == (app_call.group_index + 1) * Global.group_size
    // )
    assert
    retsub
", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDYKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBBcHBFeHBlY3RpbmdFZmZlY3RzKEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA5CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICBhc3NlcnQgLy8gT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydAogICAgcHVzaGJ5dGVzcyAweDZkM2EwNDM5IDB4NjJhMGVmNjIgLy8gbWV0aG9kICJjcmVhdGVfZ3JvdXAoYWNmZyxhcHBsKSh1aW50NjQsdWludDY0KSIsIG1ldGhvZCAibG9nX2dyb3VwKGFwcGwpdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIGNyZWF0ZV9ncm91cCBsb2dfZ3JvdXAKICAgIGVycgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA5OgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLkNyZWF0ZWRBcHBBc3NldC5jb250cmFjdC5BcHBFeHBlY3RpbmdFZmZlY3RzLmNyZWF0ZV9ncm91cFtyb3V0aW5nXSgpIC0+IHZvaWQ6CmNyZWF0ZV9ncm91cDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kCiAgICB0eG4gR3JvdXBJbmRleAogICAgcHVzaGludCAyIC8vIDIKICAgIC0KICAgIGR1cAogICAgZ3R4bnMgVHlwZUVudW0KICAgIHB1c2hpbnQgMyAvLyBhY2ZnCiAgICA9PQogICAgYXNzZXJ0IC8vIHRyYW5zYWN0aW9uIHR5cGUgaXMgYWNmZwogICAgdHhuIEdyb3VwSW5kZXgKICAgIGludGNfMCAvLyAxCiAgICAtCiAgICBkdXAKICAgIGd0eG5zIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydCAvLyB0cmFuc2FjdGlvbiB0eXBlIGlzIGFwcGwKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MTEKICAgIC8vIGFzc2VydCBhc3NldF9jcmVhdGUuY3JlYXRlZF9hc3NldC5pZCwgImV4cGVjdGVkIGFzc2V0IGNyZWF0ZWQiCiAgICBkaWcgMQogICAgZ3R4bnMgQ3JlYXRlZEFzc2V0SUQKICAgIGR1cAogICAgYXNzZXJ0IC8vIGV4cGVjdGVkIGFzc2V0IGNyZWF0ZWQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MTMKICAgIC8vIG9wLmdhaWQoYXNzZXRfY3JlYXRlLmdyb3VwX2luZGV4KSA9PSBhc3NldF9jcmVhdGUuY3JlYXRlZF9hc3NldC5pZAogICAgdW5jb3ZlciAyCiAgICBndHhucyBHcm91cEluZGV4CiAgICBnYWlkcwogICAgZGlnIDEKICAgID09CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjEyLTE0CiAgICAvLyBhc3NlcnQgKAogICAgLy8gICAgIG9wLmdhaWQoYXNzZXRfY3JlYXRlLmdyb3VwX2luZGV4KSA9PSBhc3NldF9jcmVhdGUuY3JlYXRlZF9hc3NldC5pZAogICAgLy8gKSwgImV4cGVjdGVkIGNvcnJlY3QgYXNzZXQgaWQiCiAgICBhc3NlcnQgLy8gZXhwZWN0ZWQgY29ycmVjdCBhc3NldCBpZAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weToxNQogICAgLy8gYXNzZXJ0IGFwcF9jcmVhdGUuY3JlYXRlZF9hcHAuaWQsICJleHBlY3RlZCBhcHAgY3JlYXRlZCIKICAgIGRpZyAxCiAgICBndHhucyBDcmVhdGVkQXBwbGljYXRpb25JRAogICAgZHVwCiAgICBhc3NlcnQgLy8gZXhwZWN0ZWQgYXBwIGNyZWF0ZWQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MTcKICAgIC8vIG9wLmdhaWQoYXBwX2NyZWF0ZS5ncm91cF9pbmRleCkgPT0gYXBwX2NyZWF0ZS5jcmVhdGVkX2FwcC5pZAogICAgdW5jb3ZlciAyCiAgICBndHhucyBHcm91cEluZGV4CiAgICBnYWlkcwogICAgZGlnIDEKICAgID09CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjE2LTE4CiAgICAvLyBhc3NlcnQgKAogICAgLy8gICAgIG9wLmdhaWQoYXBwX2NyZWF0ZS5ncm91cF9pbmRleCkgPT0gYXBwX2NyZWF0ZS5jcmVhdGVkX2FwcC5pZAogICAgLy8gKSwgImV4cGVjdGVkIGNvcnJlY3QgYXBwIGlkIgogICAgYXNzZXJ0IC8vIGV4cGVjdGVkIGNvcnJlY3QgYXBwIGlkCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgc3dhcAogICAgaXRvYgogICAgc3dhcAogICAgaXRvYgogICAgY29uY2F0CiAgICBieXRlY18wIC8vIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBpbnRjXzAgLy8gMQogICAgcmV0dXJuCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLkNyZWF0ZWRBcHBBc3NldC5jb250cmFjdC5BcHBFeHBlY3RpbmdFZmZlY3RzLmxvZ19ncm91cFtyb3V0aW5nXSgpIC0+IHZvaWQ6CmxvZ19ncm91cDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjIKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgdHhuIEdyb3VwSW5kZXgKICAgIGludGNfMCAvLyAxCiAgICAtCiAgICBkdXAKICAgIGd0eG5zIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydCAvLyB0cmFuc2FjdGlvbiB0eXBlIGlzIGFwcGwKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjQKICAgIC8vIGFzc2VydCBhcHBfY2FsbC5hcHBfYXJncygwKSA9PSBhcmM0LmFyYzRfc2lnbmF0dXJlKAogICAgZHVwCiAgICBwdXNoaW50IDAgLy8gMAogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjQtMjYKICAgIC8vIGFzc2VydCBhcHBfY2FsbC5hcHBfYXJncygwKSA9PSBhcmM0LmFyYzRfc2lnbmF0dXJlKAogICAgLy8gICAgICJzb21lX3ZhbHVlKCl1aW50NjQiCiAgICAvLyApLCAiZXhwZWN0ZWQgY29ycmVjdCBtZXRob2QgY2FsbGVkIgogICAgcHVzaGJ5dGVzIDB4ZDM0NzllNjUgLy8gbWV0aG9kICJzb21lX3ZhbHVlKCl1aW50NjQiCiAgICA9PQogICAgYXNzZXJ0IC8vIGV4cGVjdGVkIGNvcnJlY3QgbWV0aG9kIGNhbGxlZAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weToyNwogICAgLy8gYXNzZXJ0IGFwcF9jYWxsLm51bV9sb2dzID09IDEsICJleHBlY3RlZCBsb2dzIgogICAgZHVwCiAgICBndHhucyBOdW1Mb2dzCiAgICBpbnRjXzAgLy8gMQogICAgPT0KICAgIGFzc2VydCAvLyBleHBlY3RlZCBsb2dzCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjI5CiAgICAvLyBhcmM0LlVJbnQ2NC5mcm9tX2xvZyhhcHBfY2FsbC5sYXN0X2xvZykKICAgIGR1cAogICAgZ3R4bnMgTGFzdExvZwogICAgZHVwCiAgICBleHRyYWN0IDQgMAogICAgc3dhcAogICAgZXh0cmFjdCAwIDQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgPT0KICAgIGFzc2VydCAvLyBhcHBsaWNhdGlvbiBsb2cgdmFsdWUgaXMgbm90IHRoZSByZXN1bHQgb2YgYW4gQUJJIHJldHVybgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0NyZWF0ZWRBcHBBc3NldC9jb250cmFjdC5weTozMAogICAgLy8gPT0gKGFwcF9jYWxsLmdyb3VwX2luZGV4ICsgMSkgKiBHbG9iYWwuZ3JvdXBfc2l6ZQogICAgc3dhcAogICAgZ3R4bnMgR3JvdXBJbmRleAogICAgaW50Y18wIC8vIDEKICAgICsKICAgIGdsb2JhbCBHcm91cFNpemUKICAgICoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9DcmVhdGVkQXBwQXNzZXQvY29udHJhY3QucHk6MjktMzAKICAgIC8vIGFyYzQuVUludDY0LmZyb21fbG9nKGFwcF9jYWxsLmxhc3RfbG9nKQogICAgLy8gPT0gKGFwcF9jYWxsLmdyb3VwX2luZGV4ICsgMSkgKiBHbG9iYWwuZ3JvdXBfc2l6ZQogICAgaXRvYgogICAgYj09CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvQ3JlYXRlZEFwcEFzc2V0L2NvbnRyYWN0LnB5OjIyCiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiADAQAGJgEEFR98dTEbQQBYggIEbToEOQRioO9iNhoAjgIAGAACI0MxGRREMRhEMRYiCUk4ECQSRIgAWiJDMRkURDEYRDEWgQIJSTgQgQMSRDEWIglJOBAkEkSIABZMFkwWUChMULAiQzEZQP+4MRgURCJDigICi/44PElEi/44Fj1LARJEi/84PUlEi/84Fj1LARJEiYoBAIv/I8IagATTR55lEkSL/zg7IhJEi/84PklXBABMVwAEKBJEi/84FiIIMgQLFqhEiQ==", + "approval": "CiACAQYmAQQVH3x1MRtBAB0xGRREMRhEggIEbToEOQRioO9iNhoAjgIACQBIADEZFDEYFBBDMRaBAglJOBCBAxJEMRYiCUk4ECMSREsBODxJRE8COBY9SwESREsBOD1JRE8COBY9SwESREwWTBZQKExQsCJDMRYiCUk4ECMSREmBAMIagATTR55lEkRJODsiEkRJOD5JVwQATFcABCgSREw4FiIIMgQLFqhD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/CryptoOps/data/CryptoOpsContract.approval.teal b/tests/artifacts/CryptoOps/data/CryptoOpsContract.approval.teal index 691c4f3..6aba79b 100644 --- a/tests/artifacts/CryptoOps/data/CryptoOpsContract.approval.teal +++ b/tests/artifacts/CryptoOps/data/CryptoOpsContract.approval.teal @@ -3,517 +3,29 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 0 1 4 3000 - bytecblock 0x151f7c75 0x00 0x0004 0x068101 + intcblock 0 1 3000 4 + bytecblock 0x151f7c75 0x00 0x151f7c750020 0x0004 0x068101 // tests/artifacts/CryptoOps/contract.py:4 // class CryptoOpsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@18 - pushbytess 0x3456c4c3 0xe8442b84 0x65f567aa 0x258455b1 0x35af0f38 0x6582c997 0x6298ffbb 0x3885b54f 0x2164e0bf 0x755b79a5 0xf06bb077 0x133f8ccc 0x2f7c68a9 // method "verify_sha256(byte[],uint64)byte[]", method "verify_sha3_256(byte[],uint64)byte[]", method "verify_keccak_256(byte[],uint64)byte[]", method "verify_sha512_256(byte[],uint64)byte[]", method "verify_ed25519verify(byte[],byte[],byte[])bool", method "verify_ed25519verify_bare(byte[],byte[],byte[])bool", method "verify_ecdsa_verify_k1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_verify_r1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_recover_k1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_recover_r1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_decompress_k1(byte[])(byte[],byte[])", method "verify_ecdsa_decompress_r1(byte[])(byte[],byte[])", method "verify_vrf_verify(byte[],byte[],byte[])(byte[],bool)" - txna ApplicationArgs 0 - match main_verify_sha256_route@3 main_verify_sha3_256_route@4 main_verify_keccak_256_route@5 main_verify_sha512_256_route@6 main_verify_ed25519verify_route@7 main_verify_ed25519verify_bare_route@8 main_verify_ecdsa_verify_k1_route@9 main_verify_ecdsa_verify_r1_route@10 main_verify_ecdsa_recover_k1_route@11 main_verify_ecdsa_recover_r1_route@12 main_verify_ecdsa_decompress_k1_route@13 main_verify_ecdsa_decompress_r1_route@14 main_verify_vrf_verify_route@15 - -main_after_if_else@22: - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - intc_0 // 0 - return - -main_verify_vrf_verify_route@15: - // tests/artifacts/CryptoOps/contract.py:80 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:80 - // @arc4.abimethod() - callsub verify_vrf_verify - dig 1 - len - itob - extract 6 2 - uncover 2 - concat - bytec_1 // 0x00 - intc_0 // 0 - uncover 3 - setbit - pushbytes 0x0003 - swap - concat - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ecdsa_decompress_r1_route@14: - // tests/artifacts/CryptoOps/contract.py:75 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:75 - // @arc4.abimethod() - callsub verify_ecdsa_decompress_r1 - dig 1 - len - itob - extract 6 2 - uncover 2 - concat - dup - len - intc_2 // 4 - + - dig 2 - len - itob - extract 6 2 - uncover 3 - concat - swap - itob - extract 6 2 - bytec_2 // 0x0004 - swap - concat - uncover 2 - concat - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ecdsa_decompress_k1_route@13: - // tests/artifacts/CryptoOps/contract.py:70 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:70 - // @arc4.abimethod() - callsub verify_ecdsa_decompress_k1 - dig 1 - len - itob - extract 6 2 - uncover 2 - concat - dup - len - intc_2 // 4 - + - dig 2 - len - itob - extract 6 2 - uncover 3 - concat - swap - itob - extract 6 2 - bytec_2 // 0x0004 - swap - concat - uncover 2 - concat - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ecdsa_recover_r1_route@12: - // tests/artifacts/CryptoOps/contract.py:60 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - txna ApplicationArgs 3 - extract 2 0 - txna ApplicationArgs 4 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:60 - // @arc4.abimethod() - callsub verify_ecdsa_recover_r1 - dig 1 - len - itob - extract 6 2 - uncover 2 - concat - dup - len - intc_2 // 4 - + - dig 2 - len - itob - extract 6 2 - uncover 3 - concat - swap - itob - extract 6 2 - bytec_2 // 0x0004 - swap - concat - uncover 2 - concat - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ecdsa_recover_k1_route@11: - // tests/artifacts/CryptoOps/contract.py:53 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - txna ApplicationArgs 3 - extract 2 0 - txna ApplicationArgs 4 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:53 - // @arc4.abimethod() - callsub verify_ecdsa_recover_k1 - dig 1 - len - itob - extract 6 2 - uncover 2 - concat - dup - len - intc_2 // 4 - + - dig 2 - len - itob - extract 6 2 - uncover 3 - concat - swap - itob - extract 6 2 - bytec_2 // 0x0004 - swap - concat - uncover 2 - concat - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ecdsa_verify_r1_route@10: - // tests/artifacts/CryptoOps/contract.py:47 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - extract 2 0 - txna ApplicationArgs 4 - extract 2 0 - txna ApplicationArgs 5 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:47 - // @arc4.abimethod() - callsub verify_ecdsa_verify_r1 - bytec_1 // 0x00 - intc_0 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ecdsa_verify_k1_route@9: - // tests/artifacts/CryptoOps/contract.py:41 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - extract 2 0 - txna ApplicationArgs 4 - extract 2 0 - txna ApplicationArgs 5 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:41 - // @arc4.abimethod() - callsub verify_ecdsa_verify_k1 - bytec_1 // 0x00 - intc_0 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ed25519verify_bare_route@8: - // tests/artifacts/CryptoOps/contract.py:35 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:35 - // @arc4.abimethod() - callsub verify_ed25519verify_bare - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_ed25519verify_route@7: - // tests/artifacts/CryptoOps/contract.py:29 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - extract 2 0 - // tests/artifacts/CryptoOps/contract.py:29 - // @arc4.abimethod() - callsub verify_ed25519verify - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_sha512_256_route@6: - // tests/artifacts/CryptoOps/contract.py:23 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/CryptoOps/contract.py:23 - // @arc4.abimethod() - callsub verify_sha512_256 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_keccak_256_route@5: - // tests/artifacts/CryptoOps/contract.py:17 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/CryptoOps/contract.py:17 - // @arc4.abimethod() - callsub verify_keccak_256 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_verify_sha3_256_route@4: - // tests/artifacts/CryptoOps/contract.py:11 - // @arc4.abimethod() + bz main___algopy_default_create@20 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/CryptoOps/contract.py:11 - // @arc4.abimethod() - callsub verify_sha3_256 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return + assert + pushbytess 0x3456c4c3 0xe8442b84 0x65f567aa 0x258455b1 0x35af0f38 0x6582c997 0x6298ffbb 0x3885b54f 0x2164e0bf 0x755b79a5 0xf06bb077 0x133f8ccc 0x2f7c68a9 // method "verify_sha256(byte[],uint64)byte[]", method "verify_sha3_256(byte[],uint64)byte[]", method "verify_keccak_256(byte[],uint64)byte[]", method "verify_sha512_256(byte[],uint64)byte[]", method "verify_ed25519verify(byte[],byte[],byte[])bool", method "verify_ed25519verify_bare(byte[],byte[],byte[])bool", method "verify_ecdsa_verify_k1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_verify_r1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_recover_k1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_recover_r1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_decompress_k1(byte[])(byte[],byte[])", method "verify_ecdsa_decompress_r1(byte[])(byte[],byte[])", method "verify_vrf_verify(byte[],byte[],byte[])(byte[],bool)" + txna ApplicationArgs 0 + match verify_sha256 verify_sha3_256 verify_keccak_256 verify_sha512_256 verify_ed25519verify verify_ed25519verify_bare verify_ecdsa_verify_k1 verify_ecdsa_verify_r1 verify_ecdsa_recover_k1 verify_ecdsa_recover_r1 verify_ecdsa_decompress_k1 verify_ecdsa_decompress_r1 verify_vrf_verify + err -main_verify_sha256_route@3: - // tests/artifacts/CryptoOps/contract.py:5 - // @arc4.abimethod() +main___algopy_default_create@20: txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/CryptoOps/contract.py:5 - // @arc4.abimethod() - callsub verify_sha256 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_bare_routing@18: - // tests/artifacts/CryptoOps/contract.py:4 - // class CryptoOpsContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@22 txn ApplicationID ! - assert // can only call when creating - intc_1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating // _puya_lib.util.ensure_budget(required_budget: uint64, fee_source: uint64) -> void: @@ -527,131 +39,151 @@ ensure_budget_while_top@1: frame_dig 0 global OpcodeBudget > - bz ensure_budget_after_while@7 + bz ensure_budget_after_while@6 itxn_begin pushint 6 // appl itxn_field TypeEnum pushint 5 // DeleteApplication itxn_field OnCompletion - bytec_3 // 0x068101 + bytec 4 // 0x068101 itxn_field ApprovalProgram - bytec_3 // 0x068101 + bytec 4 // 0x068101 itxn_field ClearStateProgram frame_dig -1 switch ensure_budget_switch_case_0@3 ensure_budget_switch_case_1@4 -ensure_budget_switch_case_next@6: +ensure_budget_switch_case_next@5: itxn_submit b ensure_budget_while_top@1 ensure_budget_switch_case_1@4: global MinTxnFee itxn_field Fee - b ensure_budget_switch_case_next@6 + b ensure_budget_switch_case_next@5 ensure_budget_switch_case_0@3: intc_0 // 0 itxn_field Fee - b ensure_budget_switch_case_next@6 + b ensure_budget_switch_case_next@5 -ensure_budget_after_while@7: +ensure_budget_after_while@6: retsub -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha256(a: bytes, pad_size: uint64) -> bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha256[routing]() -> void: verify_sha256: - // tests/artifacts/CryptoOps/contract.py:5-6 + // tests/artifacts/CryptoOps/contract.py:5 // @arc4.abimethod() - // def verify_sha256(self, a: Bytes, pad_size: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/CryptoOps/contract.py:7 // a = op.bzero(pad_size) + a - frame_dig -1 bzero - frame_dig -2 + swap concat - dup - frame_bury -2 // tests/artifacts/CryptoOps/contract.py:8 // result = op.sha256(a) sha256 - // tests/artifacts/CryptoOps/contract.py:9 - // return result - retsub + // tests/artifacts/CryptoOps/contract.py:5 + // @arc4.abimethod() + bytec_2 // 0x151f7c750020 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha3_256(a: bytes, pad_size: uint64) -> bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha3_256[routing]() -> void: verify_sha3_256: - // tests/artifacts/CryptoOps/contract.py:11-12 + // tests/artifacts/CryptoOps/contract.py:11 // @arc4.abimethod() - // def verify_sha3_256(self, a: Bytes, pad_size: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/CryptoOps/contract.py:13 // a = op.bzero(pad_size) + a - frame_dig -1 bzero - frame_dig -2 + swap concat - dup - frame_bury -2 // tests/artifacts/CryptoOps/contract.py:14 // result = op.sha3_256(a) sha3_256 - // tests/artifacts/CryptoOps/contract.py:15 - // return result - retsub + // tests/artifacts/CryptoOps/contract.py:11 + // @arc4.abimethod() + bytec_2 // 0x151f7c750020 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_keccak_256(a: bytes, pad_size: uint64) -> bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_keccak_256[routing]() -> void: verify_keccak_256: - // tests/artifacts/CryptoOps/contract.py:17-18 + // tests/artifacts/CryptoOps/contract.py:17 // @arc4.abimethod() - // def verify_keccak_256(self, a: Bytes, pad_size: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/CryptoOps/contract.py:19 // a = op.bzero(pad_size) + a - frame_dig -1 bzero - frame_dig -2 + swap concat - dup - frame_bury -2 // tests/artifacts/CryptoOps/contract.py:20 // result = op.keccak256(a) keccak256 - // tests/artifacts/CryptoOps/contract.py:21 - // return result - retsub + // tests/artifacts/CryptoOps/contract.py:17 + // @arc4.abimethod() + bytec_2 // 0x151f7c750020 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha512_256(a: bytes, pad_size: uint64) -> bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha512_256[routing]() -> void: verify_sha512_256: - // tests/artifacts/CryptoOps/contract.py:23-24 + // tests/artifacts/CryptoOps/contract.py:23 // @arc4.abimethod() - // def verify_sha512_256(self, a: Bytes, pad_size: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/CryptoOps/contract.py:25 // a = op.bzero(pad_size) + a - frame_dig -1 bzero - frame_dig -2 + swap concat - dup - frame_bury -2 // tests/artifacts/CryptoOps/contract.py:26 // result = op.sha512_256(a) sha512_256 - // tests/artifacts/CryptoOps/contract.py:27 - // return result - retsub + // tests/artifacts/CryptoOps/contract.py:23 + // @arc4.abimethod() + bytec_2 // 0x151f7c750020 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify(a: bytes, b: bytes, c: bytes) -> bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify[routing]() -> void: verify_ed25519verify: - // tests/artifacts/CryptoOps/contract.py:29-30 + // tests/artifacts/CryptoOps/contract.py:29 // @arc4.abimethod() - // def verify_ed25519verify(self, a: Bytes, b: Bytes, c: Bytes) -> arc4.Bool: - proto 3 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:31 // ensure_budget(1900, OpUpFeeSource.GroupCredit) pushint 1900 // 1900 @@ -659,9 +191,6 @@ verify_ed25519verify: callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:32 // result = op.ed25519verify(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 ed25519verify // tests/artifacts/CryptoOps/contract.py:33 // return arc4.Bool(result) @@ -669,15 +198,26 @@ verify_ed25519verify: intc_0 // 0 uncover 2 setbit - retsub + // tests/artifacts/CryptoOps/contract.py:29 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify_bare(a: bytes, b: bytes, c: bytes) -> bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify_bare[routing]() -> void: verify_ed25519verify_bare: - // tests/artifacts/CryptoOps/contract.py:35-36 + // tests/artifacts/CryptoOps/contract.py:35 // @arc4.abimethod() - // def verify_ed25519verify_bare(self, a: Bytes, b: Bytes, c: Bytes) -> arc4.Bool: - proto 3 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:37 // ensure_budget(1900, OpUpFeeSource.GroupCredit) pushint 1900 // 1900 @@ -685,9 +225,6 @@ verify_ed25519verify_bare: callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:38 // result = op.ed25519verify_bare(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 ed25519verify_bare // tests/artifacts/CryptoOps/contract.py:39 // return arc4.Bool(result) @@ -695,109 +232,206 @@ verify_ed25519verify_bare: intc_0 // 0 uncover 2 setbit - retsub + // tests/artifacts/CryptoOps/contract.py:35 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_k1(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes) -> uint64: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_k1[routing]() -> void: verify_ecdsa_verify_k1: - // tests/artifacts/CryptoOps/contract.py:41-42 + // tests/artifacts/CryptoOps/contract.py:41 // @arc4.abimethod() - // def verify_ecdsa_verify_k1(self, a: Bytes, b: Bytes, c: Bytes, d: Bytes, e: Bytes) -> bool: - proto 5 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + extract 2 0 + txna ApplicationArgs 4 + extract 2 0 + txna ApplicationArgs 5 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:43 // ensure_budget(3000, OpUpFeeSource.GroupCredit) - intc_3 // 3000 + intc_2 // 3000 intc_0 // 0 callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:44 // result_k1 = op.ecdsa_verify(op.ECDSA.Secp256k1, a, b, c, d, e) - frame_dig -5 - frame_dig -4 - frame_dig -3 - frame_dig -2 - frame_dig -1 ecdsa_verify Secp256k1 - // tests/artifacts/CryptoOps/contract.py:45 - // return result_k1 - retsub + // tests/artifacts/CryptoOps/contract.py:41 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_0 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_r1(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes) -> uint64: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_r1[routing]() -> void: verify_ecdsa_verify_r1: - // tests/artifacts/CryptoOps/contract.py:47-48 + // tests/artifacts/CryptoOps/contract.py:47 // @arc4.abimethod() - // def verify_ecdsa_verify_r1(self, a: Bytes, b: Bytes, c: Bytes, d: Bytes, e: Bytes) -> bool: - proto 5 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + extract 2 0 + txna ApplicationArgs 4 + extract 2 0 + txna ApplicationArgs 5 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:49 // ensure_budget(3000, OpUpFeeSource.GroupCredit) - intc_3 // 3000 + intc_2 // 3000 intc_0 // 0 callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:50 // result_r1 = op.ecdsa_verify(op.ECDSA.Secp256r1, a, b, c, d, e) - frame_dig -5 - frame_dig -4 - frame_dig -3 - frame_dig -2 - frame_dig -1 ecdsa_verify Secp256r1 - // tests/artifacts/CryptoOps/contract.py:51 - // return result_r1 - retsub + // tests/artifacts/CryptoOps/contract.py:47 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_0 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_k1(a: bytes, b: uint64, c: bytes, d: bytes) -> bytes, bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_k1[routing]() -> void: verify_ecdsa_recover_k1: - // tests/artifacts/CryptoOps/contract.py:53-56 + // tests/artifacts/CryptoOps/contract.py:53 // @arc4.abimethod() - // def verify_ecdsa_recover_k1( - // self, a: Bytes, b: UInt64, c: Bytes, d: Bytes - // ) -> tuple[Bytes, Bytes]: - proto 4 2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + extract 2 0 + txna ApplicationArgs 4 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:57 // ensure_budget(3000, OpUpFeeSource.GroupCredit) - intc_3 // 3000 + intc_2 // 3000 intc_0 // 0 callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:58 // return op.ecdsa_pk_recover(op.ECDSA.Secp256k1, a, b, c, d) - frame_dig -4 - frame_dig -3 - frame_dig -2 - frame_dig -1 ecdsa_pk_recover Secp256k1 - retsub + // tests/artifacts/CryptoOps/contract.py:53 + // @arc4.abimethod() + dig 1 + len + itob + extract 6 2 + uncover 2 + concat + dup + len + intc_3 // 4 + + + dig 2 + len + itob + extract 6 2 + uncover 3 + concat + swap + itob + extract 6 2 + bytec_3 // 0x0004 + swap + concat + uncover 2 + concat + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_r1(a: bytes, b: uint64, c: bytes, d: bytes) -> bytes, bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_r1[routing]() -> void: verify_ecdsa_recover_r1: - // tests/artifacts/CryptoOps/contract.py:60-63 + // tests/artifacts/CryptoOps/contract.py:60 // @arc4.abimethod() - // def verify_ecdsa_recover_r1( - // self, a: Bytes, b: UInt64, c: Bytes, d: Bytes - // ) -> tuple[Bytes, Bytes]: - proto 4 2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + extract 2 0 + txna ApplicationArgs 4 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:67 // ensure_budget(3000, OpUpFeeSource.GroupCredit) - intc_3 // 3000 + intc_2 // 3000 intc_0 // 0 callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:68 // return op.ecdsa_pk_recover(op.ECDSA.Secp256r1, a, b, c, d) - frame_dig -4 - frame_dig -3 - frame_dig -2 - frame_dig -1 ecdsa_pk_recover Secp256r1 - retsub + // tests/artifacts/CryptoOps/contract.py:60 + // @arc4.abimethod() + dig 1 + len + itob + extract 6 2 + uncover 2 + concat + dup + len + intc_3 // 4 + + + dig 2 + len + itob + extract 6 2 + uncover 3 + concat + swap + itob + extract 6 2 + bytec_3 // 0x0004 + swap + concat + uncover 2 + concat + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_k1(a: bytes) -> bytes, bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_k1[routing]() -> void: verify_ecdsa_decompress_k1: - // tests/artifacts/CryptoOps/contract.py:70-71 + // tests/artifacts/CryptoOps/contract.py:70 // @arc4.abimethod() - // def verify_ecdsa_decompress_k1(self, a: Bytes) -> tuple[Bytes, Bytes]: - proto 1 2 + txna ApplicationArgs 1 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:72 // ensure_budget(700, OpUpFeeSource.GroupCredit) pushint 700 // 700 @@ -805,17 +439,49 @@ verify_ecdsa_decompress_k1: callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:73 // return op.ecdsa_pk_decompress(op.ECDSA.Secp256k1, a) - frame_dig -1 ecdsa_pk_decompress Secp256k1 - retsub + // tests/artifacts/CryptoOps/contract.py:70 + // @arc4.abimethod() + dig 1 + len + itob + extract 6 2 + uncover 2 + concat + dup + len + intc_3 // 4 + + + dig 2 + len + itob + extract 6 2 + uncover 3 + concat + swap + itob + extract 6 2 + bytec_3 // 0x0004 + swap + concat + uncover 2 + concat + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_r1(a: bytes) -> bytes, bytes: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_r1[routing]() -> void: verify_ecdsa_decompress_r1: - // tests/artifacts/CryptoOps/contract.py:75-76 + // tests/artifacts/CryptoOps/contract.py:75 // @arc4.abimethod() - // def verify_ecdsa_decompress_r1(self, a: Bytes) -> tuple[Bytes, Bytes]: - proto 1 2 + txna ApplicationArgs 1 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:77 // ensure_budget(700, OpUpFeeSource.GroupCredit) pushint 700 // 700 @@ -823,17 +489,53 @@ verify_ecdsa_decompress_r1: callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:78 // return op.ecdsa_pk_decompress(op.ECDSA.Secp256r1, a) - frame_dig -1 ecdsa_pk_decompress Secp256r1 - retsub + // tests/artifacts/CryptoOps/contract.py:75 + // @arc4.abimethod() + dig 1 + len + itob + extract 6 2 + uncover 2 + concat + dup + len + intc_3 // 4 + + + dig 2 + len + itob + extract 6 2 + uncover 3 + concat + swap + itob + extract 6 2 + bytec_3 // 0x0004 + swap + concat + uncover 2 + concat + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return -// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_vrf_verify(a: bytes, b: bytes, c: bytes) -> bytes, uint64: +// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_vrf_verify[routing]() -> void: verify_vrf_verify: - // tests/artifacts/CryptoOps/contract.py:80-81 + // tests/artifacts/CryptoOps/contract.py:80 // @arc4.abimethod() - // def verify_vrf_verify(self, a: Bytes, b: Bytes, c: Bytes) -> tuple[Bytes, bool]: - proto 3 2 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + extract 2 0 // tests/artifacts/CryptoOps/contract.py:82 // ensure_budget(5700, OpUpFeeSource.GroupCredit) pushint 5700 // 5700 @@ -841,10 +543,27 @@ verify_vrf_verify: callsub ensure_budget // tests/artifacts/CryptoOps/contract.py:83 // result = op.vrf_verify(op.VrfVerify.VrfAlgorand, a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 vrf_verify VrfAlgorand - // tests/artifacts/CryptoOps/contract.py:84 - // return result - retsub + // tests/artifacts/CryptoOps/contract.py:80 + // @arc4.abimethod() + dig 1 + len + itob + extract 6 2 + uncover 2 + concat + bytec_1 // 0x00 + intc_0 // 0 + uncover 3 + setbit + pushbytes 0x0003 + swap + concat + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_1 // 1 + return diff --git a/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc32.json b/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc32.json index 5ad6251..0ba03d9 100644 --- a/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc32.json +++ b/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc32.json @@ -67,7 +67,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 4 3000
    bytecblock 0x151f7c75 0x00 0x0004 0x068101
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@18
    pushbytess 0x3456c4c3 0xe8442b84 0x65f567aa 0x258455b1 0x35af0f38 0x6582c997 0x6298ffbb 0x3885b54f 0x2164e0bf 0x755b79a5 0xf06bb077 0x133f8ccc 0x2f7c68a9 // method "verify_sha256(byte[],uint64)byte[]", method "verify_sha3_256(byte[],uint64)byte[]", method "verify_keccak_256(byte[],uint64)byte[]", method "verify_sha512_256(byte[],uint64)byte[]", method "verify_ed25519verify(byte[],byte[],byte[])bool", method "verify_ed25519verify_bare(byte[],byte[],byte[])bool", method "verify_ecdsa_verify_k1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_verify_r1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_recover_k1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_recover_r1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_decompress_k1(byte[])(byte[],byte[])", method "verify_ecdsa_decompress_r1(byte[])(byte[],byte[])", method "verify_vrf_verify(byte[],byte[],byte[])(byte[],bool)"
    txna ApplicationArgs 0
    match main_verify_sha256_route@3 main_verify_sha3_256_route@4 main_verify_keccak_256_route@5 main_verify_sha512_256_route@6 main_verify_ed25519verify_route@7 main_verify_ed25519verify_bare_route@8 main_verify_ecdsa_verify_k1_route@9 main_verify_ecdsa_verify_r1_route@10 main_verify_ecdsa_recover_k1_route@11 main_verify_ecdsa_recover_r1_route@12 main_verify_ecdsa_decompress_k1_route@13 main_verify_ecdsa_decompress_r1_route@14 main_verify_vrf_verify_route@15

main_after_if_else@22:
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    intc_0 // 0
    return

main_verify_vrf_verify_route@15:
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    callsub verify_vrf_verify
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    bytec_1 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    pushbytes 0x0003
    swap
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_decompress_r1_route@14:
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    callsub verify_ecdsa_decompress_r1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_decompress_k1_route@13:
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    callsub verify_ecdsa_decompress_k1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_recover_r1_route@12:
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    callsub verify_ecdsa_recover_r1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_recover_k1_route@11:
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    callsub verify_ecdsa_recover_k1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_verify_r1_route@10:
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    callsub verify_ecdsa_verify_r1
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_verify_k1_route@9:
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    callsub verify_ecdsa_verify_k1
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ed25519verify_bare_route@8:
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    callsub verify_ed25519verify_bare
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ed25519verify_route@7:
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    callsub verify_ed25519verify
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_sha512_256_route@6:
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    callsub verify_sha512_256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_keccak_256_route@5:
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    callsub verify_keccak_256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_sha3_256_route@4:
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    callsub verify_sha3_256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_sha256_route@3:
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    callsub verify_sha256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_bare_routing@18:
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@22
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.util.ensure_budget(required_budget: uint64, fee_source: uint64) -> void:
ensure_budget:
    proto 2 0
    frame_dig -2
    pushint 10 // 10
    +

ensure_budget_while_top@1:
    frame_dig 0
    global OpcodeBudget
    >
    bz ensure_budget_after_while@7
    itxn_begin
    pushint 6 // appl
    itxn_field TypeEnum
    pushint 5 // DeleteApplication
    itxn_field OnCompletion
    bytec_3 // 0x068101
    itxn_field ApprovalProgram
    bytec_3 // 0x068101
    itxn_field ClearStateProgram
    frame_dig -1
    switch ensure_budget_switch_case_0@3 ensure_budget_switch_case_1@4

ensure_budget_switch_case_next@6:
    itxn_submit
    b ensure_budget_while_top@1

ensure_budget_switch_case_1@4:
    global MinTxnFee
    itxn_field Fee
    b ensure_budget_switch_case_next@6

ensure_budget_switch_case_0@3:
    intc_0 // 0
    itxn_field Fee
    b ensure_budget_switch_case_next@6

ensure_budget_after_while@7:
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha256(a: bytes, pad_size: uint64) -> bytes:
verify_sha256:
    // tests/artifacts/CryptoOps/contract.py:5-6
    // @arc4.abimethod()
    // def verify_sha256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:7
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:8
    // result = op.sha256(a)
    sha256
    // tests/artifacts/CryptoOps/contract.py:9
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha3_256(a: bytes, pad_size: uint64) -> bytes:
verify_sha3_256:
    // tests/artifacts/CryptoOps/contract.py:11-12
    // @arc4.abimethod()
    // def verify_sha3_256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:13
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:14
    // result = op.sha3_256(a)
    sha3_256
    // tests/artifacts/CryptoOps/contract.py:15
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_keccak_256(a: bytes, pad_size: uint64) -> bytes:
verify_keccak_256:
    // tests/artifacts/CryptoOps/contract.py:17-18
    // @arc4.abimethod()
    // def verify_keccak_256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:19
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:20
    // result = op.keccak256(a)
    keccak256
    // tests/artifacts/CryptoOps/contract.py:21
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha512_256(a: bytes, pad_size: uint64) -> bytes:
verify_sha512_256:
    // tests/artifacts/CryptoOps/contract.py:23-24
    // @arc4.abimethod()
    // def verify_sha512_256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:25
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:26
    // result = op.sha512_256(a)
    sha512_256
    // tests/artifacts/CryptoOps/contract.py:27
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify(a: bytes, b: bytes, c: bytes) -> bytes:
verify_ed25519verify:
    // tests/artifacts/CryptoOps/contract.py:29-30
    // @arc4.abimethod()
    // def verify_ed25519verify(self, a: Bytes, b: Bytes, c: Bytes) -> arc4.Bool:
    proto 3 1
    // tests/artifacts/CryptoOps/contract.py:31
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:32
    // result = op.ed25519verify(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ed25519verify
    // tests/artifacts/CryptoOps/contract.py:33
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify_bare(a: bytes, b: bytes, c: bytes) -> bytes:
verify_ed25519verify_bare:
    // tests/artifacts/CryptoOps/contract.py:35-36
    // @arc4.abimethod()
    // def verify_ed25519verify_bare(self, a: Bytes, b: Bytes, c: Bytes) -> arc4.Bool:
    proto 3 1
    // tests/artifacts/CryptoOps/contract.py:37
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:38
    // result = op.ed25519verify_bare(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ed25519verify_bare
    // tests/artifacts/CryptoOps/contract.py:39
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_k1(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes) -> uint64:
verify_ecdsa_verify_k1:
    // tests/artifacts/CryptoOps/contract.py:41-42
    // @arc4.abimethod()
    // def verify_ecdsa_verify_k1(self, a: Bytes, b: Bytes, c: Bytes, d: Bytes, e: Bytes) -> bool:
    proto 5 1
    // tests/artifacts/CryptoOps/contract.py:43
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:44
    // result_k1 = op.ecdsa_verify(op.ECDSA.Secp256k1, a, b, c, d, e)
    frame_dig -5
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_verify Secp256k1
    // tests/artifacts/CryptoOps/contract.py:45
    // return result_k1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_r1(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes) -> uint64:
verify_ecdsa_verify_r1:
    // tests/artifacts/CryptoOps/contract.py:47-48
    // @arc4.abimethod()
    // def verify_ecdsa_verify_r1(self, a: Bytes, b: Bytes, c: Bytes, d: Bytes, e: Bytes) -> bool:
    proto 5 1
    // tests/artifacts/CryptoOps/contract.py:49
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:50
    // result_r1 = op.ecdsa_verify(op.ECDSA.Secp256r1, a, b, c, d, e)
    frame_dig -5
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_verify Secp256r1
    // tests/artifacts/CryptoOps/contract.py:51
    // return result_r1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_k1(a: bytes, b: uint64, c: bytes, d: bytes) -> bytes, bytes:
verify_ecdsa_recover_k1:
    // tests/artifacts/CryptoOps/contract.py:53-56
    // @arc4.abimethod()
    // def verify_ecdsa_recover_k1(
    //     self, a: Bytes, b: UInt64, c: Bytes, d: Bytes
    // ) -> tuple[Bytes, Bytes]:
    proto 4 2
    // tests/artifacts/CryptoOps/contract.py:57
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:58
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256k1, a, b, c, d)
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_pk_recover Secp256k1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_r1(a: bytes, b: uint64, c: bytes, d: bytes) -> bytes, bytes:
verify_ecdsa_recover_r1:
    // tests/artifacts/CryptoOps/contract.py:60-63
    // @arc4.abimethod()
    // def verify_ecdsa_recover_r1(
    //     self, a: Bytes, b: UInt64, c: Bytes, d: Bytes
    // ) -> tuple[Bytes, Bytes]:
    proto 4 2
    // tests/artifacts/CryptoOps/contract.py:67
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:68
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256r1, a, b, c, d)
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_pk_recover Secp256r1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_k1(a: bytes) -> bytes, bytes:
verify_ecdsa_decompress_k1:
    // tests/artifacts/CryptoOps/contract.py:70-71
    // @arc4.abimethod()
    // def verify_ecdsa_decompress_k1(self, a: Bytes) -> tuple[Bytes, Bytes]:
    proto 1 2
    // tests/artifacts/CryptoOps/contract.py:72
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:73
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256k1, a)
    frame_dig -1
    ecdsa_pk_decompress Secp256k1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_r1(a: bytes) -> bytes, bytes:
verify_ecdsa_decompress_r1:
    // tests/artifacts/CryptoOps/contract.py:75-76
    // @arc4.abimethod()
    // def verify_ecdsa_decompress_r1(self, a: Bytes) -> tuple[Bytes, Bytes]:
    proto 1 2
    // tests/artifacts/CryptoOps/contract.py:77
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:78
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256r1, a)
    frame_dig -1
    ecdsa_pk_decompress Secp256r1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_vrf_verify(a: bytes, b: bytes, c: bytes) -> bytes, uint64:
verify_vrf_verify:
    // tests/artifacts/CryptoOps/contract.py:80-81
    // @arc4.abimethod()
    // def verify_vrf_verify(self, a: Bytes, b: Bytes, c: Bytes) -> tuple[Bytes, bool]:
    proto 3 2
    // tests/artifacts/CryptoOps/contract.py:82
    // ensure_budget(5700, OpUpFeeSource.GroupCredit)
    pushint 5700 // 5700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:83
    // result = op.vrf_verify(op.VrfVerify.VrfAlgorand, a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    vrf_verify VrfAlgorand
    // tests/artifacts/CryptoOps/contract.py:84
    // return result
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 3000 4
    bytecblock 0x151f7c75 0x00 0x151f7c750020 0x0004 0x068101
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@20
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x3456c4c3 0xe8442b84 0x65f567aa 0x258455b1 0x35af0f38 0x6582c997 0x6298ffbb 0x3885b54f 0x2164e0bf 0x755b79a5 0xf06bb077 0x133f8ccc 0x2f7c68a9 // method "verify_sha256(byte[],uint64)byte[]", method "verify_sha3_256(byte[],uint64)byte[]", method "verify_keccak_256(byte[],uint64)byte[]", method "verify_sha512_256(byte[],uint64)byte[]", method "verify_ed25519verify(byte[],byte[],byte[])bool", method "verify_ed25519verify_bare(byte[],byte[],byte[])bool", method "verify_ecdsa_verify_k1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_verify_r1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_recover_k1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_recover_r1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_decompress_k1(byte[])(byte[],byte[])", method "verify_ecdsa_decompress_r1(byte[])(byte[],byte[])", method "verify_vrf_verify(byte[],byte[],byte[])(byte[],bool)"
    txna ApplicationArgs 0
    match verify_sha256 verify_sha3_256 verify_keccak_256 verify_sha512_256 verify_ed25519verify verify_ed25519verify_bare verify_ecdsa_verify_k1 verify_ecdsa_verify_r1 verify_ecdsa_recover_k1 verify_ecdsa_recover_r1 verify_ecdsa_decompress_k1 verify_ecdsa_decompress_r1 verify_vrf_verify
    err

main___algopy_default_create@20:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// _puya_lib.util.ensure_budget(required_budget: uint64, fee_source: uint64) -> void:
ensure_budget:
    proto 2 0
    frame_dig -2
    pushint 10 // 10
    +

ensure_budget_while_top@1:
    frame_dig 0
    global OpcodeBudget
    >
    bz ensure_budget_after_while@6
    itxn_begin
    pushint 6 // appl
    itxn_field TypeEnum
    pushint 5 // DeleteApplication
    itxn_field OnCompletion
    bytec 4 // 0x068101
    itxn_field ApprovalProgram
    bytec 4 // 0x068101
    itxn_field ClearStateProgram
    frame_dig -1
    switch ensure_budget_switch_case_0@3 ensure_budget_switch_case_1@4

ensure_budget_switch_case_next@5:
    itxn_submit
    b ensure_budget_while_top@1

ensure_budget_switch_case_1@4:
    global MinTxnFee
    itxn_field Fee
    b ensure_budget_switch_case_next@5

ensure_budget_switch_case_0@3:
    intc_0 // 0
    itxn_field Fee
    b ensure_budget_switch_case_next@5

ensure_budget_after_while@6:
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha256[routing]() -> void:
verify_sha256:
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:7
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:8
    // result = op.sha256(a)
    sha256
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha3_256[routing]() -> void:
verify_sha3_256:
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:13
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:14
    // result = op.sha3_256(a)
    sha3_256
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_keccak_256[routing]() -> void:
verify_keccak_256:
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:19
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:20
    // result = op.keccak256(a)
    keccak256
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha512_256[routing]() -> void:
verify_sha512_256:
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:25
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:26
    // result = op.sha512_256(a)
    sha512_256
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify[routing]() -> void:
verify_ed25519verify:
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:31
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:32
    // result = op.ed25519verify(a, b, c)
    ed25519verify
    // tests/artifacts/CryptoOps/contract.py:33
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify_bare[routing]() -> void:
verify_ed25519verify_bare:
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:37
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:38
    // result = op.ed25519verify_bare(a, b, c)
    ed25519verify_bare
    // tests/artifacts/CryptoOps/contract.py:39
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_k1[routing]() -> void:
verify_ecdsa_verify_k1:
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:43
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:44
    // result_k1 = op.ecdsa_verify(op.ECDSA.Secp256k1, a, b, c, d, e)
    ecdsa_verify Secp256k1
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_r1[routing]() -> void:
verify_ecdsa_verify_r1:
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:49
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:50
    // result_r1 = op.ecdsa_verify(op.ECDSA.Secp256r1, a, b, c, d, e)
    ecdsa_verify Secp256r1
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_k1[routing]() -> void:
verify_ecdsa_recover_k1:
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:57
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:58
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256k1, a, b, c, d)
    ecdsa_pk_recover Secp256k1
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_r1[routing]() -> void:
verify_ecdsa_recover_r1:
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:67
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:68
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256r1, a, b, c, d)
    ecdsa_pk_recover Secp256r1
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_k1[routing]() -> void:
verify_ecdsa_decompress_k1:
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:72
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:73
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256k1, a)
    ecdsa_pk_decompress Secp256k1
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_r1[routing]() -> void:
verify_ecdsa_decompress_r1:
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:77
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:78
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256r1, a)
    ecdsa_pk_decompress Secp256r1
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_vrf_verify[routing]() -> void:
verify_vrf_verify:
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:82
    // ensure_budget(5700, OpUpFeeSource.GroupCredit)
    pushint 5700 // 5700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:83
    // result = op.vrf_verify(op.VrfVerify.VrfAlgorand, a, b, c)
    vrf_verify VrfAlgorand
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    bytec_1 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    pushbytes 0x0003
    swap
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc56.json b/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc56.json index da104f0..cb61e14 100644 --- a/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc56.json +++ b/tests/artifacts/CryptoOps/data/CryptoOpsContract.arc56.json @@ -411,45 +411,15 @@ "sourceInfo": [ { "pc": [ - 132, - 189, - 248, - 307, - 382, - 457, - 508, - 559, - 593, - 627, - 661, - 695, - 729 + 39 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 768 + 149 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 135, - 192, - 251, - 310, - 385, - 460, - 511, - 562, - 596, - 630, - 664, - 698, - 732 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" } ], "pcOffsetMethod": "none" @@ -460,18 +430,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 4 3000
    bytecblock 0x151f7c75 0x00 0x0004 0x068101
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@18
    pushbytess 0x3456c4c3 0xe8442b84 0x65f567aa 0x258455b1 0x35af0f38 0x6582c997 0x6298ffbb 0x3885b54f 0x2164e0bf 0x755b79a5 0xf06bb077 0x133f8ccc 0x2f7c68a9 // method "verify_sha256(byte[],uint64)byte[]", method "verify_sha3_256(byte[],uint64)byte[]", method "verify_keccak_256(byte[],uint64)byte[]", method "verify_sha512_256(byte[],uint64)byte[]", method "verify_ed25519verify(byte[],byte[],byte[])bool", method "verify_ed25519verify_bare(byte[],byte[],byte[])bool", method "verify_ecdsa_verify_k1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_verify_r1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_recover_k1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_recover_r1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_decompress_k1(byte[])(byte[],byte[])", method "verify_ecdsa_decompress_r1(byte[])(byte[],byte[])", method "verify_vrf_verify(byte[],byte[],byte[])(byte[],bool)"
    txna ApplicationArgs 0
    match main_verify_sha256_route@3 main_verify_sha3_256_route@4 main_verify_keccak_256_route@5 main_verify_sha512_256_route@6 main_verify_ed25519verify_route@7 main_verify_ed25519verify_bare_route@8 main_verify_ecdsa_verify_k1_route@9 main_verify_ecdsa_verify_r1_route@10 main_verify_ecdsa_recover_k1_route@11 main_verify_ecdsa_recover_r1_route@12 main_verify_ecdsa_decompress_k1_route@13 main_verify_ecdsa_decompress_r1_route@14 main_verify_vrf_verify_route@15

main_after_if_else@22:
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    intc_0 // 0
    return

main_verify_vrf_verify_route@15:
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    callsub verify_vrf_verify
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    bytec_1 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    pushbytes 0x0003
    swap
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_decompress_r1_route@14:
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    callsub verify_ecdsa_decompress_r1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_decompress_k1_route@13:
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    callsub verify_ecdsa_decompress_k1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_recover_r1_route@12:
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    callsub verify_ecdsa_recover_r1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_recover_k1_route@11:
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    callsub verify_ecdsa_recover_k1
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_2 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_2 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_verify_r1_route@10:
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    callsub verify_ecdsa_verify_r1
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ecdsa_verify_k1_route@9:
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    callsub verify_ecdsa_verify_k1
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ed25519verify_bare_route@8:
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    callsub verify_ed25519verify_bare
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_ed25519verify_route@7:
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    callsub verify_ed25519verify
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_sha512_256_route@6:
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    callsub verify_sha512_256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_keccak_256_route@5:
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    callsub verify_keccak_256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_sha3_256_route@4:
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    callsub verify_sha3_256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_verify_sha256_route@3:
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    callsub verify_sha256
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_bare_routing@18:
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@22
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.util.ensure_budget(required_budget: uint64, fee_source: uint64) -> void:
ensure_budget:
    proto 2 0
    frame_dig -2
    pushint 10 // 10
    +

ensure_budget_while_top@1:
    frame_dig 0
    global OpcodeBudget
    >
    bz ensure_budget_after_while@7
    itxn_begin
    pushint 6 // appl
    itxn_field TypeEnum
    pushint 5 // DeleteApplication
    itxn_field OnCompletion
    bytec_3 // 0x068101
    itxn_field ApprovalProgram
    bytec_3 // 0x068101
    itxn_field ClearStateProgram
    frame_dig -1
    switch ensure_budget_switch_case_0@3 ensure_budget_switch_case_1@4

ensure_budget_switch_case_next@6:
    itxn_submit
    b ensure_budget_while_top@1

ensure_budget_switch_case_1@4:
    global MinTxnFee
    itxn_field Fee
    b ensure_budget_switch_case_next@6

ensure_budget_switch_case_0@3:
    intc_0 // 0
    itxn_field Fee
    b ensure_budget_switch_case_next@6

ensure_budget_after_while@7:
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha256(a: bytes, pad_size: uint64) -> bytes:
verify_sha256:
    // tests/artifacts/CryptoOps/contract.py:5-6
    // @arc4.abimethod()
    // def verify_sha256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:7
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:8
    // result = op.sha256(a)
    sha256
    // tests/artifacts/CryptoOps/contract.py:9
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha3_256(a: bytes, pad_size: uint64) -> bytes:
verify_sha3_256:
    // tests/artifacts/CryptoOps/contract.py:11-12
    // @arc4.abimethod()
    // def verify_sha3_256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:13
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:14
    // result = op.sha3_256(a)
    sha3_256
    // tests/artifacts/CryptoOps/contract.py:15
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_keccak_256(a: bytes, pad_size: uint64) -> bytes:
verify_keccak_256:
    // tests/artifacts/CryptoOps/contract.py:17-18
    // @arc4.abimethod()
    // def verify_keccak_256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:19
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:20
    // result = op.keccak256(a)
    keccak256
    // tests/artifacts/CryptoOps/contract.py:21
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha512_256(a: bytes, pad_size: uint64) -> bytes:
verify_sha512_256:
    // tests/artifacts/CryptoOps/contract.py:23-24
    // @arc4.abimethod()
    // def verify_sha512_256(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/CryptoOps/contract.py:25
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/CryptoOps/contract.py:26
    // result = op.sha512_256(a)
    sha512_256
    // tests/artifacts/CryptoOps/contract.py:27
    // return result
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify(a: bytes, b: bytes, c: bytes) -> bytes:
verify_ed25519verify:
    // tests/artifacts/CryptoOps/contract.py:29-30
    // @arc4.abimethod()
    // def verify_ed25519verify(self, a: Bytes, b: Bytes, c: Bytes) -> arc4.Bool:
    proto 3 1
    // tests/artifacts/CryptoOps/contract.py:31
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:32
    // result = op.ed25519verify(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ed25519verify
    // tests/artifacts/CryptoOps/contract.py:33
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify_bare(a: bytes, b: bytes, c: bytes) -> bytes:
verify_ed25519verify_bare:
    // tests/artifacts/CryptoOps/contract.py:35-36
    // @arc4.abimethod()
    // def verify_ed25519verify_bare(self, a: Bytes, b: Bytes, c: Bytes) -> arc4.Bool:
    proto 3 1
    // tests/artifacts/CryptoOps/contract.py:37
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:38
    // result = op.ed25519verify_bare(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ed25519verify_bare
    // tests/artifacts/CryptoOps/contract.py:39
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_k1(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes) -> uint64:
verify_ecdsa_verify_k1:
    // tests/artifacts/CryptoOps/contract.py:41-42
    // @arc4.abimethod()
    // def verify_ecdsa_verify_k1(self, a: Bytes, b: Bytes, c: Bytes, d: Bytes, e: Bytes) -> bool:
    proto 5 1
    // tests/artifacts/CryptoOps/contract.py:43
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:44
    // result_k1 = op.ecdsa_verify(op.ECDSA.Secp256k1, a, b, c, d, e)
    frame_dig -5
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_verify Secp256k1
    // tests/artifacts/CryptoOps/contract.py:45
    // return result_k1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_r1(a: bytes, b: bytes, c: bytes, d: bytes, e: bytes) -> uint64:
verify_ecdsa_verify_r1:
    // tests/artifacts/CryptoOps/contract.py:47-48
    // @arc4.abimethod()
    // def verify_ecdsa_verify_r1(self, a: Bytes, b: Bytes, c: Bytes, d: Bytes, e: Bytes) -> bool:
    proto 5 1
    // tests/artifacts/CryptoOps/contract.py:49
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:50
    // result_r1 = op.ecdsa_verify(op.ECDSA.Secp256r1, a, b, c, d, e)
    frame_dig -5
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_verify Secp256r1
    // tests/artifacts/CryptoOps/contract.py:51
    // return result_r1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_k1(a: bytes, b: uint64, c: bytes, d: bytes) -> bytes, bytes:
verify_ecdsa_recover_k1:
    // tests/artifacts/CryptoOps/contract.py:53-56
    // @arc4.abimethod()
    // def verify_ecdsa_recover_k1(
    //     self, a: Bytes, b: UInt64, c: Bytes, d: Bytes
    // ) -> tuple[Bytes, Bytes]:
    proto 4 2
    // tests/artifacts/CryptoOps/contract.py:57
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:58
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256k1, a, b, c, d)
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_pk_recover Secp256k1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_r1(a: bytes, b: uint64, c: bytes, d: bytes) -> bytes, bytes:
verify_ecdsa_recover_r1:
    // tests/artifacts/CryptoOps/contract.py:60-63
    // @arc4.abimethod()
    // def verify_ecdsa_recover_r1(
    //     self, a: Bytes, b: UInt64, c: Bytes, d: Bytes
    // ) -> tuple[Bytes, Bytes]:
    proto 4 2
    // tests/artifacts/CryptoOps/contract.py:67
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_3 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:68
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256r1, a, b, c, d)
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    ecdsa_pk_recover Secp256r1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_k1(a: bytes) -> bytes, bytes:
verify_ecdsa_decompress_k1:
    // tests/artifacts/CryptoOps/contract.py:70-71
    // @arc4.abimethod()
    // def verify_ecdsa_decompress_k1(self, a: Bytes) -> tuple[Bytes, Bytes]:
    proto 1 2
    // tests/artifacts/CryptoOps/contract.py:72
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:73
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256k1, a)
    frame_dig -1
    ecdsa_pk_decompress Secp256k1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_r1(a: bytes) -> bytes, bytes:
verify_ecdsa_decompress_r1:
    // tests/artifacts/CryptoOps/contract.py:75-76
    // @arc4.abimethod()
    // def verify_ecdsa_decompress_r1(self, a: Bytes) -> tuple[Bytes, Bytes]:
    proto 1 2
    // tests/artifacts/CryptoOps/contract.py:77
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:78
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256r1, a)
    frame_dig -1
    ecdsa_pk_decompress Secp256r1
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_vrf_verify(a: bytes, b: bytes, c: bytes) -> bytes, uint64:
verify_vrf_verify:
    // tests/artifacts/CryptoOps/contract.py:80-81
    // @arc4.abimethod()
    // def verify_vrf_verify(self, a: Bytes, b: Bytes, c: Bytes) -> tuple[Bytes, bool]:
    proto 3 2
    // tests/artifacts/CryptoOps/contract.py:82
    // ensure_budget(5700, OpUpFeeSource.GroupCredit)
    pushint 5700 // 5700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:83
    // result = op.vrf_verify(op.VrfVerify.VrfAlgorand, a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    vrf_verify VrfAlgorand
    // tests/artifacts/CryptoOps/contract.py:84
    // return result
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 3000 4
    bytecblock 0x151f7c75 0x00 0x151f7c750020 0x0004 0x068101
    // tests/artifacts/CryptoOps/contract.py:4
    // class CryptoOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@20
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x3456c4c3 0xe8442b84 0x65f567aa 0x258455b1 0x35af0f38 0x6582c997 0x6298ffbb 0x3885b54f 0x2164e0bf 0x755b79a5 0xf06bb077 0x133f8ccc 0x2f7c68a9 // method "verify_sha256(byte[],uint64)byte[]", method "verify_sha3_256(byte[],uint64)byte[]", method "verify_keccak_256(byte[],uint64)byte[]", method "verify_sha512_256(byte[],uint64)byte[]", method "verify_ed25519verify(byte[],byte[],byte[])bool", method "verify_ed25519verify_bare(byte[],byte[],byte[])bool", method "verify_ecdsa_verify_k1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_verify_r1(byte[],byte[],byte[],byte[],byte[])bool", method "verify_ecdsa_recover_k1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_recover_r1(byte[],uint64,byte[],byte[])(byte[],byte[])", method "verify_ecdsa_decompress_k1(byte[])(byte[],byte[])", method "verify_ecdsa_decompress_r1(byte[])(byte[],byte[])", method "verify_vrf_verify(byte[],byte[],byte[])(byte[],bool)"
    txna ApplicationArgs 0
    match verify_sha256 verify_sha3_256 verify_keccak_256 verify_sha512_256 verify_ed25519verify verify_ed25519verify_bare verify_ecdsa_verify_k1 verify_ecdsa_verify_r1 verify_ecdsa_recover_k1 verify_ecdsa_recover_r1 verify_ecdsa_decompress_k1 verify_ecdsa_decompress_r1 verify_vrf_verify
    err

main___algopy_default_create@20:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// _puya_lib.util.ensure_budget(required_budget: uint64, fee_source: uint64) -> void:
ensure_budget:
    proto 2 0
    frame_dig -2
    pushint 10 // 10
    +

ensure_budget_while_top@1:
    frame_dig 0
    global OpcodeBudget
    >
    bz ensure_budget_after_while@6
    itxn_begin
    pushint 6 // appl
    itxn_field TypeEnum
    pushint 5 // DeleteApplication
    itxn_field OnCompletion
    bytec 4 // 0x068101
    itxn_field ApprovalProgram
    bytec 4 // 0x068101
    itxn_field ClearStateProgram
    frame_dig -1
    switch ensure_budget_switch_case_0@3 ensure_budget_switch_case_1@4

ensure_budget_switch_case_next@5:
    itxn_submit
    b ensure_budget_while_top@1

ensure_budget_switch_case_1@4:
    global MinTxnFee
    itxn_field Fee
    b ensure_budget_switch_case_next@5

ensure_budget_switch_case_0@3:
    intc_0 // 0
    itxn_field Fee
    b ensure_budget_switch_case_next@5

ensure_budget_after_while@6:
    retsub


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha256[routing]() -> void:
verify_sha256:
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:7
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:8
    // result = op.sha256(a)
    sha256
    // tests/artifacts/CryptoOps/contract.py:5
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha3_256[routing]() -> void:
verify_sha3_256:
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:13
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:14
    // result = op.sha3_256(a)
    sha3_256
    // tests/artifacts/CryptoOps/contract.py:11
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_keccak_256[routing]() -> void:
verify_keccak_256:
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:19
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:20
    // result = op.keccak256(a)
    keccak256
    // tests/artifacts/CryptoOps/contract.py:17
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_sha512_256[routing]() -> void:
verify_sha512_256:
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/CryptoOps/contract.py:25
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/CryptoOps/contract.py:26
    // result = op.sha512_256(a)
    sha512_256
    // tests/artifacts/CryptoOps/contract.py:23
    // @arc4.abimethod()
    bytec_2 // 0x151f7c750020
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify[routing]() -> void:
verify_ed25519verify:
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:31
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:32
    // result = op.ed25519verify(a, b, c)
    ed25519verify
    // tests/artifacts/CryptoOps/contract.py:33
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/CryptoOps/contract.py:29
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ed25519verify_bare[routing]() -> void:
verify_ed25519verify_bare:
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:37
    // ensure_budget(1900, OpUpFeeSource.GroupCredit)
    pushint 1900 // 1900
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:38
    // result = op.ed25519verify_bare(a, b, c)
    ed25519verify_bare
    // tests/artifacts/CryptoOps/contract.py:39
    // return arc4.Bool(result)
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/CryptoOps/contract.py:35
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_k1[routing]() -> void:
verify_ecdsa_verify_k1:
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:43
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:44
    // result_k1 = op.ecdsa_verify(op.ECDSA.Secp256k1, a, b, c, d, e)
    ecdsa_verify Secp256k1
    // tests/artifacts/CryptoOps/contract.py:41
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_verify_r1[routing]() -> void:
verify_ecdsa_verify_r1:
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:49
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:50
    // result_r1 = op.ecdsa_verify(op.ECDSA.Secp256r1, a, b, c, d, e)
    ecdsa_verify Secp256r1
    // tests/artifacts/CryptoOps/contract.py:47
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_k1[routing]() -> void:
verify_ecdsa_recover_k1:
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:57
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:58
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256k1, a, b, c, d)
    ecdsa_pk_recover Secp256k1
    // tests/artifacts/CryptoOps/contract.py:53
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_recover_r1[routing]() -> void:
verify_ecdsa_recover_r1:
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:67
    // ensure_budget(3000, OpUpFeeSource.GroupCredit)
    intc_2 // 3000
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:68
    // return op.ecdsa_pk_recover(op.ECDSA.Secp256r1, a, b, c, d)
    ecdsa_pk_recover Secp256r1
    // tests/artifacts/CryptoOps/contract.py:60
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_k1[routing]() -> void:
verify_ecdsa_decompress_k1:
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:72
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:73
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256k1, a)
    ecdsa_pk_decompress Secp256k1
    // tests/artifacts/CryptoOps/contract.py:70
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_ecdsa_decompress_r1[routing]() -> void:
verify_ecdsa_decompress_r1:
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:77
    // ensure_budget(700, OpUpFeeSource.GroupCredit)
    pushint 700 // 700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:78
    // return op.ecdsa_pk_decompress(op.ECDSA.Secp256r1, a)
    ecdsa_pk_decompress Secp256r1
    // tests/artifacts/CryptoOps/contract.py:75
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    dup
    len
    intc_3 // 4
    +
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    itob
    extract 6 2
    bytec_3 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.CryptoOps.contract.CryptoOpsContract.verify_vrf_verify[routing]() -> void:
verify_vrf_verify:
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/CryptoOps/contract.py:82
    // ensure_budget(5700, OpUpFeeSource.GroupCredit)
    pushint 5700 // 5700
    intc_0 // 0
    callsub ensure_budget
    // tests/artifacts/CryptoOps/contract.py:83
    // result = op.vrf_verify(op.VrfVerify.VrfAlgorand, a, b, c)
    vrf_verify VrfAlgorand
    // tests/artifacts/CryptoOps/contract.py:80
    // @arc4.abimethod()
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    bytec_1 // 0x00
    intc_0 // 0
    uncover 3
    setbit
    pushbytes 0x0003
    swap
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAEAAEEuBcmBAQVH3x1AQACAAQDBoEBMRtBAtuCDQQ0VsTDBOhEK4QEZfVnqgQlhFWxBDWvDzgEZYLJlwRimP+7BDiFtU8EIWTgvwR1W3mlBPBrsHcEEz+MzAQvfGipNhoAjg0CVwI1AhMB8QHPAa0BegFHAPwAsQB2ADsAAiJDMRkURDEYRDYaAVcCADYaAlcCADYaA1cCAIgDc0sBFRZXBgJPAlApIk8DVIACAANMUExQKExQsCNDMRkURDEYRDYaAVcCAIgDN0sBFRZXBgJPAlBJFSQISwIVFlcGAk8DUEwWVwYCKkxQTwJQTFAoTFCwI0MxGRREMRhENhoBVwIAiALtSwEVFlcGAk8CUEkVJAhLAhUWVwYCTwNQTBZXBgIqTFBPAlBMUChMULAjQzEZFEQxGEQ2GgFXAgA2GgIXNhoDVwIANhoEVwIAiAKPSwEVFlcGAk8CUEkVJAhLAhUWVwYCTwNQTBZXBgIqTFBPAlBMUChMULAjQzEZFEQxGEQ2GgFXAgA2GgIXNhoDVwIANhoEVwIAiAIxSwEVFlcGAk8CUEkVJAhLAhUWVwYCTwNQTBZXBgIqTFBPAlBMUChMULAjQzEZFEQxGEQ2GgFXAgA2GgJXAgA2GgNXAgA2GgRXAgA2GgVXAgCIAckpIk8CVChMULAjQzEZFEQxGEQ2GgFXAgA2GgJXAgA2GgNXAgA2GgRXAgA2GgVXAgCIAYEpIk8CVChMULAjQzEZFEQxGEQ2GgFXAgA2GgJXAgA2GgNXAgCIAUMoTFCwI0MxGRREMRhENhoBVwIANhoCVwIANhoDVwIAiAEKKExQsCNDMRkURDEYRDYaAVcCADYaAheIAOJJFRZXBgJMUChMULAjQzEZFEQxGEQ2GgFXAgA2GgIXiACySRUWVwYCTFAoTFCwI0MxGRREMRhENhoBVwIANhoCF4gAgkkVFlcGAkxQKExQsCNDMRkURDEYRDYaAVcCADYaAheIAFJJFRZXBgJMUChMULAjQzEZQP2CMRgURCNDigIAi/6BCgiLADIMDUEAKLGBBrIQgQWyGSuyHiuyH4v/jQIACwAEs0L/3TIAsgFC//UisgFC/++JigIBi/+vi/5QSYz+AYmKAgGL/6+L/lBJjP6YiYoCAYv/r4v+UEmM/gKJigIBi/+vi/5QSYz+A4mKAwGB7A4iiP+Fi/2L/ov/BCkiTwJUiYoDAYHsDiKI/26L/Yv+i/+EKSJPAlSJigUBJSKI/1mL+4v8i/2L/ov/BQCJigUBJSKI/0SL+4v8i/2L/ov/BQGJigQCJSKI/y+L/Iv9i/6L/wcAiYoEAiUiiP8ci/yL/Yv+i/8HAYmKAQKBvAUiiP8Hi/8GAImKAQKBvAUiiP74i/8GAYmKAwKBxCwiiP7pi/2L/ov/0ACJ", + "approval": "CiAEAAG4FwQmBQQVH3x1AQAGFR98dQAgAgAEAwaBATEbQQBqMRkURDEYRIINBDRWxMME6EQrhARl9WeqBCWEVbEENa8POARlgsmXBGKY/7sEOIW1TwQhZOC/BHVbeaUE8GuwdwQTP4zMBC98aKk2GgCODQBEAFgAbACAAJQAuQDeAQ4BPgGGAc4CCAJCADEZFDEYFBBDigIAi/6BCgiLADIMDUEAKrGBBrIQgQWyGScEsh4nBLIfi/+NAgALAASzQv/bMgCyAUL/9SKyAUL/74k2GgFXAgA2GgIXr0xQASpMULAjQzYaAVcCADYaAhevTFCYKkxQsCNDNhoBVwIANhoCF69MUAIqTFCwI0M2GgFXAgA2GgIXr0xQAypMULAjQzYaAVcCADYaAlcCADYaA1cCAIHsDiKI/1wEKSJPAlQoTFCwI0M2GgFXAgA2GgJXAgA2GgNXAgCB7A4iiP83hCkiTwJUKExQsCNDNhoBVwIANhoCVwIANhoDVwIANhoEVwIANhoFVwIAJCKI/wgFACkiTwJUKExQsCNDNhoBVwIANhoCVwIANhoDVwIANhoEVwIANhoFVwIAJCKI/tgFASkiTwJUKExQsCNDNhoBVwIANhoCFzYaA1cCADYaBFcCACQiiP6wBwBLARUWVwYCTwJQSRUlCEsCFRZXBgJPA1BMFlcGAitMUE8CUExQKExQsCNDNhoBVwIANhoCFzYaA1cCADYaBFcCACQiiP5oBwFLARUWVwYCTwJQSRUlCEsCFRZXBgJPA1BMFlcGAitMUE8CUExQKExQsCNDNhoBVwIAgbwFIoj+LgYASwEVFlcGAk8CUEkVJQhLAhUWVwYCTwNQTBZXBgIrTFBPAlBMUChMULAjQzYaAVcCAIG8BSKI/fQGAUsBFRZXBgJPAlBJFSUISwIVFlcGAk8DUEwWVwYCK0xQTwJQTFAoTFCwI0M2GgFXAgA2GgJXAgA2GgNXAgCBxCwiiP2u0ABLARUWVwYCTwJQKSJPA1SAAgADTFBMUChMULAjQw==", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.approval.teal b/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.approval.teal index 96aaf25..88e7011 100644 --- a/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.approval.teal +++ b/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.approval.teal @@ -3,58 +3,41 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 bytecblock 0xc0eb5c67 // tests/artifacts/GlobalStateValidator/contract.py:4 // class GlobalStateValidator(ARC4Contract): txn NumAppArgs - bz main_bare_routing@6 + bz main___algopy_default_create@5 bytec_0 // method "validate_g_args(uint64,string)void" txna ApplicationArgs 0 match main_validate_g_args_route@3 - -main_after_if_else@10: - // tests/artifacts/GlobalStateValidator/contract.py:4 - // class GlobalStateValidator(ARC4Contract): - pushint 0 // 0 - return + err main_validate_g_args_route@3: // tests/artifacts/GlobalStateValidator/contract.py:5 // @arc4.abimethod txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/GlobalStateValidator/contract.py:4 - // class GlobalStateValidator(ARC4Contract): - txna ApplicationArgs 1 - txna ApplicationArgs 2 - // tests/artifacts/GlobalStateValidator/contract.py:5 - // @arc4.abimethod - callsub validate_g_args - intc_0 // 1 - return + && + assert // OnCompletion must be NoOp && can only call when not creating + b validate_g_args -main_bare_routing@6: - // tests/artifacts/GlobalStateValidator/contract.py:4 - // class GlobalStateValidator(ARC4Contract): +main___algopy_default_create@5: txn OnCompletion - bnz main_after_if_else@10 + ! txn ApplicationID ! - assert // can only call when creating - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.GlobalStateValidator.contract.GlobalStateValidator.validate_g_args(arg1: bytes, arg2: bytes) -> void: +// tests.artifacts.GlobalStateValidator.contract.GlobalStateValidator.validate_g_args[routing]() -> void: validate_g_args: - // tests/artifacts/GlobalStateValidator/contract.py:5-6 + // tests/artifacts/GlobalStateValidator/contract.py:5 // @arc4.abimethod - // def validate_g_args(self, arg1: arc4.UInt64, arg2: arc4.String) -> None: - proto 2 0 + txna ApplicationArgs 1 + txna ApplicationArgs 2 // tests/artifacts/GlobalStateValidator/contract.py:7 // assert Txn.application_args(0) == arc4.arc4_signature("validate_g_args(uint64,string)void") txna ApplicationArgs 0 @@ -64,13 +47,12 @@ validate_g_args: // tests/artifacts/GlobalStateValidator/contract.py:8 // assert Txn.application_args(1) == arg1.bytes txna ApplicationArgs 1 - frame_dig -2 + dig 2 == assert // tests/artifacts/GlobalStateValidator/contract.py:9 // assert Txn.application_args(2) == arg2.bytes txna ApplicationArgs 2 - frame_dig -1 == assert // tests/artifacts/GlobalStateValidator/contract.py:10 @@ -81,30 +63,30 @@ validate_g_args: pushint 6 // appl == assert // transaction type is appl - intc_0 // 1 + pushint 1 // 1 gtxnsas ApplicationArgs - frame_dig -2 + dig 1 == assert // tests/artifacts/GlobalStateValidator/contract.py:11 // assert gtxn.Transaction(Txn.group_index).app_args(1) == arg1.bytes txn GroupIndex - intc_0 // 1 + pushint 1 // 1 gtxnsas ApplicationArgs - frame_dig -2 + dig 1 == assert // tests/artifacts/GlobalStateValidator/contract.py:12 // assert op.GTxn.application_args(Txn.group_index, 1) == arg1.bytes txn GroupIndex gtxnsa ApplicationArgs 1 - frame_dig -2 + dig 1 == assert // tests/artifacts/GlobalStateValidator/contract.py:13 // assert op.Txn.application_args(1) == arg1.bytes txna ApplicationArgs 1 - frame_dig -2 == - assert - retsub + // tests/artifacts/GlobalStateValidator/contract.py:5 + // @arc4.abimethod + return diff --git a/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc32.json b/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc32.json index f9bfe8e..b96c330 100644 --- a/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc32.json +++ b/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc32.json @@ -7,7 +7,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxCiAgICBieXRlY2Jsb2NrIDB4YzBlYjVjNjcKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBHbG9iYWxTdGF0ZVZhbGlkYXRvcihBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIGJ5dGVjXzAgLy8gbWV0aG9kICJ2YWxpZGF0ZV9nX2FyZ3ModWludDY0LHN0cmluZyl2b2lkIgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl92YWxpZGF0ZV9nX2FyZ3Nfcm91dGVAMwoKbWFpbl9hZnRlcl9pZl9lbHNlQDEwOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEdsb2JhbFN0YXRlVmFsaWRhdG9yKEFSQzRDb250cmFjdCk6CiAgICBwdXNoaW50IDAgLy8gMAogICAgcmV0dXJuCgptYWluX3ZhbGlkYXRlX2dfYXJnc19yb3V0ZUAzOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBpcyBub3QgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NAogICAgLy8gY2xhc3MgR2xvYmFsU3RhdGVWYWxpZGF0b3IoQVJDNENvbnRyYWN0KToKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIGNhbGxzdWIgdmFsaWRhdGVfZ19hcmdzCiAgICBpbnRjXzAgLy8gMQogICAgcmV0dXJuCgptYWluX2JhcmVfcm91dGluZ0A2OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEdsb2JhbFN0YXRlVmFsaWRhdG9yKEFSQzRDb250cmFjdCk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDEwCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5HbG9iYWxTdGF0ZVZhbGlkYXRvci5jb250cmFjdC5HbG9iYWxTdGF0ZVZhbGlkYXRvci52YWxpZGF0ZV9nX2FyZ3MoYXJnMTogYnl0ZXMsIGFyZzI6IGJ5dGVzKSAtPiB2b2lkOgp2YWxpZGF0ZV9nX2FyZ3M6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NS02CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIC8vIGRlZiB2YWxpZGF0ZV9nX2FyZ3Moc2VsZiwgYXJnMTogYXJjNC5VSW50NjQsIGFyZzI6IGFyYzQuU3RyaW5nKSAtPiBOb25lOgogICAgcHJvdG8gMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NwogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDApID09IGFyYzQuYXJjNF9zaWduYXR1cmUoInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiKQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgYnl0ZWNfMCAvLyBtZXRob2QgInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6OAogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDEpID09IGFyZzEuYnl0ZXMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGZyYW1lX2RpZyAtMgogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjkKICAgIC8vIGFzc2VydCBUeG4uYXBwbGljYXRpb25fYXJncygyKSA9PSBhcmcyLmJ5dGVzCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICBmcmFtZV9kaWcgLTEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weToxMAogICAgLy8gYXNzZXJ0IGd0eG4uQXBwbGljYXRpb25DYWxsVHJhbnNhY3Rpb24oVHhuLmdyb3VwX2luZGV4KS5hcHBfYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG4gR3JvdXBJbmRleAogICAgZHVwCiAgICBndHhucyBUeXBlRW51bQogICAgcHVzaGludCA2IC8vIGFwcGwKICAgID09CiAgICBhc3NlcnQgLy8gdHJhbnNhY3Rpb24gdHlwZSBpcyBhcHBsCiAgICBpbnRjXzAgLy8gMQogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIGZyYW1lX2RpZyAtMgogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjExCiAgICAvLyBhc3NlcnQgZ3R4bi5UcmFuc2FjdGlvbihUeG4uZ3JvdXBfaW5kZXgpLmFwcF9hcmdzKDEpID09IGFyZzEuYnl0ZXMKICAgIHR4biBHcm91cEluZGV4CiAgICBpbnRjXzAgLy8gMQogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIGZyYW1lX2RpZyAtMgogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjEyCiAgICAvLyBhc3NlcnQgb3AuR1R4bi5hcHBsaWNhdGlvbl9hcmdzKFR4bi5ncm91cF9pbmRleCwgMSkgPT0gYXJnMS5ieXRlcwogICAgdHhuIEdyb3VwSW5kZXgKICAgIGd0eG5zYSBBcHBsaWNhdGlvbkFyZ3MgMQogICAgZnJhbWVfZGlnIC0yCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6MTMKICAgIC8vIGFzc2VydCBvcC5UeG4uYXBwbGljYXRpb25fYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBmcmFtZV9kaWcgLTIKICAgID09CiAgICBhc3NlcnQKICAgIHJldHN1Ygo=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGJ5dGVjYmxvY2sgMHhjMGViNWM2NwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEdsb2JhbFN0YXRlVmFsaWRhdG9yKEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1CiAgICBieXRlY18wIC8vIG1ldGhvZCAidmFsaWRhdGVfZ19hcmdzKHVpbnQ2NCxzdHJpbmcpdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIG1haW5fdmFsaWRhdGVfZ19hcmdzX3JvdXRlQDMKICAgIGVycgoKbWFpbl92YWxpZGF0ZV9nX2FyZ3Nfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgYiB2YWxpZGF0ZV9nX2FyZ3MKCm1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5HbG9iYWxTdGF0ZVZhbGlkYXRvci5jb250cmFjdC5HbG9iYWxTdGF0ZVZhbGlkYXRvci52YWxpZGF0ZV9nX2FyZ3Nbcm91dGluZ10oKSAtPiB2b2lkOgp2YWxpZGF0ZV9nX2FyZ3M6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NwogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDApID09IGFyYzQuYXJjNF9zaWduYXR1cmUoInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiKQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgYnl0ZWNfMCAvLyBtZXRob2QgInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6OAogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDEpID09IGFyZzEuYnl0ZXMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGRpZyAyCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6OQogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDIpID09IGFyZzIuYnl0ZXMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weToxMAogICAgLy8gYXNzZXJ0IGd0eG4uQXBwbGljYXRpb25DYWxsVHJhbnNhY3Rpb24oVHhuLmdyb3VwX2luZGV4KS5hcHBfYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG4gR3JvdXBJbmRleAogICAgZHVwCiAgICBndHhucyBUeXBlRW51bQogICAgcHVzaGludCA2IC8vIGFwcGwKICAgID09CiAgICBhc3NlcnQgLy8gdHJhbnNhY3Rpb24gdHlwZSBpcyBhcHBsCiAgICBwdXNoaW50IDEgLy8gMQogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIGRpZyAxCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6MTEKICAgIC8vIGFzc2VydCBndHhuLlRyYW5zYWN0aW9uKFR4bi5ncm91cF9pbmRleCkuYXBwX2FyZ3MoMSkgPT0gYXJnMS5ieXRlcwogICAgdHhuIEdyb3VwSW5kZXgKICAgIHB1c2hpbnQgMSAvLyAxCiAgICBndHhuc2FzIEFwcGxpY2F0aW9uQXJncwogICAgZGlnIDEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weToxMgogICAgLy8gYXNzZXJ0IG9wLkdUeG4uYXBwbGljYXRpb25fYXJncyhUeG4uZ3JvdXBfaW5kZXgsIDEpID09IGFyZzEuYnl0ZXMKICAgIHR4biBHcm91cEluZGV4CiAgICBndHhuc2EgQXBwbGljYXRpb25BcmdzIDEKICAgIGRpZyAxCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6MTMKICAgIC8vIGFzc2VydCBvcC5UeG4uYXBwbGljYXRpb25fYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICA9PQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgcmV0dXJuCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc56.json b/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc56.json index 5fb0a8a..9a3c502 100644 --- a/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc56.json +++ b/tests/artifacts/GlobalStateValidator/data/GlobalStateValidator.arc56.json @@ -66,25 +66,19 @@ "sourceInfo": [ { "pc": [ - 30 + 39 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 53 + 28 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when not creating" }, { "pc": [ - 33 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 87 + 72 ], "errorMessage": "transaction type is appl" } @@ -97,18 +91,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxCiAgICBieXRlY2Jsb2NrIDB4YzBlYjVjNjcKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weTo0CiAgICAvLyBjbGFzcyBHbG9iYWxTdGF0ZVZhbGlkYXRvcihBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIGJ5dGVjXzAgLy8gbWV0aG9kICJ2YWxpZGF0ZV9nX2FyZ3ModWludDY0LHN0cmluZyl2b2lkIgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl92YWxpZGF0ZV9nX2FyZ3Nfcm91dGVAMwoKbWFpbl9hZnRlcl9pZl9lbHNlQDEwOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEdsb2JhbFN0YXRlVmFsaWRhdG9yKEFSQzRDb250cmFjdCk6CiAgICBwdXNoaW50IDAgLy8gMAogICAgcmV0dXJuCgptYWluX3ZhbGlkYXRlX2dfYXJnc19yb3V0ZUAzOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBpcyBub3QgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NAogICAgLy8gY2xhc3MgR2xvYmFsU3RhdGVWYWxpZGF0b3IoQVJDNENvbnRyYWN0KToKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIGNhbGxzdWIgdmFsaWRhdGVfZ19hcmdzCiAgICBpbnRjXzAgLy8gMQogICAgcmV0dXJuCgptYWluX2JhcmVfcm91dGluZ0A2OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEdsb2JhbFN0YXRlVmFsaWRhdG9yKEFSQzRDb250cmFjdCk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDEwCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5HbG9iYWxTdGF0ZVZhbGlkYXRvci5jb250cmFjdC5HbG9iYWxTdGF0ZVZhbGlkYXRvci52YWxpZGF0ZV9nX2FyZ3MoYXJnMTogYnl0ZXMsIGFyZzI6IGJ5dGVzKSAtPiB2b2lkOgp2YWxpZGF0ZV9nX2FyZ3M6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NS02CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIC8vIGRlZiB2YWxpZGF0ZV9nX2FyZ3Moc2VsZiwgYXJnMTogYXJjNC5VSW50NjQsIGFyZzI6IGFyYzQuU3RyaW5nKSAtPiBOb25lOgogICAgcHJvdG8gMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NwogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDApID09IGFyYzQuYXJjNF9zaWduYXR1cmUoInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiKQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgYnl0ZWNfMCAvLyBtZXRob2QgInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6OAogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDEpID09IGFyZzEuYnl0ZXMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGZyYW1lX2RpZyAtMgogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjkKICAgIC8vIGFzc2VydCBUeG4uYXBwbGljYXRpb25fYXJncygyKSA9PSBhcmcyLmJ5dGVzCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICBmcmFtZV9kaWcgLTEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weToxMAogICAgLy8gYXNzZXJ0IGd0eG4uQXBwbGljYXRpb25DYWxsVHJhbnNhY3Rpb24oVHhuLmdyb3VwX2luZGV4KS5hcHBfYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG4gR3JvdXBJbmRleAogICAgZHVwCiAgICBndHhucyBUeXBlRW51bQogICAgcHVzaGludCA2IC8vIGFwcGwKICAgID09CiAgICBhc3NlcnQgLy8gdHJhbnNhY3Rpb24gdHlwZSBpcyBhcHBsCiAgICBpbnRjXzAgLy8gMQogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIGZyYW1lX2RpZyAtMgogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjExCiAgICAvLyBhc3NlcnQgZ3R4bi5UcmFuc2FjdGlvbihUeG4uZ3JvdXBfaW5kZXgpLmFwcF9hcmdzKDEpID09IGFyZzEuYnl0ZXMKICAgIHR4biBHcm91cEluZGV4CiAgICBpbnRjXzAgLy8gMQogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIGZyYW1lX2RpZyAtMgogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjEyCiAgICAvLyBhc3NlcnQgb3AuR1R4bi5hcHBsaWNhdGlvbl9hcmdzKFR4bi5ncm91cF9pbmRleCwgMSkgPT0gYXJnMS5ieXRlcwogICAgdHhuIEdyb3VwSW5kZXgKICAgIGd0eG5zYSBBcHBsaWNhdGlvbkFyZ3MgMQogICAgZnJhbWVfZGlnIC0yCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6MTMKICAgIC8vIGFzc2VydCBvcC5UeG4uYXBwbGljYXRpb25fYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBmcmFtZV9kaWcgLTIKICAgID09CiAgICBhc3NlcnQKICAgIHJldHN1Ygo=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGJ5dGVjYmxvY2sgMHhjMGViNWM2NwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjQKICAgIC8vIGNsYXNzIEdsb2JhbFN0YXRlVmFsaWRhdG9yKEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1CiAgICBieXRlY18wIC8vIG1ldGhvZCAidmFsaWRhdGVfZ19hcmdzKHVpbnQ2NCxzdHJpbmcpdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIG1haW5fdmFsaWRhdGVfZ19hcmdzX3JvdXRlQDMKICAgIGVycgoKbWFpbl92YWxpZGF0ZV9nX2FyZ3Nfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weTo1CiAgICAvLyBAYXJjNC5hYmltZXRob2QKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgYiB2YWxpZGF0ZV9nX2FyZ3MKCm1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5HbG9iYWxTdGF0ZVZhbGlkYXRvci5jb250cmFjdC5HbG9iYWxTdGF0ZVZhbGlkYXRvci52YWxpZGF0ZV9nX2FyZ3Nbcm91dGluZ10oKSAtPiB2b2lkOgp2YWxpZGF0ZV9nX2FyZ3M6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6NwogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDApID09IGFyYzQuYXJjNF9zaWduYXR1cmUoInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiKQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgYnl0ZWNfMCAvLyBtZXRob2QgInZhbGlkYXRlX2dfYXJncyh1aW50NjQsc3RyaW5nKXZvaWQiCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6OAogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDEpID09IGFyZzEuYnl0ZXMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGRpZyAyCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6OQogICAgLy8gYXNzZXJ0IFR4bi5hcHBsaWNhdGlvbl9hcmdzKDIpID09IGFyZzIuYnl0ZXMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weToxMAogICAgLy8gYXNzZXJ0IGd0eG4uQXBwbGljYXRpb25DYWxsVHJhbnNhY3Rpb24oVHhuLmdyb3VwX2luZGV4KS5hcHBfYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG4gR3JvdXBJbmRleAogICAgZHVwCiAgICBndHhucyBUeXBlRW51bQogICAgcHVzaGludCA2IC8vIGFwcGwKICAgID09CiAgICBhc3NlcnQgLy8gdHJhbnNhY3Rpb24gdHlwZSBpcyBhcHBsCiAgICBwdXNoaW50IDEgLy8gMQogICAgZ3R4bnNhcyBBcHBsaWNhdGlvbkFyZ3MKICAgIGRpZyAxCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6MTEKICAgIC8vIGFzc2VydCBndHhuLlRyYW5zYWN0aW9uKFR4bi5ncm91cF9pbmRleCkuYXBwX2FyZ3MoMSkgPT0gYXJnMS5ieXRlcwogICAgdHhuIEdyb3VwSW5kZXgKICAgIHB1c2hpbnQgMSAvLyAxCiAgICBndHhuc2FzIEFwcGxpY2F0aW9uQXJncwogICAgZGlnIDEKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9HbG9iYWxTdGF0ZVZhbGlkYXRvci9jb250cmFjdC5weToxMgogICAgLy8gYXNzZXJ0IG9wLkdUeG4uYXBwbGljYXRpb25fYXJncyhUeG4uZ3JvdXBfaW5kZXgsIDEpID09IGFyZzEuYnl0ZXMKICAgIHR4biBHcm91cEluZGV4CiAgICBndHhuc2EgQXBwbGljYXRpb25BcmdzIDEKICAgIGRpZyAxCiAgICA9PQogICAgYXNzZXJ0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvR2xvYmFsU3RhdGVWYWxpZGF0b3IvY29udHJhY3QucHk6MTMKICAgIC8vIGFzc2VydCBvcC5UeG4uYXBwbGljYXRpb25fYXJncygxKSA9PSBhcmcxLmJ5dGVzCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICA9PQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL0dsb2JhbFN0YXRlVmFsaWRhdG9yL2NvbnRyYWN0LnB5OjUKICAgIC8vIEBhcmM0LmFiaW1ldGhvZAogICAgcmV0dXJuCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiABASYBBMDrXGcxG0EAHSg2GgCOAQADgQBDMRkURDEYRDYaATYaAogADSJDMRlA/+YxGBREIkOKAgA2GgAoEkQ2GgGL/hJENhoCi/8SRDEWSTgQgQYSRCLCGov+EkQxFiLCGov+EkQxFjkaAYv+EkQ2GgGL/hJEiQ==", + "approval": "CiYBBMDrXGcxG0EAEyg2GgCOAQABADEZFDEYEERCAAgxGRQxGBQQQzYaATYaAjYaACgSRDYaAUsCEkQ2GgISRDEWSTgQgQYSRIEBwhpLARJEMRaBAcIaSwESRDEWORoBSwESRDYaARJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/MiscellaneousOps/contract.py b/tests/artifacts/MiscellaneousOps/contract.py index 2cf4aab..0e50a02 100644 --- a/tests/artifacts/MiscellaneousOps/contract.py +++ b/tests/artifacts/MiscellaneousOps/contract.py @@ -104,12 +104,12 @@ def verify_extract_uint64(self, a: Bytes, b: UInt64) -> UInt64: return result @arc4.abimethod() - def verify_getbit_bytes(self, a: Bytes, b: UInt64) -> UInt64: + def verify_getbit_bytes(self, a: Bytes, b: UInt64) -> bool: result = op.getbit(a, b) return result @arc4.abimethod() - def verify_getbit_uint64(self, a: UInt64, b: UInt64) -> UInt64: + def verify_getbit_uint64(self, a: UInt64, b: UInt64) -> bool: result = op.getbit(a, b) return result @@ -144,12 +144,12 @@ def verify_select_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64: return result @arc4.abimethod() - def verify_setbit_bytes(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes: + def verify_setbit_bytes(self, a: Bytes, b: UInt64, c: bool) -> Bytes: # noqa: FBT001 result = op.setbit_bytes(a, b, c) return result @arc4.abimethod() - def verify_setbit_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64: + def verify_setbit_uint64(self, a: UInt64, b: UInt64, c: bool) -> UInt64: # noqa: FBT001 result = op.setbit_uint64(a, b, c) return result diff --git a/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.approval.teal b/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.approval.teal index dd2c6d3..8b7cb74 100644 --- a/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.approval.teal +++ b/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.approval.teal @@ -3,44 +3,53 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 - bytecblock 0x151f7c75 + intcblock 1 0 + bytecblock 0x151f7c75 0x151f7c750020 0x00 // tests/artifacts/MiscellaneousOps/contract.py:4 // class MiscellaneousOpsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@42 - pushbytess 0x45847eea 0xf57aceb5 0x7d631730 0xa1b24441 0xcd7be1ac 0x7cfda64b 0x54a910d9 0xc46568de 0x7a46a6ae 0x04372209 0x7e5f6d72 0x24ebcf84 0x9c0b3397 0x0ad40da4 0x95178870 0xdeedc99b 0xab2150bb 0x02a54017 0x3db66b41 0xc7ea8c2a 0x1dcea50c 0x16166f9a 0x2f472065 0xd5a739c3 0x61f3b3e1 0x56cf368b 0x919ffbd2 0x8e30f4e7 0x89f81d92 0xd5260327 0x114c8c6d 0x39e9e62a 0xd6a4c05e 0x1ef8151a 0x66dd7f96 0x4d9eceb2 0x19ba70ee // method "verify_addw(uint64,uint64)(uint64,uint64)", method "verify_base64_decode_standard(byte[])byte[]", method "verify_base64_decode_url(byte[])byte[]", method "verify_bytes_bitlen(byte[],uint64)uint64", method "verify_uint64_bitlen(uint64)uint64", method "verify_bsqrt(byte[])byte[]", method "verify_btoi(byte[])uint64", method "verify_bzero(uint64)byte[]", method "verify_concat(byte[],byte[],uint64,uint64)byte[]", method "verify_divmodw(uint64,uint64,uint64,uint64)(uint64,uint64,uint64,uint64)", method "verify_divw(uint64,uint64,uint64)uint64", method "verify_err()void", method "verify_exp(uint64,uint64)uint64", method "verify_expw(uint64,uint64)(uint64,uint64)", method "verify_extract(byte[],uint64,uint64)byte[]", method "verify_extract_from_2(byte[])byte[]", method "verify_extract_uint16(byte[],uint64)uint64", method "verify_extract_uint32(byte[],uint64)uint64", method "verify_extract_uint64(byte[],uint64)uint64", method "verify_getbit_bytes(byte[],uint64)uint64", method "verify_getbit_uint64(uint64,uint64)uint64", method "verify_getbyte(byte[],uint64)uint64", method "verify_itob(uint64)byte[]", method "verify_mulw(uint64,uint64)(uint64,uint64)", method "verify_replace(byte[],uint64,byte[])byte[]", method "verify_select_bytes(byte[],byte[],uint64)byte[]", method "verify_select_uint64(uint64,uint64,uint64)uint64", method "verify_setbit_bytes(byte[],uint64,uint64)byte[]", method "verify_setbit_uint64(uint64,uint64,uint64)uint64", method "verify_setbyte(byte[],uint64,uint64)byte[]", method "verify_shl(uint64,uint64)uint64", method "verify_shr(uint64,uint64)uint64", method "verify_sqrt(uint64)uint64", method "verify_substring(byte[],uint64,uint64)byte[]", method "verify_json_ref_string(byte[],byte[])byte[]", method "verify_json_ref_uint64(byte[],byte[])uint64", method "verify_json_ref_object(byte[],byte[])byte[]" + bz main___algopy_default_create@44 + txn OnCompletion + ! + assert // OnCompletion must be NoOp + txn ApplicationID + assert + pushbytess 0x45847eea 0xf57aceb5 0x7d631730 0xa1b24441 0xcd7be1ac 0x7cfda64b 0x54a910d9 0xc46568de 0x7a46a6ae 0x04372209 0x7e5f6d72 0x24ebcf84 0x9c0b3397 0x0ad40da4 0x95178870 0xdeedc99b 0xab2150bb 0x02a54017 0x3db66b41 0x6e3ff38c 0x8f3b9f18 0x16166f9a 0x2f472065 0xd5a739c3 0x61f3b3e1 0x56cf368b 0x919ffbd2 0xaae8b697 0x847422b1 0xd5260327 0x114c8c6d 0x39e9e62a 0xd6a4c05e 0x1ef8151a 0x66dd7f96 0x4d9eceb2 0x19ba70ee // method "verify_addw(uint64,uint64)(uint64,uint64)", method "verify_base64_decode_standard(byte[])byte[]", method "verify_base64_decode_url(byte[])byte[]", method "verify_bytes_bitlen(byte[],uint64)uint64", method "verify_uint64_bitlen(uint64)uint64", method "verify_bsqrt(byte[])byte[]", method "verify_btoi(byte[])uint64", method "verify_bzero(uint64)byte[]", method "verify_concat(byte[],byte[],uint64,uint64)byte[]", method "verify_divmodw(uint64,uint64,uint64,uint64)(uint64,uint64,uint64,uint64)", method "verify_divw(uint64,uint64,uint64)uint64", method "verify_err()void", method "verify_exp(uint64,uint64)uint64", method "verify_expw(uint64,uint64)(uint64,uint64)", method "verify_extract(byte[],uint64,uint64)byte[]", method "verify_extract_from_2(byte[])byte[]", method "verify_extract_uint16(byte[],uint64)uint64", method "verify_extract_uint32(byte[],uint64)uint64", method "verify_extract_uint64(byte[],uint64)uint64", method "verify_getbit_bytes(byte[],uint64)bool", method "verify_getbit_uint64(uint64,uint64)bool", method "verify_getbyte(byte[],uint64)uint64", method "verify_itob(uint64)byte[]", method "verify_mulw(uint64,uint64)(uint64,uint64)", method "verify_replace(byte[],uint64,byte[])byte[]", method "verify_select_bytes(byte[],byte[],uint64)byte[]", method "verify_select_uint64(uint64,uint64,uint64)uint64", method "verify_setbit_bytes(byte[],uint64,bool)byte[]", method "verify_setbit_uint64(uint64,uint64,bool)uint64", method "verify_setbyte(byte[],uint64,uint64)byte[]", method "verify_shl(uint64,uint64)uint64", method "verify_shr(uint64,uint64)uint64", method "verify_sqrt(uint64)uint64", method "verify_substring(byte[],uint64,uint64)byte[]", method "verify_json_ref_string(byte[],byte[])byte[]", method "verify_json_ref_uint64(byte[],byte[])uint64", method "verify_json_ref_object(byte[],byte[])byte[]" txna ApplicationArgs 0 - match main_verify_addw_route@3 main_verify_base64_decode_standard_route@4 main_verify_base64_decode_url_route@5 main_verify_bytes_bitlen_route@6 main_verify_uint64_bitlen_route@7 main_verify_bsqrt_route@8 main_verify_btoi_route@9 main_verify_bzero_route@10 main_verify_concat_route@11 main_verify_divmodw_route@12 main_verify_divw_route@13 main_verify_err_route@14 main_verify_exp_route@15 main_verify_expw_route@16 main_verify_extract_route@17 main_verify_extract_from_2_route@18 main_verify_extract_uint16_route@19 main_verify_extract_uint32_route@20 main_verify_extract_uint64_route@21 main_verify_getbit_bytes_route@22 main_verify_getbit_uint64_route@23 main_verify_getbyte_route@24 main_verify_itob_route@25 main_verify_mulw_route@26 main_verify_replace_route@27 main_verify_select_bytes_route@28 main_verify_select_uint64_route@29 main_verify_setbit_bytes_route@30 main_verify_setbit_uint64_route@31 main_verify_setbyte_route@32 main_verify_shl_route@33 main_verify_shr_route@34 main_verify_sqrt_route@35 main_verify_substring_route@36 main_verify_json_ref_string_route@37 main_verify_json_ref_uint64_route@38 main_verify_json_ref_object_route@39 + match verify_addw verify_base64_decode_standard verify_base64_decode_url verify_bytes_bitlen verify_uint64_bitlen verify_bsqrt verify_btoi verify_bzero verify_concat verify_divmodw verify_divw main_verify_err_route@15 verify_exp verify_expw verify_extract verify_extract_from_2 verify_extract_uint16 verify_extract_uint32 verify_extract_uint64 verify_getbit_bytes verify_getbit_uint64 verify_getbyte verify_itob verify_mulw verify_replace verify_select_bytes verify_select_uint64 verify_setbit_bytes verify_setbit_uint64 verify_setbyte verify_shl verify_shr verify_sqrt verify_substring verify_json_ref_string verify_json_ref_uint64 verify_json_ref_object + err -main_after_if_else@46: - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): - pushint 0 // 0 - return +main_verify_err_route@15: + // tests/artifacts/MiscellaneousOps/contract.py:69 + // op.err() + err -main_verify_json_ref_object_route@39: - // tests/artifacts/MiscellaneousOps/contract.py:191 - // @arc4.abimethod() +main___algopy_default_create@44: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): + ! + && + return // on error: OnCompletion must be NoOp && can only call when creating + + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_addw[routing]() -> void: +verify_addw: + // tests/artifacts/MiscellaneousOps/contract.py:5 + // @arc4.abimethod() txna ApplicationArgs 1 - extract 2 0 + btoi txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:191 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:7 + // result = op.addw(a, b) + addw + // tests/artifacts/MiscellaneousOps/contract.py:5 // @arc4.abimethod() - callsub verify_json_ref_object - dup - len + swap itob - extract 6 2 swap + itob concat bytec_0 // 0x151f7c75 swap @@ -49,24 +58,24 @@ main_verify_json_ref_object_route@39: intc_0 // 1 return -main_verify_json_ref_uint64_route@38: - // tests/artifacts/MiscellaneousOps/contract.py:186 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_standard[routing]() -> void: +verify_base64_decode_standard: + // tests/artifacts/MiscellaneousOps/contract.py:10 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:186 + // tests/artifacts/MiscellaneousOps/contract.py:12 + // result = op.base64_decode(op.Base64.StdEncoding, a) + base64_decode StdEncoding + // tests/artifacts/MiscellaneousOps/contract.py:10 // @arc4.abimethod() - callsub verify_json_ref_uint64 + dup + len itob + extract 6 2 + swap + concat bytec_0 // 0x151f7c75 swap concat @@ -74,23 +83,18 @@ main_verify_json_ref_uint64_route@38: intc_0 // 1 return -main_verify_json_ref_string_route@37: - // tests/artifacts/MiscellaneousOps/contract.py:181 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_url[routing]() -> void: +verify_base64_decode_url: + // tests/artifacts/MiscellaneousOps/contract.py:15 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:181 + // tests/artifacts/MiscellaneousOps/contract.py:17 + // result = op.base64_decode(op.Base64.URLEncoding, a) + base64_decode URLEncoding + // tests/artifacts/MiscellaneousOps/contract.py:15 // @arc4.abimethod() - callsub verify_json_ref_string dup len itob @@ -104,31 +108,26 @@ main_verify_json_ref_string_route@37: intc_0 // 1 return -main_verify_substring_route@36: - // tests/artifacts/MiscellaneousOps/contract.py:176 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bytes_bitlen[routing]() -> void: +verify_bytes_bitlen: + // tests/artifacts/MiscellaneousOps/contract.py:20 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 btoi - txna ApplicationArgs 3 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:176 - // @arc4.abimethod() - callsub verify_substring - dup - len - itob - extract 6 2 + // tests/artifacts/MiscellaneousOps/contract.py:22 + // a = op.bzero(pad_a_size) + a + bzero swap concat + // tests/artifacts/MiscellaneousOps/contract.py:23 + // result = op.bitlen(a) + bitlen + // tests/artifacts/MiscellaneousOps/contract.py:20 + // @arc4.abimethod() + itob bytec_0 // 0x151f7c75 swap concat @@ -136,21 +135,18 @@ main_verify_substring_route@36: intc_0 // 1 return -main_verify_sqrt_route@35: - // tests/artifacts/MiscellaneousOps/contract.py:171 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_uint64_bitlen[routing]() -> void: +verify_uint64_bitlen: + // tests/artifacts/MiscellaneousOps/contract.py:26 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 btoi - // tests/artifacts/MiscellaneousOps/contract.py:171 + // tests/artifacts/MiscellaneousOps/contract.py:28 + // result = op.bitlen(a) + bitlen + // tests/artifacts/MiscellaneousOps/contract.py:26 // @arc4.abimethod() - callsub verify_sqrt itob bytec_0 // 0x151f7c75 swap @@ -159,24 +155,24 @@ main_verify_sqrt_route@35: intc_0 // 1 return -main_verify_shr_route@34: - // tests/artifacts/MiscellaneousOps/contract.py:166 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bsqrt[routing]() -> void: +verify_bsqrt: + // tests/artifacts/MiscellaneousOps/contract.py:31 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:166 + extract 2 0 + // tests/artifacts/MiscellaneousOps/contract.py:34 + // result = op.bsqrt(a_biguint) + bsqrt + // tests/artifacts/MiscellaneousOps/contract.py:31 // @arc4.abimethod() - callsub verify_shr + dup + len itob + extract 6 2 + swap + concat bytec_0 // 0x151f7c75 swap concat @@ -184,23 +180,18 @@ main_verify_shr_route@34: intc_0 // 1 return -main_verify_shl_route@33: - // tests/artifacts/MiscellaneousOps/contract.py:161 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_btoi[routing]() -> void: +verify_btoi: + // tests/artifacts/MiscellaneousOps/contract.py:37 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/MiscellaneousOps/contract.py:39 + // result = op.btoi(a) btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:161 + // tests/artifacts/MiscellaneousOps/contract.py:37 // @arc4.abimethod() - callsub verify_shl itob bytec_0 // 0x151f7c75 swap @@ -209,89 +200,96 @@ main_verify_shl_route@33: intc_0 // 1 return -main_verify_setbyte_route@32: - // tests/artifacts/MiscellaneousOps/contract.py:156 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bzero[routing]() -> void: +verify_bzero: + // tests/artifacts/MiscellaneousOps/contract.py:42 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - txna ApplicationArgs 3 btoi - // tests/artifacts/MiscellaneousOps/contract.py:156 + // tests/artifacts/MiscellaneousOps/contract.py:44 + // result = op.bzero(a) + bzero + // tests/artifacts/MiscellaneousOps/contract.py:45 + // return op.sha256(result) + sha256 + // tests/artifacts/MiscellaneousOps/contract.py:42 // @arc4.abimethod() - callsub verify_setbyte - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 + bytec_1 // 0x151f7c750020 swap concat log intc_0 // 1 return -main_verify_setbit_uint64_route@31: - // tests/artifacts/MiscellaneousOps/contract.py:151 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_concat[routing]() -> void: +verify_concat: + // tests/artifacts/MiscellaneousOps/contract.py:47 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - btoi + extract 2 0 txna ApplicationArgs 2 - btoi + extract 2 0 txna ApplicationArgs 3 btoi - // tests/artifacts/MiscellaneousOps/contract.py:151 + txna ApplicationArgs 4 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:49 + // a = op.bzero(pad_a_size) + a + swap + bzero + uncover 3 + concat + // tests/artifacts/MiscellaneousOps/contract.py:50 + // b = op.bzero(pad_b_size) + b + swap + bzero + uncover 2 + concat + // tests/artifacts/MiscellaneousOps/contract.py:51 + // result = a + b + concat + // tests/artifacts/MiscellaneousOps/contract.py:52 + // result = op.sha256(result) + sha256 + // tests/artifacts/MiscellaneousOps/contract.py:47 // @arc4.abimethod() - callsub verify_setbit_uint64 - itob - bytec_0 // 0x151f7c75 + bytec_1 // 0x151f7c750020 swap concat log intc_0 // 1 return -main_verify_setbit_bytes_route@30: - // tests/artifacts/MiscellaneousOps/contract.py:146 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divmodw[routing]() -> void: +verify_divmodw: + // tests/artifacts/MiscellaneousOps/contract.py:55 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 + btoi txna ApplicationArgs 2 btoi txna ApplicationArgs 3 btoi - // tests/artifacts/MiscellaneousOps/contract.py:146 + txna ApplicationArgs 4 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:59 + // result = op.divmodw(a, b, c, d) + divmodw + // tests/artifacts/MiscellaneousOps/contract.py:55 // @arc4.abimethod() - callsub verify_setbit_bytes - dup - len + uncover 3 itob - extract 6 2 + uncover 3 + itob + concat + uncover 2 + itob + concat swap + itob concat bytec_0 // 0x151f7c75 swap @@ -300,26 +298,23 @@ main_verify_setbit_bytes_route@30: intc_0 // 1 return -main_verify_select_uint64_route@29: - // tests/artifacts/MiscellaneousOps/contract.py:141 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divw[routing]() -> void: +verify_divw: + // tests/artifacts/MiscellaneousOps/contract.py:62 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 btoi txna ApplicationArgs 2 btoi txna ApplicationArgs 3 btoi - // tests/artifacts/MiscellaneousOps/contract.py:141 - // @arc4.abimethod() - callsub verify_select_uint64 - itob + // tests/artifacts/MiscellaneousOps/contract.py:64 + // result = op.divw(a, b, c) + divw + // tests/artifacts/MiscellaneousOps/contract.py:62 + // @arc4.abimethod() + itob bytec_0 // 0x151f7c75 swap concat @@ -327,31 +322,21 @@ main_verify_select_uint64_route@29: intc_0 // 1 return -main_verify_select_bytes_route@28: - // tests/artifacts/MiscellaneousOps/contract.py:136 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_exp[routing]() -> void: +verify_exp: + // tests/artifacts/MiscellaneousOps/contract.py:71 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 + btoi txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 btoi - // tests/artifacts/MiscellaneousOps/contract.py:136 + // tests/artifacts/MiscellaneousOps/contract.py:73 + // result = op.exp(a, b) + exp + // tests/artifacts/MiscellaneousOps/contract.py:71 // @arc4.abimethod() - callsub verify_select_bytes - dup - len itob - extract 6 2 - swap - concat bytec_0 // 0x151f7c75 swap concat @@ -359,30 +344,24 @@ main_verify_select_bytes_route@28: intc_0 // 1 return -main_verify_replace_route@27: - // tests/artifacts/MiscellaneousOps/contract.py:131 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_expw[routing]() -> void: +verify_expw: + // tests/artifacts/MiscellaneousOps/contract.py:76 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 + btoi txna ApplicationArgs 2 btoi - txna ApplicationArgs 3 - extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:131 + // tests/artifacts/MiscellaneousOps/contract.py:78 + // result = op.expw(a, b) + expw + // tests/artifacts/MiscellaneousOps/contract.py:76 // @arc4.abimethod() - callsub verify_replace - dup - len + swap itob - extract 6 2 swap + itob concat bytec_0 // 0x151f7c75 swap @@ -391,27 +370,27 @@ main_verify_replace_route@27: intc_0 // 1 return -main_verify_mulw_route@26: - // tests/artifacts/MiscellaneousOps/contract.py:126 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract[routing]() -> void: +verify_extract: + // tests/artifacts/MiscellaneousOps/contract.py:81 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - btoi + extract 2 0 txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:126 + txna ApplicationArgs 3 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:83 + // result = op.extract(a, b, c) + extract3 + // tests/artifacts/MiscellaneousOps/contract.py:81 // @arc4.abimethod() - callsub verify_mulw - swap + dup + len itob + extract 6 2 swap - itob concat bytec_0 // 0x151f7c75 swap @@ -420,21 +399,17 @@ main_verify_mulw_route@26: intc_0 // 1 return -main_verify_itob_route@25: - // tests/artifacts/MiscellaneousOps/contract.py:121 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_from_2[routing]() -> void: +verify_extract_from_2: + // tests/artifacts/MiscellaneousOps/contract.py:86 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:121 + // tests/artifacts/MiscellaneousOps/contract.py:88 + // result = op.extract(a, 2, 0) + extract 4 0 + // tests/artifacts/MiscellaneousOps/contract.py:86 // @arc4.abimethod() - callsub verify_itob dup len itob @@ -448,23 +423,20 @@ main_verify_itob_route@25: intc_0 // 1 return -main_verify_getbyte_route@24: - // tests/artifacts/MiscellaneousOps/contract.py:116 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint16[routing]() -> void: +verify_extract_uint16: + // tests/artifacts/MiscellaneousOps/contract.py:91 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:116 + // tests/artifacts/MiscellaneousOps/contract.py:93 + // result = op.extract_uint16(a, b) + extract_uint16 + // tests/artifacts/MiscellaneousOps/contract.py:91 // @arc4.abimethod() - callsub verify_getbyte itob bytec_0 // 0x151f7c75 swap @@ -473,23 +445,20 @@ main_verify_getbyte_route@24: intc_0 // 1 return -main_verify_getbit_uint64_route@23: - // tests/artifacts/MiscellaneousOps/contract.py:111 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint32[routing]() -> void: +verify_extract_uint32: + // tests/artifacts/MiscellaneousOps/contract.py:96 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - btoi + extract 2 0 txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:111 + // tests/artifacts/MiscellaneousOps/contract.py:98 + // result = op.extract_uint32(a, b) + extract_uint32 + // tests/artifacts/MiscellaneousOps/contract.py:96 // @arc4.abimethod() - callsub verify_getbit_uint64 itob bytec_0 // 0x151f7c75 swap @@ -498,24 +467,42 @@ main_verify_getbit_uint64_route@23: intc_0 // 1 return -main_verify_getbit_bytes_route@22: + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint64[routing]() -> void: +verify_extract_uint64: + // tests/artifacts/MiscellaneousOps/contract.py:101 + // @arc4.abimethod() + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi + pushint 8 // 8 + extract3 + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_bytes[routing]() -> void: +verify_getbit_bytes: // tests/artifacts/MiscellaneousOps/contract.py:106 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 btoi + // tests/artifacts/MiscellaneousOps/contract.py:108 + // result = op.getbit(a, b) + getbit // tests/artifacts/MiscellaneousOps/contract.py:106 // @arc4.abimethod() - callsub verify_getbit_bytes - itob + bytec_2 // 0x00 + intc_1 // 0 + uncover 2 + setbit bytec_0 // 0x151f7c75 swap concat @@ -523,24 +510,24 @@ main_verify_getbit_bytes_route@22: intc_0 // 1 return -main_verify_extract_uint64_route@21: - // tests/artifacts/MiscellaneousOps/contract.py:101 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_uint64[routing]() -> void: +verify_getbit_uint64: + // tests/artifacts/MiscellaneousOps/contract.py:111 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 + btoi txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:101 + // tests/artifacts/MiscellaneousOps/contract.py:113 + // result = op.getbit(a, b) + getbit + // tests/artifacts/MiscellaneousOps/contract.py:111 // @arc4.abimethod() - callsub verify_extract_uint64 - itob + bytec_2 // 0x00 + intc_1 // 0 + uncover 2 + setbit bytec_0 // 0x151f7c75 swap concat @@ -548,23 +535,20 @@ main_verify_extract_uint64_route@21: intc_0 // 1 return -main_verify_extract_uint32_route@20: - // tests/artifacts/MiscellaneousOps/contract.py:96 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbyte[routing]() -> void: +verify_getbyte: + // tests/artifacts/MiscellaneousOps/contract.py:116 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:96 + // tests/artifacts/MiscellaneousOps/contract.py:118 + // result = op.getbyte(a, b) + getbyte + // tests/artifacts/MiscellaneousOps/contract.py:116 // @arc4.abimethod() - callsub verify_extract_uint32 itob bytec_0 // 0x151f7c75 swap @@ -573,24 +557,44 @@ main_verify_extract_uint32_route@20: intc_0 // 1 return -main_verify_extract_uint16_route@19: - // tests/artifacts/MiscellaneousOps/contract.py:91 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_itob[routing]() -> void: +verify_itob: + // tests/artifacts/MiscellaneousOps/contract.py:121 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:123 + // result = op.itob(a) + itob + // tests/artifacts/MiscellaneousOps/contract.py:121 + // @arc4.abimethod() + pushbytes 0x151f7c750008 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_mulw[routing]() -> void: +verify_mulw: + // tests/artifacts/MiscellaneousOps/contract.py:126 + // @arc4.abimethod() + txna ApplicationArgs 1 + btoi txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:91 + // tests/artifacts/MiscellaneousOps/contract.py:128 + // result = op.mulw(a, b) + mulw + // tests/artifacts/MiscellaneousOps/contract.py:126 // @arc4.abimethod() - callsub verify_extract_uint16 + swap + itob + swap itob + concat bytec_0 // 0x151f7c75 swap concat @@ -598,21 +602,22 @@ main_verify_extract_uint16_route@19: intc_0 // 1 return -main_verify_extract_from_2_route@18: - // tests/artifacts/MiscellaneousOps/contract.py:86 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_replace[routing]() -> void: +verify_replace: + // tests/artifacts/MiscellaneousOps/contract.py:131 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:86 + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + extract 2 0 + // tests/artifacts/MiscellaneousOps/contract.py:133 + // result = op.replace(a, b, c) + replace3 + // tests/artifacts/MiscellaneousOps/contract.py:131 // @arc4.abimethod() - callsub verify_extract_from_2 dup len itob @@ -626,25 +631,22 @@ main_verify_extract_from_2_route@18: intc_0 // 1 return -main_verify_extract_route@17: - // tests/artifacts/MiscellaneousOps/contract.py:81 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_bytes[routing]() -> void: +verify_select_bytes: + // tests/artifacts/MiscellaneousOps/contract.py:136 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 - btoi + extract 2 0 txna ApplicationArgs 3 btoi - // tests/artifacts/MiscellaneousOps/contract.py:81 + // tests/artifacts/MiscellaneousOps/contract.py:138 + // result = op.select_bytes(a, b, c) + select + // tests/artifacts/MiscellaneousOps/contract.py:136 // @arc4.abimethod() - callsub verify_extract dup len itob @@ -658,28 +660,23 @@ main_verify_extract_route@17: intc_0 // 1 return -main_verify_expw_route@16: - // tests/artifacts/MiscellaneousOps/contract.py:76 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_uint64[routing]() -> void: +verify_select_uint64: + // tests/artifacts/MiscellaneousOps/contract.py:141 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 btoi txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:76 + txna ApplicationArgs 3 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:143 + // result = op.select_uint64(a, b, c) + select + // tests/artifacts/MiscellaneousOps/contract.py:141 // @arc4.abimethod() - callsub verify_expw - swap - itob - swap itob - concat bytec_0 // 0x151f7c75 swap concat @@ -687,24 +684,29 @@ main_verify_expw_route@16: intc_0 // 1 return -main_verify_exp_route@15: - // tests/artifacts/MiscellaneousOps/contract.py:71 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_bytes[routing]() -> void: +verify_setbit_bytes: + // tests/artifacts/MiscellaneousOps/contract.py:146 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - btoi + extract 2 0 txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:71 + txna ApplicationArgs 3 + intc_1 // 0 + getbit + // tests/artifacts/MiscellaneousOps/contract.py:148 + // result = op.setbit_bytes(a, b, c) + setbit + // tests/artifacts/MiscellaneousOps/contract.py:146 // @arc4.abimethod() - callsub verify_exp + dup + len itob + extract 6 2 + swap + concat bytec_0 // 0x151f7c75 swap concat @@ -712,37 +714,23 @@ main_verify_exp_route@15: intc_0 // 1 return -main_verify_err_route@14: - // tests/artifacts/MiscellaneousOps/contract.py:67 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:69 - // op.err() - err -main_verify_divw_route@13: - // tests/artifacts/MiscellaneousOps/contract.py:62 +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_uint64[routing]() -> void: +verify_setbit_uint64: + // tests/artifacts/MiscellaneousOps/contract.py:151 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 btoi txna ApplicationArgs 2 btoi txna ApplicationArgs 3 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:62 + intc_1 // 0 + getbit + // tests/artifacts/MiscellaneousOps/contract.py:153 + // result = op.setbit_uint64(a, b, c) + setbit + // tests/artifacts/MiscellaneousOps/contract.py:151 // @arc4.abimethod() - callsub verify_divw itob bytec_0 // 0x151f7c75 swap @@ -751,37 +739,27 @@ main_verify_divw_route@13: intc_0 // 1 return -main_verify_divmodw_route@12: - // tests/artifacts/MiscellaneousOps/contract.py:55 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbyte[routing]() -> void: +verify_setbyte: + // tests/artifacts/MiscellaneousOps/contract.py:156 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - btoi + extract 2 0 txna ApplicationArgs 2 btoi txna ApplicationArgs 3 btoi - txna ApplicationArgs 4 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:55 + // tests/artifacts/MiscellaneousOps/contract.py:158 + // result = op.setbyte(a, b, c) + setbyte + // tests/artifacts/MiscellaneousOps/contract.py:156 // @arc4.abimethod() - callsub verify_divmodw - uncover 3 - itob - uncover 3 - itob - concat - uncover 2 + dup + len itob - concat + extract 6 2 swap - itob concat bytec_0 // 0x151f7c75 swap @@ -790,33 +768,21 @@ main_verify_divmodw_route@12: intc_0 // 1 return -main_verify_concat_route@11: - // tests/artifacts/MiscellaneousOps/contract.py:47 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shl[routing]() -> void: +verify_shl: + // tests/artifacts/MiscellaneousOps/contract.py:161 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 btoi - txna ApplicationArgs 4 + txna ApplicationArgs 2 btoi - // tests/artifacts/MiscellaneousOps/contract.py:47 + // tests/artifacts/MiscellaneousOps/contract.py:163 + // result = op.shl(a, b) + shl + // tests/artifacts/MiscellaneousOps/contract.py:161 // @arc4.abimethod() - callsub verify_concat - dup - len itob - extract 6 2 - swap - concat bytec_0 // 0x151f7c75 swap concat @@ -824,27 +790,21 @@ main_verify_concat_route@11: intc_0 // 1 return -main_verify_bzero_route@10: - // tests/artifacts/MiscellaneousOps/contract.py:42 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shr[routing]() -> void: +verify_shr: + // tests/artifacts/MiscellaneousOps/contract.py:166 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 btoi - // tests/artifacts/MiscellaneousOps/contract.py:42 + txna ApplicationArgs 2 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:168 + // result = op.shr(a, b) + shr + // tests/artifacts/MiscellaneousOps/contract.py:166 // @arc4.abimethod() - callsub verify_bzero - dup - len itob - extract 6 2 - swap - concat bytec_0 // 0x151f7c75 swap concat @@ -852,21 +812,18 @@ main_verify_bzero_route@10: intc_0 // 1 return -main_verify_btoi_route@9: - // tests/artifacts/MiscellaneousOps/contract.py:37 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_sqrt[routing]() -> void: +verify_sqrt: + // tests/artifacts/MiscellaneousOps/contract.py:171 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:37 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:173 + // result = op.sqrt(a) + sqrt + // tests/artifacts/MiscellaneousOps/contract.py:171 // @arc4.abimethod() - callsub verify_btoi itob bytec_0 // 0x151f7c75 swap @@ -875,21 +832,22 @@ main_verify_btoi_route@9: intc_0 // 1 return -main_verify_bsqrt_route@8: - // tests/artifacts/MiscellaneousOps/contract.py:31 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_substring[routing]() -> void: +verify_substring: + // tests/artifacts/MiscellaneousOps/contract.py:176 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:31 + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + btoi + // tests/artifacts/MiscellaneousOps/contract.py:178 + // result = op.substring(a, b, c) + substring3 + // tests/artifacts/MiscellaneousOps/contract.py:176 // @arc4.abimethod() - callsub verify_bsqrt dup len itob @@ -903,47 +861,26 @@ main_verify_bsqrt_route@8: intc_0 // 1 return -main_verify_uint64_bitlen_route@7: - // tests/artifacts/MiscellaneousOps/contract.py:26 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:26 - // @arc4.abimethod() - callsub verify_uint64_bitlen - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_bytes_bitlen_route@6: - // tests/artifacts/MiscellaneousOps/contract.py:20 +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_string[routing]() -> void: +verify_json_ref_string: + // tests/artifacts/MiscellaneousOps/contract.py:181 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 txna ApplicationArgs 2 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:20 + extract 2 0 + // tests/artifacts/MiscellaneousOps/contract.py:183 + // result = op.JsonRef.json_string(a, b) + json_ref JSONString + // tests/artifacts/MiscellaneousOps/contract.py:181 // @arc4.abimethod() - callsub verify_bytes_bitlen + dup + len itob + extract 6 2 + swap + concat bytec_0 // 0x151f7c75 swap concat @@ -951,27 +888,21 @@ main_verify_bytes_bitlen_route@6: intc_0 // 1 return -main_verify_base64_decode_url_route@5: - // tests/artifacts/MiscellaneousOps/contract.py:15 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_uint64[routing]() -> void: +verify_json_ref_uint64: + // tests/artifacts/MiscellaneousOps/contract.py:186 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:15 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/MiscellaneousOps/contract.py:188 + // result = op.JsonRef.json_uint64(a, b) + json_ref JSONUint64 + // tests/artifacts/MiscellaneousOps/contract.py:186 // @arc4.abimethod() - callsub verify_base64_decode_url - dup - len itob - extract 6 2 - swap - concat bytec_0 // 0x151f7c75 swap concat @@ -979,21 +910,20 @@ main_verify_base64_decode_url_route@5: intc_0 // 1 return -main_verify_base64_decode_standard_route@4: - // tests/artifacts/MiscellaneousOps/contract.py:10 + +// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_object[routing]() -> void: +verify_json_ref_object: + // tests/artifacts/MiscellaneousOps/contract.py:191 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:10 + txna ApplicationArgs 2 + extract 2 0 + // tests/artifacts/MiscellaneousOps/contract.py:193 + // result = op.JsonRef.json_object(a, b) + json_ref JSONObject + // tests/artifacts/MiscellaneousOps/contract.py:191 // @arc4.abimethod() - callsub verify_base64_decode_standard dup len itob @@ -1006,647 +936,3 @@ main_verify_base64_decode_standard_route@4: log intc_0 // 1 return - -main_verify_addw_route@3: - // tests/artifacts/MiscellaneousOps/contract.py:5 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:5 - // @arc4.abimethod() - callsub verify_addw - swap - itob - swap - itob - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_bare_routing@42: - // tests/artifacts/MiscellaneousOps/contract.py:4 - // class MiscellaneousOpsContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@46 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_addw(a: uint64, b: uint64) -> uint64, uint64: -verify_addw: - // tests/artifacts/MiscellaneousOps/contract.py:5-6 - // @arc4.abimethod() - // def verify_addw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]: - proto 2 2 - // tests/artifacts/MiscellaneousOps/contract.py:7 - // result = op.addw(a, b) - frame_dig -2 - frame_dig -1 - addw - // tests/artifacts/MiscellaneousOps/contract.py:8 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_standard(a: bytes) -> bytes: -verify_base64_decode_standard: - // tests/artifacts/MiscellaneousOps/contract.py:10-11 - // @arc4.abimethod() - // def verify_base64_decode_standard(self, a: Bytes) -> Bytes: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:12 - // result = op.base64_decode(op.Base64.StdEncoding, a) - frame_dig -1 - base64_decode StdEncoding - // tests/artifacts/MiscellaneousOps/contract.py:13 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_url(a: bytes) -> bytes: -verify_base64_decode_url: - // tests/artifacts/MiscellaneousOps/contract.py:15-16 - // @arc4.abimethod() - // def verify_base64_decode_url(self, a: Bytes) -> Bytes: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:17 - // result = op.base64_decode(op.Base64.URLEncoding, a) - frame_dig -1 - base64_decode URLEncoding - // tests/artifacts/MiscellaneousOps/contract.py:18 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bytes_bitlen(a: bytes, pad_a_size: uint64) -> uint64: -verify_bytes_bitlen: - // tests/artifacts/MiscellaneousOps/contract.py:20-21 - // @arc4.abimethod() - // def verify_bytes_bitlen(self, a: Bytes, pad_a_size: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:22 - // a = op.bzero(pad_a_size) + a - frame_dig -1 - bzero - frame_dig -2 - concat - dup - frame_bury -2 - // tests/artifacts/MiscellaneousOps/contract.py:23 - // result = op.bitlen(a) - bitlen - // tests/artifacts/MiscellaneousOps/contract.py:24 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_uint64_bitlen(a: uint64) -> uint64: -verify_uint64_bitlen: - // tests/artifacts/MiscellaneousOps/contract.py:26-27 - // @arc4.abimethod() - // def verify_uint64_bitlen(self, a: UInt64) -> UInt64: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:28 - // result = op.bitlen(a) - frame_dig -1 - bitlen - // tests/artifacts/MiscellaneousOps/contract.py:29 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bsqrt(a: bytes) -> bytes: -verify_bsqrt: - // tests/artifacts/MiscellaneousOps/contract.py:31-32 - // @arc4.abimethod() - // def verify_bsqrt(self, a: Bytes) -> Bytes: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:34 - // result = op.bsqrt(a_biguint) - frame_dig -1 - bsqrt - // tests/artifacts/MiscellaneousOps/contract.py:35 - // return result.bytes - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_btoi(a: bytes) -> uint64: -verify_btoi: - // tests/artifacts/MiscellaneousOps/contract.py:37-38 - // @arc4.abimethod() - // def verify_btoi(self, a: Bytes) -> UInt64: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:39 - // result = op.btoi(a) - frame_dig -1 - btoi - // tests/artifacts/MiscellaneousOps/contract.py:40 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bzero(a: uint64) -> bytes: -verify_bzero: - // tests/artifacts/MiscellaneousOps/contract.py:42-43 - // @arc4.abimethod() - // def verify_bzero(self, a: UInt64) -> Bytes: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:44 - // result = op.bzero(a) - frame_dig -1 - bzero - // tests/artifacts/MiscellaneousOps/contract.py:45 - // return op.sha256(result) - sha256 - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_concat(a: bytes, b: bytes, pad_a_size: uint64, pad_b_size: uint64) -> bytes: -verify_concat: - // tests/artifacts/MiscellaneousOps/contract.py:47-48 - // @arc4.abimethod() - // def verify_concat(self, a: Bytes, b: Bytes, pad_a_size: UInt64, pad_b_size: UInt64) -> Bytes: - proto 4 1 - // tests/artifacts/MiscellaneousOps/contract.py:49 - // a = op.bzero(pad_a_size) + a - frame_dig -2 - bzero - frame_dig -4 - concat - frame_bury -4 - // tests/artifacts/MiscellaneousOps/contract.py:50 - // b = op.bzero(pad_b_size) + b - frame_dig -1 - bzero - frame_dig -3 - concat - frame_bury -3 - // tests/artifacts/MiscellaneousOps/contract.py:51 - // result = a + b - frame_dig -4 - frame_dig -3 - concat - // tests/artifacts/MiscellaneousOps/contract.py:52 - // result = op.sha256(result) - sha256 - // tests/artifacts/MiscellaneousOps/contract.py:53 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divmodw(a: uint64, b: uint64, c: uint64, d: uint64) -> uint64, uint64, uint64, uint64: -verify_divmodw: - // tests/artifacts/MiscellaneousOps/contract.py:55-58 - // @arc4.abimethod() - // def verify_divmodw( - // self, a: UInt64, b: UInt64, c: UInt64, d: UInt64 - // ) -> tuple[UInt64, UInt64, UInt64, UInt64]: - proto 4 4 - // tests/artifacts/MiscellaneousOps/contract.py:59 - // result = op.divmodw(a, b, c, d) - frame_dig -4 - frame_dig -3 - frame_dig -2 - frame_dig -1 - divmodw - // tests/artifacts/MiscellaneousOps/contract.py:60 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divw(a: uint64, b: uint64, c: uint64) -> uint64: -verify_divw: - // tests/artifacts/MiscellaneousOps/contract.py:62-63 - // @arc4.abimethod() - // def verify_divw(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:64 - // result = op.divw(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - divw - // tests/artifacts/MiscellaneousOps/contract.py:65 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_exp(a: uint64, b: uint64) -> uint64: -verify_exp: - // tests/artifacts/MiscellaneousOps/contract.py:71-72 - // @arc4.abimethod() - // def verify_exp(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:73 - // result = op.exp(a, b) - frame_dig -2 - frame_dig -1 - exp - // tests/artifacts/MiscellaneousOps/contract.py:74 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_expw(a: uint64, b: uint64) -> uint64, uint64: -verify_expw: - // tests/artifacts/MiscellaneousOps/contract.py:76-77 - // @arc4.abimethod() - // def verify_expw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]: - proto 2 2 - // tests/artifacts/MiscellaneousOps/contract.py:78 - // result = op.expw(a, b) - frame_dig -2 - frame_dig -1 - expw - // tests/artifacts/MiscellaneousOps/contract.py:79 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract(a: bytes, b: uint64, c: uint64) -> bytes: -verify_extract: - // tests/artifacts/MiscellaneousOps/contract.py:81-82 - // @arc4.abimethod() - // def verify_extract(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:83 - // result = op.extract(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - extract3 - // tests/artifacts/MiscellaneousOps/contract.py:84 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_from_2(a: bytes) -> bytes: -verify_extract_from_2: - // tests/artifacts/MiscellaneousOps/contract.py:86-87 - // @arc4.abimethod() - // def verify_extract_from_2(self, a: Bytes) -> Bytes: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:88 - // result = op.extract(a, 2, 0) - frame_dig -1 - extract 2 0 - // tests/artifacts/MiscellaneousOps/contract.py:89 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint16(a: bytes, b: uint64) -> uint64: -verify_extract_uint16: - // tests/artifacts/MiscellaneousOps/contract.py:91-92 - // @arc4.abimethod() - // def verify_extract_uint16(self, a: Bytes, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:93 - // result = op.extract_uint16(a, b) - frame_dig -2 - frame_dig -1 - extract_uint16 - // tests/artifacts/MiscellaneousOps/contract.py:94 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint32(a: bytes, b: uint64) -> uint64: -verify_extract_uint32: - // tests/artifacts/MiscellaneousOps/contract.py:96-97 - // @arc4.abimethod() - // def verify_extract_uint32(self, a: Bytes, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:98 - // result = op.extract_uint32(a, b) - frame_dig -2 - frame_dig -1 - extract_uint32 - // tests/artifacts/MiscellaneousOps/contract.py:99 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint64(a: bytes, b: uint64) -> uint64: -verify_extract_uint64: - // tests/artifacts/MiscellaneousOps/contract.py:101-102 - // @arc4.abimethod() - // def verify_extract_uint64(self, a: Bytes, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:103 - // result = op.extract_uint64(a, b) - frame_dig -2 - frame_dig -1 - extract_uint64 - // tests/artifacts/MiscellaneousOps/contract.py:104 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_bytes(a: bytes, b: uint64) -> uint64: -verify_getbit_bytes: - // tests/artifacts/MiscellaneousOps/contract.py:106-107 - // @arc4.abimethod() - // def verify_getbit_bytes(self, a: Bytes, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:108 - // result = op.getbit(a, b) - frame_dig -2 - frame_dig -1 - getbit - // tests/artifacts/MiscellaneousOps/contract.py:109 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_uint64(a: uint64, b: uint64) -> uint64: -verify_getbit_uint64: - // tests/artifacts/MiscellaneousOps/contract.py:111-112 - // @arc4.abimethod() - // def verify_getbit_uint64(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:113 - // result = op.getbit(a, b) - frame_dig -2 - frame_dig -1 - getbit - // tests/artifacts/MiscellaneousOps/contract.py:114 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbyte(a: bytes, b: uint64) -> uint64: -verify_getbyte: - // tests/artifacts/MiscellaneousOps/contract.py:116-117 - // @arc4.abimethod() - // def verify_getbyte(self, a: Bytes, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:118 - // result = op.getbyte(a, b) - frame_dig -2 - frame_dig -1 - getbyte - // tests/artifacts/MiscellaneousOps/contract.py:119 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_itob(a: uint64) -> bytes: -verify_itob: - // tests/artifacts/MiscellaneousOps/contract.py:121-122 - // @arc4.abimethod() - // def verify_itob(self, a: UInt64) -> Bytes: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:123 - // result = op.itob(a) - frame_dig -1 - itob - // tests/artifacts/MiscellaneousOps/contract.py:124 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_mulw(a: uint64, b: uint64) -> uint64, uint64: -verify_mulw: - // tests/artifacts/MiscellaneousOps/contract.py:126-127 - // @arc4.abimethod() - // def verify_mulw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]: - proto 2 2 - // tests/artifacts/MiscellaneousOps/contract.py:128 - // result = op.mulw(a, b) - frame_dig -2 - frame_dig -1 - mulw - // tests/artifacts/MiscellaneousOps/contract.py:129 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_replace(a: bytes, b: uint64, c: bytes) -> bytes: -verify_replace: - // tests/artifacts/MiscellaneousOps/contract.py:131-132 - // @arc4.abimethod() - // def verify_replace(self, a: Bytes, b: UInt64, c: Bytes) -> Bytes: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:133 - // result = op.replace(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - replace3 - // tests/artifacts/MiscellaneousOps/contract.py:134 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_bytes(a: bytes, b: bytes, c: uint64) -> bytes: -verify_select_bytes: - // tests/artifacts/MiscellaneousOps/contract.py:136-137 - // @arc4.abimethod() - // def verify_select_bytes(self, a: Bytes, b: Bytes, c: UInt64) -> Bytes: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:138 - // result = op.select_bytes(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - select - // tests/artifacts/MiscellaneousOps/contract.py:139 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_uint64(a: uint64, b: uint64, c: uint64) -> uint64: -verify_select_uint64: - // tests/artifacts/MiscellaneousOps/contract.py:141-142 - // @arc4.abimethod() - // def verify_select_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:143 - // result = op.select_uint64(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - select - // tests/artifacts/MiscellaneousOps/contract.py:144 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_bytes(a: bytes, b: uint64, c: uint64) -> bytes: -verify_setbit_bytes: - // tests/artifacts/MiscellaneousOps/contract.py:146-147 - // @arc4.abimethod() - // def verify_setbit_bytes(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:148 - // result = op.setbit_bytes(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - setbit - // tests/artifacts/MiscellaneousOps/contract.py:149 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_uint64(a: uint64, b: uint64, c: uint64) -> uint64: -verify_setbit_uint64: - // tests/artifacts/MiscellaneousOps/contract.py:151-152 - // @arc4.abimethod() - // def verify_setbit_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:153 - // result = op.setbit_uint64(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - setbit - // tests/artifacts/MiscellaneousOps/contract.py:154 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbyte(a: bytes, b: uint64, c: uint64) -> bytes: -verify_setbyte: - // tests/artifacts/MiscellaneousOps/contract.py:156-157 - // @arc4.abimethod() - // def verify_setbyte(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:158 - // result = op.setbyte(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - setbyte - // tests/artifacts/MiscellaneousOps/contract.py:159 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shl(a: uint64, b: uint64) -> uint64: -verify_shl: - // tests/artifacts/MiscellaneousOps/contract.py:161-162 - // @arc4.abimethod() - // def verify_shl(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:163 - // result = op.shl(a, b) - frame_dig -2 - frame_dig -1 - shl - // tests/artifacts/MiscellaneousOps/contract.py:164 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shr(a: uint64, b: uint64) -> uint64: -verify_shr: - // tests/artifacts/MiscellaneousOps/contract.py:166-167 - // @arc4.abimethod() - // def verify_shr(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:168 - // result = op.shr(a, b) - frame_dig -2 - frame_dig -1 - shr - // tests/artifacts/MiscellaneousOps/contract.py:169 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_sqrt(a: uint64) -> uint64: -verify_sqrt: - // tests/artifacts/MiscellaneousOps/contract.py:171-172 - // @arc4.abimethod() - // def verify_sqrt(self, a: UInt64) -> UInt64: - proto 1 1 - // tests/artifacts/MiscellaneousOps/contract.py:173 - // result = op.sqrt(a) - frame_dig -1 - sqrt - // tests/artifacts/MiscellaneousOps/contract.py:174 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_substring(a: bytes, b: uint64, c: uint64) -> bytes: -verify_substring: - // tests/artifacts/MiscellaneousOps/contract.py:176-177 - // @arc4.abimethod() - // def verify_substring(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes: - proto 3 1 - // tests/artifacts/MiscellaneousOps/contract.py:178 - // result = op.substring(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - substring3 - // tests/artifacts/MiscellaneousOps/contract.py:179 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_string(a: bytes, b: bytes) -> bytes: -verify_json_ref_string: - // tests/artifacts/MiscellaneousOps/contract.py:181-182 - // @arc4.abimethod() - // def verify_json_ref_string(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:183 - // result = op.JsonRef.json_string(a, b) - frame_dig -2 - frame_dig -1 - json_ref JSONString - // tests/artifacts/MiscellaneousOps/contract.py:184 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_uint64(a: bytes, b: bytes) -> uint64: -verify_json_ref_uint64: - // tests/artifacts/MiscellaneousOps/contract.py:186-187 - // @arc4.abimethod() - // def verify_json_ref_uint64(self, a: Bytes, b: Bytes) -> UInt64: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:188 - // result = op.JsonRef.json_uint64(a, b) - frame_dig -2 - frame_dig -1 - json_ref JSONUint64 - // tests/artifacts/MiscellaneousOps/contract.py:189 - // return result - retsub - - -// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_object(a: bytes, b: bytes) -> bytes: -verify_json_ref_object: - // tests/artifacts/MiscellaneousOps/contract.py:191-192 - // @arc4.abimethod() - // def verify_json_ref_object(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 - // tests/artifacts/MiscellaneousOps/contract.py:193 - // result = op.JsonRef.json_object(a, b) - frame_dig -2 - frame_dig -1 - json_ref JSONObject - // tests/artifacts/MiscellaneousOps/contract.py:194 - // return result - retsub diff --git a/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc32.json b/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc32.json index a0d96eb..e543033 100644 --- a/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc32.json +++ b/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc32.json @@ -95,12 +95,12 @@ "no_op": "CALL" } }, - "verify_getbit_bytes(byte[],uint64)uint64": { + "verify_getbit_bytes(byte[],uint64)bool": { "call_config": { "no_op": "CALL" } }, - "verify_getbit_uint64(uint64,uint64)uint64": { + "verify_getbit_uint64(uint64,uint64)bool": { "call_config": { "no_op": "CALL" } @@ -135,12 +135,12 @@ "no_op": "CALL" } }, - "verify_setbit_bytes(byte[],uint64,uint64)byte[]": { + "verify_setbit_bytes(byte[],uint64,bool)byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_setbit_uint64(uint64,uint64,uint64)uint64": { + "verify_setbit_uint64(uint64,uint64,bool)uint64": { "call_config": { "no_op": "CALL" } @@ -187,7 +187,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@42
    pushbytess 0x45847eea 0xf57aceb5 0x7d631730 0xa1b24441 0xcd7be1ac 0x7cfda64b 0x54a910d9 0xc46568de 0x7a46a6ae 0x04372209 0x7e5f6d72 0x24ebcf84 0x9c0b3397 0x0ad40da4 0x95178870 0xdeedc99b 0xab2150bb 0x02a54017 0x3db66b41 0xc7ea8c2a 0x1dcea50c 0x16166f9a 0x2f472065 0xd5a739c3 0x61f3b3e1 0x56cf368b 0x919ffbd2 0x8e30f4e7 0x89f81d92 0xd5260327 0x114c8c6d 0x39e9e62a 0xd6a4c05e 0x1ef8151a 0x66dd7f96 0x4d9eceb2 0x19ba70ee // method "verify_addw(uint64,uint64)(uint64,uint64)", method "verify_base64_decode_standard(byte[])byte[]", method "verify_base64_decode_url(byte[])byte[]", method "verify_bytes_bitlen(byte[],uint64)uint64", method "verify_uint64_bitlen(uint64)uint64", method "verify_bsqrt(byte[])byte[]", method "verify_btoi(byte[])uint64", method "verify_bzero(uint64)byte[]", method "verify_concat(byte[],byte[],uint64,uint64)byte[]", method "verify_divmodw(uint64,uint64,uint64,uint64)(uint64,uint64,uint64,uint64)", method "verify_divw(uint64,uint64,uint64)uint64", method "verify_err()void", method "verify_exp(uint64,uint64)uint64", method "verify_expw(uint64,uint64)(uint64,uint64)", method "verify_extract(byte[],uint64,uint64)byte[]", method "verify_extract_from_2(byte[])byte[]", method "verify_extract_uint16(byte[],uint64)uint64", method "verify_extract_uint32(byte[],uint64)uint64", method "verify_extract_uint64(byte[],uint64)uint64", method "verify_getbit_bytes(byte[],uint64)uint64", method "verify_getbit_uint64(uint64,uint64)uint64", method "verify_getbyte(byte[],uint64)uint64", method "verify_itob(uint64)byte[]", method "verify_mulw(uint64,uint64)(uint64,uint64)", method "verify_replace(byte[],uint64,byte[])byte[]", method "verify_select_bytes(byte[],byte[],uint64)byte[]", method "verify_select_uint64(uint64,uint64,uint64)uint64", method "verify_setbit_bytes(byte[],uint64,uint64)byte[]", method "verify_setbit_uint64(uint64,uint64,uint64)uint64", method "verify_setbyte(byte[],uint64,uint64)byte[]", method "verify_shl(uint64,uint64)uint64", method "verify_shr(uint64,uint64)uint64", method "verify_sqrt(uint64)uint64", method "verify_substring(byte[],uint64,uint64)byte[]", method "verify_json_ref_string(byte[],byte[])byte[]", method "verify_json_ref_uint64(byte[],byte[])uint64", method "verify_json_ref_object(byte[],byte[])byte[]"
    txna ApplicationArgs 0
    match main_verify_addw_route@3 main_verify_base64_decode_standard_route@4 main_verify_base64_decode_url_route@5 main_verify_bytes_bitlen_route@6 main_verify_uint64_bitlen_route@7 main_verify_bsqrt_route@8 main_verify_btoi_route@9 main_verify_bzero_route@10 main_verify_concat_route@11 main_verify_divmodw_route@12 main_verify_divw_route@13 main_verify_err_route@14 main_verify_exp_route@15 main_verify_expw_route@16 main_verify_extract_route@17 main_verify_extract_from_2_route@18 main_verify_extract_uint16_route@19 main_verify_extract_uint32_route@20 main_verify_extract_uint64_route@21 main_verify_getbit_bytes_route@22 main_verify_getbit_uint64_route@23 main_verify_getbyte_route@24 main_verify_itob_route@25 main_verify_mulw_route@26 main_verify_replace_route@27 main_verify_select_bytes_route@28 main_verify_select_uint64_route@29 main_verify_setbit_bytes_route@30 main_verify_setbit_uint64_route@31 main_verify_setbyte_route@32 main_verify_shl_route@33 main_verify_shr_route@34 main_verify_sqrt_route@35 main_verify_substring_route@36 main_verify_json_ref_string_route@37 main_verify_json_ref_uint64_route@38 main_verify_json_ref_object_route@39

main_after_if_else@46:
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    pushint 0 // 0
    return

main_verify_json_ref_object_route@39:
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    callsub verify_json_ref_object
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_json_ref_uint64_route@38:
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    callsub verify_json_ref_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_json_ref_string_route@37:
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    callsub verify_json_ref_string
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_substring_route@36:
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    callsub verify_substring
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_sqrt_route@35:
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    callsub verify_sqrt
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_shr_route@34:
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    callsub verify_shr
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_shl_route@33:
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    callsub verify_shl
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_setbyte_route@32:
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    callsub verify_setbyte
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_setbit_uint64_route@31:
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    callsub verify_setbit_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_setbit_bytes_route@30:
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    callsub verify_setbit_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_select_uint64_route@29:
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    callsub verify_select_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_select_bytes_route@28:
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    callsub verify_select_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_replace_route@27:
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    callsub verify_replace
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_mulw_route@26:
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    callsub verify_mulw
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_itob_route@25:
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    callsub verify_itob
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_getbyte_route@24:
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    callsub verify_getbyte
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_getbit_uint64_route@23:
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    callsub verify_getbit_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_getbit_bytes_route@22:
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    callsub verify_getbit_bytes
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_uint64_route@21:
    // tests/artifacts/MiscellaneousOps/contract.py:101
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:101
    // @arc4.abimethod()
    callsub verify_extract_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_uint32_route@20:
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    callsub verify_extract_uint32
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_uint16_route@19:
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    callsub verify_extract_uint16
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_from_2_route@18:
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    callsub verify_extract_from_2
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_route@17:
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    callsub verify_extract
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_expw_route@16:
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    callsub verify_expw
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_exp_route@15:
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    callsub verify_exp
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_err_route@14:
    // tests/artifacts/MiscellaneousOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:69
    // op.err()
    err

main_verify_divw_route@13:
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    callsub verify_divw
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_divmodw_route@12:
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    callsub verify_divmodw
    uncover 3
    itob
    uncover 3
    itob
    concat
    uncover 2
    itob
    concat
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_concat_route@11:
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    callsub verify_concat
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bzero_route@10:
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    callsub verify_bzero
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_btoi_route@9:
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    callsub verify_btoi
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bsqrt_route@8:
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    callsub verify_bsqrt
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_bitlen_route@7:
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    callsub verify_uint64_bitlen
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_bitlen_route@6:
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    callsub verify_bytes_bitlen
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_base64_decode_url_route@5:
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    callsub verify_base64_decode_url
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_base64_decode_standard_route@4:
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    callsub verify_base64_decode_standard
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_addw_route@3:
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    callsub verify_addw
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@42:
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@46
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_addw(a: uint64, b: uint64) -> uint64, uint64:
verify_addw:
    // tests/artifacts/MiscellaneousOps/contract.py:5-6
    // @arc4.abimethod()
    // def verify_addw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/MiscellaneousOps/contract.py:7
    // result = op.addw(a, b)
    frame_dig -2
    frame_dig -1
    addw
    // tests/artifacts/MiscellaneousOps/contract.py:8
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_standard(a: bytes) -> bytes:
verify_base64_decode_standard:
    // tests/artifacts/MiscellaneousOps/contract.py:10-11
    // @arc4.abimethod()
    // def verify_base64_decode_standard(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:12
    // result = op.base64_decode(op.Base64.StdEncoding, a)
    frame_dig -1
    base64_decode StdEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:13
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_url(a: bytes) -> bytes:
verify_base64_decode_url:
    // tests/artifacts/MiscellaneousOps/contract.py:15-16
    // @arc4.abimethod()
    // def verify_base64_decode_url(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:17
    // result = op.base64_decode(op.Base64.URLEncoding, a)
    frame_dig -1
    base64_decode URLEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:18
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bytes_bitlen(a: bytes, pad_a_size: uint64) -> uint64:
verify_bytes_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:20-21
    // @arc4.abimethod()
    // def verify_bytes_bitlen(self, a: Bytes, pad_a_size: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:22
    // a = op.bzero(pad_a_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/MiscellaneousOps/contract.py:23
    // result = op.bitlen(a)
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:24
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_uint64_bitlen(a: uint64) -> uint64:
verify_uint64_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:26-27
    // @arc4.abimethod()
    // def verify_uint64_bitlen(self, a: UInt64) -> UInt64:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:28
    // result = op.bitlen(a)
    frame_dig -1
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:29
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bsqrt(a: bytes) -> bytes:
verify_bsqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:31-32
    // @arc4.abimethod()
    // def verify_bsqrt(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:34
    // result = op.bsqrt(a_biguint)
    frame_dig -1
    bsqrt
    // tests/artifacts/MiscellaneousOps/contract.py:35
    // return result.bytes
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_btoi(a: bytes) -> uint64:
verify_btoi:
    // tests/artifacts/MiscellaneousOps/contract.py:37-38
    // @arc4.abimethod()
    // def verify_btoi(self, a: Bytes) -> UInt64:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:39
    // result = op.btoi(a)
    frame_dig -1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:40
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bzero(a: uint64) -> bytes:
verify_bzero:
    // tests/artifacts/MiscellaneousOps/contract.py:42-43
    // @arc4.abimethod()
    // def verify_bzero(self, a: UInt64) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:44
    // result = op.bzero(a)
    frame_dig -1
    bzero
    // tests/artifacts/MiscellaneousOps/contract.py:45
    // return op.sha256(result)
    sha256
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_concat(a: bytes, b: bytes, pad_a_size: uint64, pad_b_size: uint64) -> bytes:
verify_concat:
    // tests/artifacts/MiscellaneousOps/contract.py:47-48
    // @arc4.abimethod()
    // def verify_concat(self, a: Bytes, b: Bytes, pad_a_size: UInt64, pad_b_size: UInt64) -> Bytes:
    proto 4 1
    // tests/artifacts/MiscellaneousOps/contract.py:49
    // a = op.bzero(pad_a_size) + a
    frame_dig -2
    bzero
    frame_dig -4
    concat
    frame_bury -4
    // tests/artifacts/MiscellaneousOps/contract.py:50
    // b = op.bzero(pad_b_size) + b
    frame_dig -1
    bzero
    frame_dig -3
    concat
    frame_bury -3
    // tests/artifacts/MiscellaneousOps/contract.py:51
    // result = a + b
    frame_dig -4
    frame_dig -3
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:52
    // result = op.sha256(result)
    sha256
    // tests/artifacts/MiscellaneousOps/contract.py:53
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divmodw(a: uint64, b: uint64, c: uint64, d: uint64) -> uint64, uint64, uint64, uint64:
verify_divmodw:
    // tests/artifacts/MiscellaneousOps/contract.py:55-58
    // @arc4.abimethod()
    // def verify_divmodw(
    //     self, a: UInt64, b: UInt64, c: UInt64, d: UInt64
    // ) -> tuple[UInt64, UInt64, UInt64, UInt64]:
    proto 4 4
    // tests/artifacts/MiscellaneousOps/contract.py:59
    // result = op.divmodw(a, b, c, d)
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    divmodw
    // tests/artifacts/MiscellaneousOps/contract.py:60
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divw(a: uint64, b: uint64, c: uint64) -> uint64:
verify_divw:
    // tests/artifacts/MiscellaneousOps/contract.py:62-63
    // @arc4.abimethod()
    // def verify_divw(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:64
    // result = op.divw(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    divw
    // tests/artifacts/MiscellaneousOps/contract.py:65
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_exp(a: uint64, b: uint64) -> uint64:
verify_exp:
    // tests/artifacts/MiscellaneousOps/contract.py:71-72
    // @arc4.abimethod()
    // def verify_exp(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:73
    // result = op.exp(a, b)
    frame_dig -2
    frame_dig -1
    exp
    // tests/artifacts/MiscellaneousOps/contract.py:74
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_expw(a: uint64, b: uint64) -> uint64, uint64:
verify_expw:
    // tests/artifacts/MiscellaneousOps/contract.py:76-77
    // @arc4.abimethod()
    // def verify_expw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/MiscellaneousOps/contract.py:78
    // result = op.expw(a, b)
    frame_dig -2
    frame_dig -1
    expw
    // tests/artifacts/MiscellaneousOps/contract.py:79
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract(a: bytes, b: uint64, c: uint64) -> bytes:
verify_extract:
    // tests/artifacts/MiscellaneousOps/contract.py:81-82
    // @arc4.abimethod()
    // def verify_extract(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:83
    // result = op.extract(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    extract3
    // tests/artifacts/MiscellaneousOps/contract.py:84
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_from_2(a: bytes) -> bytes:
verify_extract_from_2:
    // tests/artifacts/MiscellaneousOps/contract.py:86-87
    // @arc4.abimethod()
    // def verify_extract_from_2(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:88
    // result = op.extract(a, 2, 0)
    frame_dig -1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:89
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint16(a: bytes, b: uint64) -> uint64:
verify_extract_uint16:
    // tests/artifacts/MiscellaneousOps/contract.py:91-92
    // @arc4.abimethod()
    // def verify_extract_uint16(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:93
    // result = op.extract_uint16(a, b)
    frame_dig -2
    frame_dig -1
    extract_uint16
    // tests/artifacts/MiscellaneousOps/contract.py:94
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint32(a: bytes, b: uint64) -> uint64:
verify_extract_uint32:
    // tests/artifacts/MiscellaneousOps/contract.py:96-97
    // @arc4.abimethod()
    // def verify_extract_uint32(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:98
    // result = op.extract_uint32(a, b)
    frame_dig -2
    frame_dig -1
    extract_uint32
    // tests/artifacts/MiscellaneousOps/contract.py:99
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint64(a: bytes, b: uint64) -> uint64:
verify_extract_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:101-102
    // @arc4.abimethod()
    // def verify_extract_uint64(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:103
    // result = op.extract_uint64(a, b)
    frame_dig -2
    frame_dig -1
    extract_uint64
    // tests/artifacts/MiscellaneousOps/contract.py:104
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_bytes(a: bytes, b: uint64) -> uint64:
verify_getbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:106-107
    // @arc4.abimethod()
    // def verify_getbit_bytes(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:108
    // result = op.getbit(a, b)
    frame_dig -2
    frame_dig -1
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:109
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_uint64(a: uint64, b: uint64) -> uint64:
verify_getbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:111-112
    // @arc4.abimethod()
    // def verify_getbit_uint64(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:113
    // result = op.getbit(a, b)
    frame_dig -2
    frame_dig -1
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:114
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbyte(a: bytes, b: uint64) -> uint64:
verify_getbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:116-117
    // @arc4.abimethod()
    // def verify_getbyte(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:118
    // result = op.getbyte(a, b)
    frame_dig -2
    frame_dig -1
    getbyte
    // tests/artifacts/MiscellaneousOps/contract.py:119
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_itob(a: uint64) -> bytes:
verify_itob:
    // tests/artifacts/MiscellaneousOps/contract.py:121-122
    // @arc4.abimethod()
    // def verify_itob(self, a: UInt64) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:123
    // result = op.itob(a)
    frame_dig -1
    itob
    // tests/artifacts/MiscellaneousOps/contract.py:124
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_mulw(a: uint64, b: uint64) -> uint64, uint64:
verify_mulw:
    // tests/artifacts/MiscellaneousOps/contract.py:126-127
    // @arc4.abimethod()
    // def verify_mulw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/MiscellaneousOps/contract.py:128
    // result = op.mulw(a, b)
    frame_dig -2
    frame_dig -1
    mulw
    // tests/artifacts/MiscellaneousOps/contract.py:129
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_replace(a: bytes, b: uint64, c: bytes) -> bytes:
verify_replace:
    // tests/artifacts/MiscellaneousOps/contract.py:131-132
    // @arc4.abimethod()
    // def verify_replace(self, a: Bytes, b: UInt64, c: Bytes) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:133
    // result = op.replace(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    replace3
    // tests/artifacts/MiscellaneousOps/contract.py:134
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_bytes(a: bytes, b: bytes, c: uint64) -> bytes:
verify_select_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:136-137
    // @arc4.abimethod()
    // def verify_select_bytes(self, a: Bytes, b: Bytes, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:138
    // result = op.select_bytes(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    select
    // tests/artifacts/MiscellaneousOps/contract.py:139
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_uint64(a: uint64, b: uint64, c: uint64) -> uint64:
verify_select_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:141-142
    // @arc4.abimethod()
    // def verify_select_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:143
    // result = op.select_uint64(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    select
    // tests/artifacts/MiscellaneousOps/contract.py:144
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_bytes(a: bytes, b: uint64, c: uint64) -> bytes:
verify_setbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:146-147
    // @arc4.abimethod()
    // def verify_setbit_bytes(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:148
    // result = op.setbit_bytes(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:149
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_uint64(a: uint64, b: uint64, c: uint64) -> uint64:
verify_setbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:151-152
    // @arc4.abimethod()
    // def verify_setbit_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:153
    // result = op.setbit_uint64(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:154
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbyte(a: bytes, b: uint64, c: uint64) -> bytes:
verify_setbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:156-157
    // @arc4.abimethod()
    // def verify_setbyte(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:158
    // result = op.setbyte(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    setbyte
    // tests/artifacts/MiscellaneousOps/contract.py:159
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shl(a: uint64, b: uint64) -> uint64:
verify_shl:
    // tests/artifacts/MiscellaneousOps/contract.py:161-162
    // @arc4.abimethod()
    // def verify_shl(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:163
    // result = op.shl(a, b)
    frame_dig -2
    frame_dig -1
    shl
    // tests/artifacts/MiscellaneousOps/contract.py:164
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shr(a: uint64, b: uint64) -> uint64:
verify_shr:
    // tests/artifacts/MiscellaneousOps/contract.py:166-167
    // @arc4.abimethod()
    // def verify_shr(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:168
    // result = op.shr(a, b)
    frame_dig -2
    frame_dig -1
    shr
    // tests/artifacts/MiscellaneousOps/contract.py:169
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_sqrt(a: uint64) -> uint64:
verify_sqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:171-172
    // @arc4.abimethod()
    // def verify_sqrt(self, a: UInt64) -> UInt64:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:173
    // result = op.sqrt(a)
    frame_dig -1
    sqrt
    // tests/artifacts/MiscellaneousOps/contract.py:174
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_substring(a: bytes, b: uint64, c: uint64) -> bytes:
verify_substring:
    // tests/artifacts/MiscellaneousOps/contract.py:176-177
    // @arc4.abimethod()
    // def verify_substring(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:178
    // result = op.substring(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    substring3
    // tests/artifacts/MiscellaneousOps/contract.py:179
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_string(a: bytes, b: bytes) -> bytes:
verify_json_ref_string:
    // tests/artifacts/MiscellaneousOps/contract.py:181-182
    // @arc4.abimethod()
    // def verify_json_ref_string(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:183
    // result = op.JsonRef.json_string(a, b)
    frame_dig -2
    frame_dig -1
    json_ref JSONString
    // tests/artifacts/MiscellaneousOps/contract.py:184
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_uint64(a: bytes, b: bytes) -> uint64:
verify_json_ref_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:186-187
    // @arc4.abimethod()
    // def verify_json_ref_uint64(self, a: Bytes, b: Bytes) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:188
    // result = op.JsonRef.json_uint64(a, b)
    frame_dig -2
    frame_dig -1
    json_ref JSONUint64
    // tests/artifacts/MiscellaneousOps/contract.py:189
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_object(a: bytes, b: bytes) -> bytes:
verify_json_ref_object:
    // tests/artifacts/MiscellaneousOps/contract.py:191-192
    // @arc4.abimethod()
    // def verify_json_ref_object(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:193
    // result = op.JsonRef.json_object(a, b)
    frame_dig -2
    frame_dig -1
    json_ref JSONObject
    // tests/artifacts/MiscellaneousOps/contract.py:194
    // return result
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x151f7c750020 0x00
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@44
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x45847eea 0xf57aceb5 0x7d631730 0xa1b24441 0xcd7be1ac 0x7cfda64b 0x54a910d9 0xc46568de 0x7a46a6ae 0x04372209 0x7e5f6d72 0x24ebcf84 0x9c0b3397 0x0ad40da4 0x95178870 0xdeedc99b 0xab2150bb 0x02a54017 0x3db66b41 0x6e3ff38c 0x8f3b9f18 0x16166f9a 0x2f472065 0xd5a739c3 0x61f3b3e1 0x56cf368b 0x919ffbd2 0xaae8b697 0x847422b1 0xd5260327 0x114c8c6d 0x39e9e62a 0xd6a4c05e 0x1ef8151a 0x66dd7f96 0x4d9eceb2 0x19ba70ee // method "verify_addw(uint64,uint64)(uint64,uint64)", method "verify_base64_decode_standard(byte[])byte[]", method "verify_base64_decode_url(byte[])byte[]", method "verify_bytes_bitlen(byte[],uint64)uint64", method "verify_uint64_bitlen(uint64)uint64", method "verify_bsqrt(byte[])byte[]", method "verify_btoi(byte[])uint64", method "verify_bzero(uint64)byte[]", method "verify_concat(byte[],byte[],uint64,uint64)byte[]", method "verify_divmodw(uint64,uint64,uint64,uint64)(uint64,uint64,uint64,uint64)", method "verify_divw(uint64,uint64,uint64)uint64", method "verify_err()void", method "verify_exp(uint64,uint64)uint64", method "verify_expw(uint64,uint64)(uint64,uint64)", method "verify_extract(byte[],uint64,uint64)byte[]", method "verify_extract_from_2(byte[])byte[]", method "verify_extract_uint16(byte[],uint64)uint64", method "verify_extract_uint32(byte[],uint64)uint64", method "verify_extract_uint64(byte[],uint64)uint64", method "verify_getbit_bytes(byte[],uint64)bool", method "verify_getbit_uint64(uint64,uint64)bool", method "verify_getbyte(byte[],uint64)uint64", method "verify_itob(uint64)byte[]", method "verify_mulw(uint64,uint64)(uint64,uint64)", method "verify_replace(byte[],uint64,byte[])byte[]", method "verify_select_bytes(byte[],byte[],uint64)byte[]", method "verify_select_uint64(uint64,uint64,uint64)uint64", method "verify_setbit_bytes(byte[],uint64,bool)byte[]", method "verify_setbit_uint64(uint64,uint64,bool)uint64", method "verify_setbyte(byte[],uint64,uint64)byte[]", method "verify_shl(uint64,uint64)uint64", method "verify_shr(uint64,uint64)uint64", method "verify_sqrt(uint64)uint64", method "verify_substring(byte[],uint64,uint64)byte[]", method "verify_json_ref_string(byte[],byte[])byte[]", method "verify_json_ref_uint64(byte[],byte[])uint64", method "verify_json_ref_object(byte[],byte[])byte[]"
    txna ApplicationArgs 0
    match verify_addw verify_base64_decode_standard verify_base64_decode_url verify_bytes_bitlen verify_uint64_bitlen verify_bsqrt verify_btoi verify_bzero verify_concat verify_divmodw verify_divw main_verify_err_route@15 verify_exp verify_expw verify_extract verify_extract_from_2 verify_extract_uint16 verify_extract_uint32 verify_extract_uint64 verify_getbit_bytes verify_getbit_uint64 verify_getbyte verify_itob verify_mulw verify_replace verify_select_bytes verify_select_uint64 verify_setbit_bytes verify_setbit_uint64 verify_setbyte verify_shl verify_shr verify_sqrt verify_substring verify_json_ref_string verify_json_ref_uint64 verify_json_ref_object
    err

main_verify_err_route@15:
    // tests/artifacts/MiscellaneousOps/contract.py:69
    // op.err()
    err

main___algopy_default_create@44:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_addw[routing]() -> void:
verify_addw:
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:7
    // result = op.addw(a, b)
    addw
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_standard[routing]() -> void:
verify_base64_decode_standard:
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:12
    // result = op.base64_decode(op.Base64.StdEncoding, a)
    base64_decode StdEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_url[routing]() -> void:
verify_base64_decode_url:
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:17
    // result = op.base64_decode(op.Base64.URLEncoding, a)
    base64_decode URLEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bytes_bitlen[routing]() -> void:
verify_bytes_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:22
    // a = op.bzero(pad_a_size) + a
    bzero
    swap
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:23
    // result = op.bitlen(a)
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_uint64_bitlen[routing]() -> void:
verify_uint64_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:28
    // result = op.bitlen(a)
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bsqrt[routing]() -> void:
verify_bsqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:34
    // result = op.bsqrt(a_biguint)
    bsqrt
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_btoi[routing]() -> void:
verify_btoi:
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:39
    // result = op.btoi(a)
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bzero[routing]() -> void:
verify_bzero:
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:44
    // result = op.bzero(a)
    bzero
    // tests/artifacts/MiscellaneousOps/contract.py:45
    // return op.sha256(result)
    sha256
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    bytec_1 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_concat[routing]() -> void:
verify_concat:
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:49
    // a = op.bzero(pad_a_size) + a
    swap
    bzero
    uncover 3
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:50
    // b = op.bzero(pad_b_size) + b
    swap
    bzero
    uncover 2
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:51
    // result = a + b
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:52
    // result = op.sha256(result)
    sha256
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    bytec_1 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divmodw[routing]() -> void:
verify_divmodw:
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:59
    // result = op.divmodw(a, b, c, d)
    divmodw
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    uncover 3
    itob
    uncover 3
    itob
    concat
    uncover 2
    itob
    concat
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divw[routing]() -> void:
verify_divw:
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:64
    // result = op.divw(a, b, c)
    divw
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_exp[routing]() -> void:
verify_exp:
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:73
    // result = op.exp(a, b)
    exp
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_expw[routing]() -> void:
verify_expw:
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:78
    // result = op.expw(a, b)
    expw
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract[routing]() -> void:
verify_extract:
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:83
    // result = op.extract(a, b, c)
    extract3
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_from_2[routing]() -> void:
verify_extract_from_2:
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/MiscellaneousOps/contract.py:88
    // result = op.extract(a, 2, 0)
    extract 4 0
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint16[routing]() -> void:
verify_extract_uint16:
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:93
    // result = op.extract_uint16(a, b)
    extract_uint16
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint32[routing]() -> void:
verify_extract_uint32:
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:98
    // result = op.extract_uint32(a, b)
    extract_uint32
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint64[routing]() -> void:
verify_extract_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:101
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    pushint 8 // 8
    extract3
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_bytes[routing]() -> void:
verify_getbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:108
    // result = op.getbit(a, b)
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    bytec_2 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_uint64[routing]() -> void:
verify_getbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:113
    // result = op.getbit(a, b)
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    bytec_2 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbyte[routing]() -> void:
verify_getbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:118
    // result = op.getbyte(a, b)
    getbyte
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_itob[routing]() -> void:
verify_itob:
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:123
    // result = op.itob(a)
    itob
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    pushbytes 0x151f7c750008
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_mulw[routing]() -> void:
verify_mulw:
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:128
    // result = op.mulw(a, b)
    mulw
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_replace[routing]() -> void:
verify_replace:
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:133
    // result = op.replace(a, b, c)
    replace3
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_bytes[routing]() -> void:
verify_select_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:138
    // result = op.select_bytes(a, b, c)
    select
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_uint64[routing]() -> void:
verify_select_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:143
    // result = op.select_uint64(a, b, c)
    select
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_bytes[routing]() -> void:
verify_setbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    intc_1 // 0
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:148
    // result = op.setbit_bytes(a, b, c)
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_uint64[routing]() -> void:
verify_setbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    intc_1 // 0
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:153
    // result = op.setbit_uint64(a, b, c)
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbyte[routing]() -> void:
verify_setbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:158
    // result = op.setbyte(a, b, c)
    setbyte
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shl[routing]() -> void:
verify_shl:
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:163
    // result = op.shl(a, b)
    shl
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shr[routing]() -> void:
verify_shr:
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:168
    // result = op.shr(a, b)
    shr
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_sqrt[routing]() -> void:
verify_sqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:173
    // result = op.sqrt(a)
    sqrt
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_substring[routing]() -> void:
verify_substring:
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:178
    // result = op.substring(a, b, c)
    substring3
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_string[routing]() -> void:
verify_json_ref_string:
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:183
    // result = op.JsonRef.json_string(a, b)
    json_ref JSONString
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_uint64[routing]() -> void:
verify_json_ref_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:188
    // result = op.JsonRef.json_uint64(a, b)
    json_ref JSONUint64
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_object[routing]() -> void:
verify_json_ref_object:
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:193
    // result = op.JsonRef.json_object(a, b)
    json_ref JSONObject
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -537,7 +537,7 @@ ], "readonly": false, "returns": { - "type": "uint64" + "type": "bool" } }, { @@ -554,7 +554,7 @@ ], "readonly": false, "returns": { - "type": "uint64" + "type": "bool" } }, { @@ -679,7 +679,7 @@ "name": "b" }, { - "type": "uint64", + "type": "bool", "name": "c" } ], @@ -700,7 +700,7 @@ "name": "b" }, { - "type": "uint64", + "type": "bool", "name": "c" } ], diff --git a/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc56.json b/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc56.json index 1f74dbc..a97f0d2 100644 --- a/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc56.json +++ b/tests/artifacts/MiscellaneousOps/data/MiscellaneousOpsContract.arc56.json @@ -477,7 +477,7 @@ } ], "returns": { - "type": "uint64" + "type": "bool" }, "actions": { "create": [], @@ -502,7 +502,7 @@ } ], "returns": { - "type": "uint64" + "type": "bool" }, "actions": { "create": [], @@ -684,7 +684,7 @@ "name": "b" }, { - "type": "uint64", + "type": "bool", "name": "c" } ], @@ -713,7 +713,7 @@ "name": "b" }, { - "type": "uint64", + "type": "bool", "name": "c" } ], @@ -973,93 +973,15 @@ "sourceInfo": [ { "pc": [ - 288, - 324, - 353, - 389, - 427, - 448, - 473, - 498, - 536, - 565, - 603, - 632, - 672, - 712, - 741, - 769, - 796, - 821, - 848, - 875, - 902, - 929, - 959, - 997, - 1026, - 1051, - 1059, - 1088, - 1134, - 1178, - 1206, - 1229, - 1259, - 1280, - 1307, - 1337, - 1367 - ], - "errorMessage": "OnCompletion is not NoOp" - }, - { - "pc": [ - 1401 + 29 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 291, - 327, - 356, - 392, - 430, - 451, - 476, - 501, - 539, - 568, - 606, - 635, - 675, - 715, - 744, - 772, - 799, - 824, - 851, - 878, - 905, - 932, - 962, - 1000, - 1029, - 1054, - 1062, - 1091, - 1137, - 1181, - 1209, - 1232, - 1262, - 1283, - 1310, - 1340, - 1370 + 308 ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" } ], "pcOffsetMethod": "none" @@ -1070,18 +992,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@42
    pushbytess 0x45847eea 0xf57aceb5 0x7d631730 0xa1b24441 0xcd7be1ac 0x7cfda64b 0x54a910d9 0xc46568de 0x7a46a6ae 0x04372209 0x7e5f6d72 0x24ebcf84 0x9c0b3397 0x0ad40da4 0x95178870 0xdeedc99b 0xab2150bb 0x02a54017 0x3db66b41 0xc7ea8c2a 0x1dcea50c 0x16166f9a 0x2f472065 0xd5a739c3 0x61f3b3e1 0x56cf368b 0x919ffbd2 0x8e30f4e7 0x89f81d92 0xd5260327 0x114c8c6d 0x39e9e62a 0xd6a4c05e 0x1ef8151a 0x66dd7f96 0x4d9eceb2 0x19ba70ee // method "verify_addw(uint64,uint64)(uint64,uint64)", method "verify_base64_decode_standard(byte[])byte[]", method "verify_base64_decode_url(byte[])byte[]", method "verify_bytes_bitlen(byte[],uint64)uint64", method "verify_uint64_bitlen(uint64)uint64", method "verify_bsqrt(byte[])byte[]", method "verify_btoi(byte[])uint64", method "verify_bzero(uint64)byte[]", method "verify_concat(byte[],byte[],uint64,uint64)byte[]", method "verify_divmodw(uint64,uint64,uint64,uint64)(uint64,uint64,uint64,uint64)", method "verify_divw(uint64,uint64,uint64)uint64", method "verify_err()void", method "verify_exp(uint64,uint64)uint64", method "verify_expw(uint64,uint64)(uint64,uint64)", method "verify_extract(byte[],uint64,uint64)byte[]", method "verify_extract_from_2(byte[])byte[]", method "verify_extract_uint16(byte[],uint64)uint64", method "verify_extract_uint32(byte[],uint64)uint64", method "verify_extract_uint64(byte[],uint64)uint64", method "verify_getbit_bytes(byte[],uint64)uint64", method "verify_getbit_uint64(uint64,uint64)uint64", method "verify_getbyte(byte[],uint64)uint64", method "verify_itob(uint64)byte[]", method "verify_mulw(uint64,uint64)(uint64,uint64)", method "verify_replace(byte[],uint64,byte[])byte[]", method "verify_select_bytes(byte[],byte[],uint64)byte[]", method "verify_select_uint64(uint64,uint64,uint64)uint64", method "verify_setbit_bytes(byte[],uint64,uint64)byte[]", method "verify_setbit_uint64(uint64,uint64,uint64)uint64", method "verify_setbyte(byte[],uint64,uint64)byte[]", method "verify_shl(uint64,uint64)uint64", method "verify_shr(uint64,uint64)uint64", method "verify_sqrt(uint64)uint64", method "verify_substring(byte[],uint64,uint64)byte[]", method "verify_json_ref_string(byte[],byte[])byte[]", method "verify_json_ref_uint64(byte[],byte[])uint64", method "verify_json_ref_object(byte[],byte[])byte[]"
    txna ApplicationArgs 0
    match main_verify_addw_route@3 main_verify_base64_decode_standard_route@4 main_verify_base64_decode_url_route@5 main_verify_bytes_bitlen_route@6 main_verify_uint64_bitlen_route@7 main_verify_bsqrt_route@8 main_verify_btoi_route@9 main_verify_bzero_route@10 main_verify_concat_route@11 main_verify_divmodw_route@12 main_verify_divw_route@13 main_verify_err_route@14 main_verify_exp_route@15 main_verify_expw_route@16 main_verify_extract_route@17 main_verify_extract_from_2_route@18 main_verify_extract_uint16_route@19 main_verify_extract_uint32_route@20 main_verify_extract_uint64_route@21 main_verify_getbit_bytes_route@22 main_verify_getbit_uint64_route@23 main_verify_getbyte_route@24 main_verify_itob_route@25 main_verify_mulw_route@26 main_verify_replace_route@27 main_verify_select_bytes_route@28 main_verify_select_uint64_route@29 main_verify_setbit_bytes_route@30 main_verify_setbit_uint64_route@31 main_verify_setbyte_route@32 main_verify_shl_route@33 main_verify_shr_route@34 main_verify_sqrt_route@35 main_verify_substring_route@36 main_verify_json_ref_string_route@37 main_verify_json_ref_uint64_route@38 main_verify_json_ref_object_route@39

main_after_if_else@46:
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    pushint 0 // 0
    return

main_verify_json_ref_object_route@39:
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    callsub verify_json_ref_object
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_json_ref_uint64_route@38:
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    callsub verify_json_ref_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_json_ref_string_route@37:
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    callsub verify_json_ref_string
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_substring_route@36:
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    callsub verify_substring
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_sqrt_route@35:
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    callsub verify_sqrt
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_shr_route@34:
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    callsub verify_shr
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_shl_route@33:
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    callsub verify_shl
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_setbyte_route@32:
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    callsub verify_setbyte
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_setbit_uint64_route@31:
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    callsub verify_setbit_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_setbit_bytes_route@30:
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    callsub verify_setbit_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_select_uint64_route@29:
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    callsub verify_select_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_select_bytes_route@28:
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    callsub verify_select_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_replace_route@27:
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    callsub verify_replace
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_mulw_route@26:
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    callsub verify_mulw
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_itob_route@25:
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    callsub verify_itob
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_getbyte_route@24:
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    callsub verify_getbyte
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_getbit_uint64_route@23:
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    callsub verify_getbit_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_getbit_bytes_route@22:
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    callsub verify_getbit_bytes
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_uint64_route@21:
    // tests/artifacts/MiscellaneousOps/contract.py:101
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:101
    // @arc4.abimethod()
    callsub verify_extract_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_uint32_route@20:
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    callsub verify_extract_uint32
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_uint16_route@19:
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    callsub verify_extract_uint16
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_from_2_route@18:
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    callsub verify_extract_from_2
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_extract_route@17:
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    callsub verify_extract
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_expw_route@16:
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    callsub verify_expw
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_exp_route@15:
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    callsub verify_exp
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_err_route@14:
    // tests/artifacts/MiscellaneousOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:69
    // op.err()
    err

main_verify_divw_route@13:
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    callsub verify_divw
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_divmodw_route@12:
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    callsub verify_divmodw
    uncover 3
    itob
    uncover 3
    itob
    concat
    uncover 2
    itob
    concat
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_concat_route@11:
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    callsub verify_concat
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bzero_route@10:
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    callsub verify_bzero
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_btoi_route@9:
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    callsub verify_btoi
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bsqrt_route@8:
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    callsub verify_bsqrt
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_bitlen_route@7:
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    callsub verify_uint64_bitlen
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_bitlen_route@6:
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    callsub verify_bytes_bitlen
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_base64_decode_url_route@5:
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    callsub verify_base64_decode_url
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_base64_decode_standard_route@4:
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    callsub verify_base64_decode_standard
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_addw_route@3:
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    callsub verify_addw
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@42:
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@46
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_addw(a: uint64, b: uint64) -> uint64, uint64:
verify_addw:
    // tests/artifacts/MiscellaneousOps/contract.py:5-6
    // @arc4.abimethod()
    // def verify_addw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/MiscellaneousOps/contract.py:7
    // result = op.addw(a, b)
    frame_dig -2
    frame_dig -1
    addw
    // tests/artifacts/MiscellaneousOps/contract.py:8
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_standard(a: bytes) -> bytes:
verify_base64_decode_standard:
    // tests/artifacts/MiscellaneousOps/contract.py:10-11
    // @arc4.abimethod()
    // def verify_base64_decode_standard(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:12
    // result = op.base64_decode(op.Base64.StdEncoding, a)
    frame_dig -1
    base64_decode StdEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:13
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_url(a: bytes) -> bytes:
verify_base64_decode_url:
    // tests/artifacts/MiscellaneousOps/contract.py:15-16
    // @arc4.abimethod()
    // def verify_base64_decode_url(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:17
    // result = op.base64_decode(op.Base64.URLEncoding, a)
    frame_dig -1
    base64_decode URLEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:18
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bytes_bitlen(a: bytes, pad_a_size: uint64) -> uint64:
verify_bytes_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:20-21
    // @arc4.abimethod()
    // def verify_bytes_bitlen(self, a: Bytes, pad_a_size: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:22
    // a = op.bzero(pad_a_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/MiscellaneousOps/contract.py:23
    // result = op.bitlen(a)
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:24
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_uint64_bitlen(a: uint64) -> uint64:
verify_uint64_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:26-27
    // @arc4.abimethod()
    // def verify_uint64_bitlen(self, a: UInt64) -> UInt64:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:28
    // result = op.bitlen(a)
    frame_dig -1
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:29
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bsqrt(a: bytes) -> bytes:
verify_bsqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:31-32
    // @arc4.abimethod()
    // def verify_bsqrt(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:34
    // result = op.bsqrt(a_biguint)
    frame_dig -1
    bsqrt
    // tests/artifacts/MiscellaneousOps/contract.py:35
    // return result.bytes
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_btoi(a: bytes) -> uint64:
verify_btoi:
    // tests/artifacts/MiscellaneousOps/contract.py:37-38
    // @arc4.abimethod()
    // def verify_btoi(self, a: Bytes) -> UInt64:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:39
    // result = op.btoi(a)
    frame_dig -1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:40
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bzero(a: uint64) -> bytes:
verify_bzero:
    // tests/artifacts/MiscellaneousOps/contract.py:42-43
    // @arc4.abimethod()
    // def verify_bzero(self, a: UInt64) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:44
    // result = op.bzero(a)
    frame_dig -1
    bzero
    // tests/artifacts/MiscellaneousOps/contract.py:45
    // return op.sha256(result)
    sha256
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_concat(a: bytes, b: bytes, pad_a_size: uint64, pad_b_size: uint64) -> bytes:
verify_concat:
    // tests/artifacts/MiscellaneousOps/contract.py:47-48
    // @arc4.abimethod()
    // def verify_concat(self, a: Bytes, b: Bytes, pad_a_size: UInt64, pad_b_size: UInt64) -> Bytes:
    proto 4 1
    // tests/artifacts/MiscellaneousOps/contract.py:49
    // a = op.bzero(pad_a_size) + a
    frame_dig -2
    bzero
    frame_dig -4
    concat
    frame_bury -4
    // tests/artifacts/MiscellaneousOps/contract.py:50
    // b = op.bzero(pad_b_size) + b
    frame_dig -1
    bzero
    frame_dig -3
    concat
    frame_bury -3
    // tests/artifacts/MiscellaneousOps/contract.py:51
    // result = a + b
    frame_dig -4
    frame_dig -3
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:52
    // result = op.sha256(result)
    sha256
    // tests/artifacts/MiscellaneousOps/contract.py:53
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divmodw(a: uint64, b: uint64, c: uint64, d: uint64) -> uint64, uint64, uint64, uint64:
verify_divmodw:
    // tests/artifacts/MiscellaneousOps/contract.py:55-58
    // @arc4.abimethod()
    // def verify_divmodw(
    //     self, a: UInt64, b: UInt64, c: UInt64, d: UInt64
    // ) -> tuple[UInt64, UInt64, UInt64, UInt64]:
    proto 4 4
    // tests/artifacts/MiscellaneousOps/contract.py:59
    // result = op.divmodw(a, b, c, d)
    frame_dig -4
    frame_dig -3
    frame_dig -2
    frame_dig -1
    divmodw
    // tests/artifacts/MiscellaneousOps/contract.py:60
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divw(a: uint64, b: uint64, c: uint64) -> uint64:
verify_divw:
    // tests/artifacts/MiscellaneousOps/contract.py:62-63
    // @arc4.abimethod()
    // def verify_divw(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:64
    // result = op.divw(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    divw
    // tests/artifacts/MiscellaneousOps/contract.py:65
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_exp(a: uint64, b: uint64) -> uint64:
verify_exp:
    // tests/artifacts/MiscellaneousOps/contract.py:71-72
    // @arc4.abimethod()
    // def verify_exp(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:73
    // result = op.exp(a, b)
    frame_dig -2
    frame_dig -1
    exp
    // tests/artifacts/MiscellaneousOps/contract.py:74
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_expw(a: uint64, b: uint64) -> uint64, uint64:
verify_expw:
    // tests/artifacts/MiscellaneousOps/contract.py:76-77
    // @arc4.abimethod()
    // def verify_expw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/MiscellaneousOps/contract.py:78
    // result = op.expw(a, b)
    frame_dig -2
    frame_dig -1
    expw
    // tests/artifacts/MiscellaneousOps/contract.py:79
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract(a: bytes, b: uint64, c: uint64) -> bytes:
verify_extract:
    // tests/artifacts/MiscellaneousOps/contract.py:81-82
    // @arc4.abimethod()
    // def verify_extract(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:83
    // result = op.extract(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    extract3
    // tests/artifacts/MiscellaneousOps/contract.py:84
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_from_2(a: bytes) -> bytes:
verify_extract_from_2:
    // tests/artifacts/MiscellaneousOps/contract.py:86-87
    // @arc4.abimethod()
    // def verify_extract_from_2(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:88
    // result = op.extract(a, 2, 0)
    frame_dig -1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:89
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint16(a: bytes, b: uint64) -> uint64:
verify_extract_uint16:
    // tests/artifacts/MiscellaneousOps/contract.py:91-92
    // @arc4.abimethod()
    // def verify_extract_uint16(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:93
    // result = op.extract_uint16(a, b)
    frame_dig -2
    frame_dig -1
    extract_uint16
    // tests/artifacts/MiscellaneousOps/contract.py:94
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint32(a: bytes, b: uint64) -> uint64:
verify_extract_uint32:
    // tests/artifacts/MiscellaneousOps/contract.py:96-97
    // @arc4.abimethod()
    // def verify_extract_uint32(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:98
    // result = op.extract_uint32(a, b)
    frame_dig -2
    frame_dig -1
    extract_uint32
    // tests/artifacts/MiscellaneousOps/contract.py:99
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint64(a: bytes, b: uint64) -> uint64:
verify_extract_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:101-102
    // @arc4.abimethod()
    // def verify_extract_uint64(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:103
    // result = op.extract_uint64(a, b)
    frame_dig -2
    frame_dig -1
    extract_uint64
    // tests/artifacts/MiscellaneousOps/contract.py:104
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_bytes(a: bytes, b: uint64) -> uint64:
verify_getbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:106-107
    // @arc4.abimethod()
    // def verify_getbit_bytes(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:108
    // result = op.getbit(a, b)
    frame_dig -2
    frame_dig -1
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:109
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_uint64(a: uint64, b: uint64) -> uint64:
verify_getbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:111-112
    // @arc4.abimethod()
    // def verify_getbit_uint64(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:113
    // result = op.getbit(a, b)
    frame_dig -2
    frame_dig -1
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:114
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbyte(a: bytes, b: uint64) -> uint64:
verify_getbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:116-117
    // @arc4.abimethod()
    // def verify_getbyte(self, a: Bytes, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:118
    // result = op.getbyte(a, b)
    frame_dig -2
    frame_dig -1
    getbyte
    // tests/artifacts/MiscellaneousOps/contract.py:119
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_itob(a: uint64) -> bytes:
verify_itob:
    // tests/artifacts/MiscellaneousOps/contract.py:121-122
    // @arc4.abimethod()
    // def verify_itob(self, a: UInt64) -> Bytes:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:123
    // result = op.itob(a)
    frame_dig -1
    itob
    // tests/artifacts/MiscellaneousOps/contract.py:124
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_mulw(a: uint64, b: uint64) -> uint64, uint64:
verify_mulw:
    // tests/artifacts/MiscellaneousOps/contract.py:126-127
    // @arc4.abimethod()
    // def verify_mulw(self, a: UInt64, b: UInt64) -> tuple[UInt64, UInt64]:
    proto 2 2
    // tests/artifacts/MiscellaneousOps/contract.py:128
    // result = op.mulw(a, b)
    frame_dig -2
    frame_dig -1
    mulw
    // tests/artifacts/MiscellaneousOps/contract.py:129
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_replace(a: bytes, b: uint64, c: bytes) -> bytes:
verify_replace:
    // tests/artifacts/MiscellaneousOps/contract.py:131-132
    // @arc4.abimethod()
    // def verify_replace(self, a: Bytes, b: UInt64, c: Bytes) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:133
    // result = op.replace(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    replace3
    // tests/artifacts/MiscellaneousOps/contract.py:134
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_bytes(a: bytes, b: bytes, c: uint64) -> bytes:
verify_select_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:136-137
    // @arc4.abimethod()
    // def verify_select_bytes(self, a: Bytes, b: Bytes, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:138
    // result = op.select_bytes(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    select
    // tests/artifacts/MiscellaneousOps/contract.py:139
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_uint64(a: uint64, b: uint64, c: uint64) -> uint64:
verify_select_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:141-142
    // @arc4.abimethod()
    // def verify_select_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:143
    // result = op.select_uint64(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    select
    // tests/artifacts/MiscellaneousOps/contract.py:144
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_bytes(a: bytes, b: uint64, c: uint64) -> bytes:
verify_setbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:146-147
    // @arc4.abimethod()
    // def verify_setbit_bytes(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:148
    // result = op.setbit_bytes(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:149
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_uint64(a: uint64, b: uint64, c: uint64) -> uint64:
verify_setbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:151-152
    // @arc4.abimethod()
    // def verify_setbit_uint64(self, a: UInt64, b: UInt64, c: UInt64) -> UInt64:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:153
    // result = op.setbit_uint64(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:154
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbyte(a: bytes, b: uint64, c: uint64) -> bytes:
verify_setbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:156-157
    // @arc4.abimethod()
    // def verify_setbyte(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:158
    // result = op.setbyte(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    setbyte
    // tests/artifacts/MiscellaneousOps/contract.py:159
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shl(a: uint64, b: uint64) -> uint64:
verify_shl:
    // tests/artifacts/MiscellaneousOps/contract.py:161-162
    // @arc4.abimethod()
    // def verify_shl(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:163
    // result = op.shl(a, b)
    frame_dig -2
    frame_dig -1
    shl
    // tests/artifacts/MiscellaneousOps/contract.py:164
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shr(a: uint64, b: uint64) -> uint64:
verify_shr:
    // tests/artifacts/MiscellaneousOps/contract.py:166-167
    // @arc4.abimethod()
    // def verify_shr(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:168
    // result = op.shr(a, b)
    frame_dig -2
    frame_dig -1
    shr
    // tests/artifacts/MiscellaneousOps/contract.py:169
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_sqrt(a: uint64) -> uint64:
verify_sqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:171-172
    // @arc4.abimethod()
    // def verify_sqrt(self, a: UInt64) -> UInt64:
    proto 1 1
    // tests/artifacts/MiscellaneousOps/contract.py:173
    // result = op.sqrt(a)
    frame_dig -1
    sqrt
    // tests/artifacts/MiscellaneousOps/contract.py:174
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_substring(a: bytes, b: uint64, c: uint64) -> bytes:
verify_substring:
    // tests/artifacts/MiscellaneousOps/contract.py:176-177
    // @arc4.abimethod()
    // def verify_substring(self, a: Bytes, b: UInt64, c: UInt64) -> Bytes:
    proto 3 1
    // tests/artifacts/MiscellaneousOps/contract.py:178
    // result = op.substring(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    substring3
    // tests/artifacts/MiscellaneousOps/contract.py:179
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_string(a: bytes, b: bytes) -> bytes:
verify_json_ref_string:
    // tests/artifacts/MiscellaneousOps/contract.py:181-182
    // @arc4.abimethod()
    // def verify_json_ref_string(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:183
    // result = op.JsonRef.json_string(a, b)
    frame_dig -2
    frame_dig -1
    json_ref JSONString
    // tests/artifacts/MiscellaneousOps/contract.py:184
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_uint64(a: bytes, b: bytes) -> uint64:
verify_json_ref_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:186-187
    // @arc4.abimethod()
    // def verify_json_ref_uint64(self, a: Bytes, b: Bytes) -> UInt64:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:188
    // result = op.JsonRef.json_uint64(a, b)
    frame_dig -2
    frame_dig -1
    json_ref JSONUint64
    // tests/artifacts/MiscellaneousOps/contract.py:189
    // return result
    retsub


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_object(a: bytes, b: bytes) -> bytes:
verify_json_ref_object:
    // tests/artifacts/MiscellaneousOps/contract.py:191-192
    // @arc4.abimethod()
    // def verify_json_ref_object(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/MiscellaneousOps/contract.py:193
    // result = op.JsonRef.json_object(a, b)
    frame_dig -2
    frame_dig -1
    json_ref JSONObject
    // tests/artifacts/MiscellaneousOps/contract.py:194
    // return result
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x151f7c750020 0x00
    // tests/artifacts/MiscellaneousOps/contract.py:4
    // class MiscellaneousOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@44
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x45847eea 0xf57aceb5 0x7d631730 0xa1b24441 0xcd7be1ac 0x7cfda64b 0x54a910d9 0xc46568de 0x7a46a6ae 0x04372209 0x7e5f6d72 0x24ebcf84 0x9c0b3397 0x0ad40da4 0x95178870 0xdeedc99b 0xab2150bb 0x02a54017 0x3db66b41 0x6e3ff38c 0x8f3b9f18 0x16166f9a 0x2f472065 0xd5a739c3 0x61f3b3e1 0x56cf368b 0x919ffbd2 0xaae8b697 0x847422b1 0xd5260327 0x114c8c6d 0x39e9e62a 0xd6a4c05e 0x1ef8151a 0x66dd7f96 0x4d9eceb2 0x19ba70ee // method "verify_addw(uint64,uint64)(uint64,uint64)", method "verify_base64_decode_standard(byte[])byte[]", method "verify_base64_decode_url(byte[])byte[]", method "verify_bytes_bitlen(byte[],uint64)uint64", method "verify_uint64_bitlen(uint64)uint64", method "verify_bsqrt(byte[])byte[]", method "verify_btoi(byte[])uint64", method "verify_bzero(uint64)byte[]", method "verify_concat(byte[],byte[],uint64,uint64)byte[]", method "verify_divmodw(uint64,uint64,uint64,uint64)(uint64,uint64,uint64,uint64)", method "verify_divw(uint64,uint64,uint64)uint64", method "verify_err()void", method "verify_exp(uint64,uint64)uint64", method "verify_expw(uint64,uint64)(uint64,uint64)", method "verify_extract(byte[],uint64,uint64)byte[]", method "verify_extract_from_2(byte[])byte[]", method "verify_extract_uint16(byte[],uint64)uint64", method "verify_extract_uint32(byte[],uint64)uint64", method "verify_extract_uint64(byte[],uint64)uint64", method "verify_getbit_bytes(byte[],uint64)bool", method "verify_getbit_uint64(uint64,uint64)bool", method "verify_getbyte(byte[],uint64)uint64", method "verify_itob(uint64)byte[]", method "verify_mulw(uint64,uint64)(uint64,uint64)", method "verify_replace(byte[],uint64,byte[])byte[]", method "verify_select_bytes(byte[],byte[],uint64)byte[]", method "verify_select_uint64(uint64,uint64,uint64)uint64", method "verify_setbit_bytes(byte[],uint64,bool)byte[]", method "verify_setbit_uint64(uint64,uint64,bool)uint64", method "verify_setbyte(byte[],uint64,uint64)byte[]", method "verify_shl(uint64,uint64)uint64", method "verify_shr(uint64,uint64)uint64", method "verify_sqrt(uint64)uint64", method "verify_substring(byte[],uint64,uint64)byte[]", method "verify_json_ref_string(byte[],byte[])byte[]", method "verify_json_ref_uint64(byte[],byte[])uint64", method "verify_json_ref_object(byte[],byte[])byte[]"
    txna ApplicationArgs 0
    match verify_addw verify_base64_decode_standard verify_base64_decode_url verify_bytes_bitlen verify_uint64_bitlen verify_bsqrt verify_btoi verify_bzero verify_concat verify_divmodw verify_divw main_verify_err_route@15 verify_exp verify_expw verify_extract verify_extract_from_2 verify_extract_uint16 verify_extract_uint32 verify_extract_uint64 verify_getbit_bytes verify_getbit_uint64 verify_getbyte verify_itob verify_mulw verify_replace verify_select_bytes verify_select_uint64 verify_setbit_bytes verify_setbit_uint64 verify_setbyte verify_shl verify_shr verify_sqrt verify_substring verify_json_ref_string verify_json_ref_uint64 verify_json_ref_object
    err

main_verify_err_route@15:
    // tests/artifacts/MiscellaneousOps/contract.py:69
    // op.err()
    err

main___algopy_default_create@44:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_addw[routing]() -> void:
verify_addw:
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:7
    // result = op.addw(a, b)
    addw
    // tests/artifacts/MiscellaneousOps/contract.py:5
    // @arc4.abimethod()
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_standard[routing]() -> void:
verify_base64_decode_standard:
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:12
    // result = op.base64_decode(op.Base64.StdEncoding, a)
    base64_decode StdEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:10
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_base64_decode_url[routing]() -> void:
verify_base64_decode_url:
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:17
    // result = op.base64_decode(op.Base64.URLEncoding, a)
    base64_decode URLEncoding
    // tests/artifacts/MiscellaneousOps/contract.py:15
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bytes_bitlen[routing]() -> void:
verify_bytes_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:22
    // a = op.bzero(pad_a_size) + a
    bzero
    swap
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:23
    // result = op.bitlen(a)
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:20
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_uint64_bitlen[routing]() -> void:
verify_uint64_bitlen:
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:28
    // result = op.bitlen(a)
    bitlen
    // tests/artifacts/MiscellaneousOps/contract.py:26
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bsqrt[routing]() -> void:
verify_bsqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:34
    // result = op.bsqrt(a_biguint)
    bsqrt
    // tests/artifacts/MiscellaneousOps/contract.py:31
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_btoi[routing]() -> void:
verify_btoi:
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:39
    // result = op.btoi(a)
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:37
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_bzero[routing]() -> void:
verify_bzero:
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:44
    // result = op.bzero(a)
    bzero
    // tests/artifacts/MiscellaneousOps/contract.py:45
    // return op.sha256(result)
    sha256
    // tests/artifacts/MiscellaneousOps/contract.py:42
    // @arc4.abimethod()
    bytec_1 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_concat[routing]() -> void:
verify_concat:
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:49
    // a = op.bzero(pad_a_size) + a
    swap
    bzero
    uncover 3
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:50
    // b = op.bzero(pad_b_size) + b
    swap
    bzero
    uncover 2
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:51
    // result = a + b
    concat
    // tests/artifacts/MiscellaneousOps/contract.py:52
    // result = op.sha256(result)
    sha256
    // tests/artifacts/MiscellaneousOps/contract.py:47
    // @arc4.abimethod()
    bytec_1 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divmodw[routing]() -> void:
verify_divmodw:
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:59
    // result = op.divmodw(a, b, c, d)
    divmodw
    // tests/artifacts/MiscellaneousOps/contract.py:55
    // @arc4.abimethod()
    uncover 3
    itob
    uncover 3
    itob
    concat
    uncover 2
    itob
    concat
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_divw[routing]() -> void:
verify_divw:
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:64
    // result = op.divw(a, b, c)
    divw
    // tests/artifacts/MiscellaneousOps/contract.py:62
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_exp[routing]() -> void:
verify_exp:
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:73
    // result = op.exp(a, b)
    exp
    // tests/artifacts/MiscellaneousOps/contract.py:71
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_expw[routing]() -> void:
verify_expw:
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:78
    // result = op.expw(a, b)
    expw
    // tests/artifacts/MiscellaneousOps/contract.py:76
    // @arc4.abimethod()
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract[routing]() -> void:
verify_extract:
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:83
    // result = op.extract(a, b, c)
    extract3
    // tests/artifacts/MiscellaneousOps/contract.py:81
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_from_2[routing]() -> void:
verify_extract_from_2:
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/MiscellaneousOps/contract.py:88
    // result = op.extract(a, 2, 0)
    extract 4 0
    // tests/artifacts/MiscellaneousOps/contract.py:86
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint16[routing]() -> void:
verify_extract_uint16:
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:93
    // result = op.extract_uint16(a, b)
    extract_uint16
    // tests/artifacts/MiscellaneousOps/contract.py:91
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint32[routing]() -> void:
verify_extract_uint32:
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:98
    // result = op.extract_uint32(a, b)
    extract_uint32
    // tests/artifacts/MiscellaneousOps/contract.py:96
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_extract_uint64[routing]() -> void:
verify_extract_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:101
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    pushint 8 // 8
    extract3
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_bytes[routing]() -> void:
verify_getbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:108
    // result = op.getbit(a, b)
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:106
    // @arc4.abimethod()
    bytec_2 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbit_uint64[routing]() -> void:
verify_getbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:113
    // result = op.getbit(a, b)
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:111
    // @arc4.abimethod()
    bytec_2 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_getbyte[routing]() -> void:
verify_getbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:118
    // result = op.getbyte(a, b)
    getbyte
    // tests/artifacts/MiscellaneousOps/contract.py:116
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_itob[routing]() -> void:
verify_itob:
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:123
    // result = op.itob(a)
    itob
    // tests/artifacts/MiscellaneousOps/contract.py:121
    // @arc4.abimethod()
    pushbytes 0x151f7c750008
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_mulw[routing]() -> void:
verify_mulw:
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:128
    // result = op.mulw(a, b)
    mulw
    // tests/artifacts/MiscellaneousOps/contract.py:126
    // @arc4.abimethod()
    swap
    itob
    swap
    itob
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_replace[routing]() -> void:
verify_replace:
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:133
    // result = op.replace(a, b, c)
    replace3
    // tests/artifacts/MiscellaneousOps/contract.py:131
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_bytes[routing]() -> void:
verify_select_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:138
    // result = op.select_bytes(a, b, c)
    select
    // tests/artifacts/MiscellaneousOps/contract.py:136
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_select_uint64[routing]() -> void:
verify_select_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:143
    // result = op.select_uint64(a, b, c)
    select
    // tests/artifacts/MiscellaneousOps/contract.py:141
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_bytes[routing]() -> void:
verify_setbit_bytes:
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    intc_1 // 0
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:148
    // result = op.setbit_bytes(a, b, c)
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:146
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbit_uint64[routing]() -> void:
verify_setbit_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    intc_1 // 0
    getbit
    // tests/artifacts/MiscellaneousOps/contract.py:153
    // result = op.setbit_uint64(a, b, c)
    setbit
    // tests/artifacts/MiscellaneousOps/contract.py:151
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_setbyte[routing]() -> void:
verify_setbyte:
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:158
    // result = op.setbyte(a, b, c)
    setbyte
    // tests/artifacts/MiscellaneousOps/contract.py:156
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shl[routing]() -> void:
verify_shl:
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:163
    // result = op.shl(a, b)
    shl
    // tests/artifacts/MiscellaneousOps/contract.py:161
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_shr[routing]() -> void:
verify_shr:
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:168
    // result = op.shr(a, b)
    shr
    // tests/artifacts/MiscellaneousOps/contract.py:166
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_sqrt[routing]() -> void:
verify_sqrt:
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:173
    // result = op.sqrt(a)
    sqrt
    // tests/artifacts/MiscellaneousOps/contract.py:171
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_substring[routing]() -> void:
verify_substring:
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/MiscellaneousOps/contract.py:178
    // result = op.substring(a, b, c)
    substring3
    // tests/artifacts/MiscellaneousOps/contract.py:176
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_string[routing]() -> void:
verify_json_ref_string:
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:183
    // result = op.JsonRef.json_string(a, b)
    json_ref JSONString
    // tests/artifacts/MiscellaneousOps/contract.py:181
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_uint64[routing]() -> void:
verify_json_ref_uint64:
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:188
    // result = op.JsonRef.json_uint64(a, b)
    json_ref JSONUint64
    // tests/artifacts/MiscellaneousOps/contract.py:186
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.MiscellaneousOps.contract.MiscellaneousOpsContract.verify_json_ref_object[routing]() -> void:
verify_json_ref_object:
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/MiscellaneousOps/contract.py:193
    // result = op.JsonRef.json_object(a, b)
    json_ref JSONObject
    // tests/artifacts/MiscellaneousOps/contract.py:191
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiABASYBBBUffHUxG0EFYYIlBEWEfuoE9XrOtQR9YxcwBKGyREEEzXvhrAR8/aZLBFSpENkExGVo3gR6RqauBAQ3IgkEfl9tcgQk68+EBJwLM5cECtQNpASVF4hwBN7tyZsEqyFQuwQCpUAXBD22a0EEx+qMKgQdzqUMBBYWb5oEL0cgZQTVpznDBGHzs+EEVs82iwSRn/vSBI4w9OcEifgdkgTVJgMnBBFMjG0EOenmKgTWpMBeBB74FRoEZt1/lgRNns6yBBm6cO42GgCOJQQ6BBwD/gPjA84DsAOZA30DUQMjAwYC/gLlAsgCogKEAmkCTgIzAhgB/wHkAcgBqwGDAVsBPgEYAPsA1QC8AKMAjgBoAEQAJwADgQBDMRkURDEYRDYaAVcCADYaAlcCAIgFpUkVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAlcCAIgFdxYoTFCwIkMxGRREMRhENhoBVwIANhoCVwIAiAVQSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCFzYaAxeIBR9JFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXiAT8FihMULAiQzEZFEQxGEQ2GgEXNhoCF4gE2hYoTFCwIkMxGRREMRhENhoBFzYaAheIBLgWKExQsCJDMRkURDEYRDYaAVcCADYaAhc2GgMXiASOSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBFzYaAhc2GgMXiARfFihMULAiQzEZFEQxGEQ2GgFXAgA2GgIXNhoDF4gENUkVFlcGAkxQKExQsCJDMRkURDEYRDYaARc2GgIXNhoDF4gEBhYoTFCwIkMxGRREMRhENhoBVwIANhoCVwIANhoDF4gD2kkVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAhc2GgNXAgCIA6dJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXNhoCF4gDfkwWTBZQKExQsCJDMRkURDEYRDYaAReIA15JFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgIXiAMzFihMULAiQzEZFEQxGEQ2GgEXNhoCF4gDERYoTFCwIkMxGRREMRhENhoBVwIANhoCF4gC7RYoTFCwIkMxGRREMRhENhoBVwIANhoCF4gCyRYoTFCwIkMxGRREMRhENhoBVwIANhoCF4gCpRYoTFCwIkMxGRREMRhENhoBVwIANhoCF4gCgRYoTFCwIkMxGRREMRhENhoBVwIAiAJhSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCFzYaAxeIAjBJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXNhoCF4gCB0wWTBZQKExQsCJDMRkURDEYRDYaARc2GgIXiAHhFihMULAiQzEZFEQxGEQAMRkURDEYRDYaARc2GgIXNhoDF4gBsRYoTFCwIkMxGRREMRhENhoBFzYaAhc2GgMXNhoEF4gBg08DFk8DFlBPAhZQTBZQKExQsCJDMRkURDEYRDYaAVcCADYaAlcCADYaAxc2GgQXiAE3SRUWVwYCTFAoTFCwIkMxGRREMRhENhoBF4gBE0kVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCAIgA7hYoTFCwIkMxGRREMRhENhoBVwIAiADQSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBF4gArRYoTFCwIkMxGRREMRhENhoBVwIANhoCF4gAhBYoTFCwIkMxGRREMRhENhoBVwIAiABlSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIAiAA/SRUWVwYCTFAoTFCwIkMxGRREMRhENhoBFzYaAheIABZMFkwWUChMULAiQzEZQPukMRgURCJDigICi/6L/x6JigEBi/9eAYmKAQGL/14AiYoCAYv/r4v+UEmM/pOJigEBi/+TiYoBAYv/lomKAQGL/xeJigEBi/+vAYmKBAGL/q+L/FCM/Iv/r4v9UIz9i/yL/VABiYoEBIv8i/2L/ov/H4mKAwGL/Yv+i/+XiYoCAYv+i/+UiYoCAov+i/+ViYoDAYv9i/6L/1iJigEBi/9XAgCJigIBi/6L/1mJigIBi/6L/1qJigIBi/6L/1uJigIBi/6L/1OJigIBi/6L/1OJigIBi/6L/1WJigEBi/8WiYoCAov+i/8diYoDAYv9i/6L/12JigMBi/2L/ov/TYmKAwGL/Yv+i/9NiYoDAYv9i/6L/1SJigMBi/2L/ov/VImKAwGL/Yv+i/9WiYoCAYv+i/+QiYoCAYv+i/+RiYoBAYv/komKAwGL/Yv+i/9SiYoCAYv+i/9fAImKAgGL/ov/XwGJigIBi/6L/18CiQ==", + "approval": "CiACAQAmAwQVH3x1BhUffHUAIAEAMRtBARMxGRREMRhEgiUERYR+6gT1es61BH1jFzAEobJEQQTNe+GsBHz9pksEVKkQ2QTEZWjeBHpGpq4EBDciCQR+X21yBCTrz4QEnAszlwQK1A2kBJUXiHAE3u3JmwSrIVC7BAKlQBcEPbZrQQRuP/OMBI87nxgEFhZvmgQvRyBlBNWnOcMEYfOz4QRWzzaLBJGf+9IEqui2lwSEdCKxBNUmAycEEUyMbQQ56eYqBNakwF4EHvgVGgRm3X+WBE2ezrIEGbpw7jYaAI4lAAoAHgA0AEoAXwBrAIAAjgCaAMAA5QABAPkBCQEdAToBTgFgAXIBhQGbAa8BwQHTAecCBgIlAjkCVwJsAokCmQKpArUC0gLuAwMAADEZFDEYFBBDNhoBFzYaAhceTBZMFlAoTFCwIkM2GgFXAgBeAUkVFlcGAkxQKExQsCJDNhoBVwIAXgBJFRZXBgJMUChMULAiQzYaAVcCADYaAhevTFCTFihMULAiQzYaAReTFihMULAiQzYaAVcCAJZJFRZXBgJMUChMULAiQzYaAVcCABcWKExQsCJDNhoBF68BKUxQsCJDNhoBVwIANhoCVwIANhoDFzYaBBdMr08DUEyvTwJQUAEpTFCwIkM2GgEXNhoCFzYaAxc2GgQXH08DFk8DFlBPAhZQTBZQKExQsCJDNhoBFzYaAhc2GgMXlxYoTFCwIkM2GgEXNhoCF5QWKExQsCJDNhoBFzYaAheVTBZMFlAoTFCwIkM2GgFXAgA2GgIXNhoDF1hJFRZXBgJMUChMULAiQzYaAVcEAEkVFlcGAkxQKExQsCJDNhoBVwIANhoCF1kWKExQsCJDNhoBVwIANhoCF1oWKExQsCJDNhoBVwIANhoCF4EIWChMULAiQzYaAVcCADYaAhdTKiNPAlQoTFCwIkM2GgEXNhoCF1MqI08CVChMULAiQzYaAVcCADYaAhdVFihMULAiQzYaARcWgAYVH3x1AAhMULAiQzYaARc2GgIXHUwWTBZQKExQsCJDNhoBVwIANhoCFzYaA1cCAF1JFRZXBgJMUChMULAiQzYaAVcCADYaAlcCADYaAxdNSRUWVwYCTFAoTFCwIkM2GgEXNhoCFzYaAxdNFihMULAiQzYaAVcCADYaAhc2GgMjU1RJFRZXBgJMUChMULAiQzYaARc2GgIXNhoDI1NUFihMULAiQzYaAVcCADYaAhc2GgMXVkkVFlcGAkxQKExQsCJDNhoBFzYaAheQFihMULAiQzYaARc2GgIXkRYoTFCwIkM2GgEXkhYoTFCwIkM2GgFXAgA2GgIXNhoDF1JJFRZXBgJMUChMULAiQzYaAVcCADYaAlcCAF8ASRUWVwYCTFAoTFCwIkM2GgFXAgA2GgJXAgBfARYoTFCwIkM2GgFXAgA2GgJXAgBfAkkVFlcGAkxQKExQsCJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.approval.teal b/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.approval.teal index 95304ba..3ef2382 100644 --- a/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.approval.teal +++ b/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.approval.teal @@ -4,1633 +4,41 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: intcblock 1 0 - bytecblock 0x151f7c75 0x00 "-" + bytecblock 0x151f7c75 0x00 "-" 0x151f7c750020 // tests/artifacts/PrimitiveOps/contract.py:6 // class PrimitiveOpsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@65 - pushbytess 0x725c692b 0x17314559 0x53f34893 0x88c8b269 0xa464b7ab 0x9c8b11b8 0x6f40654e 0xec9a2974 0xc793708f 0x7ddb7499 0xa21c443d 0x6e7fb212 0xb007fcb0 0x2ebc20d4 0xb0954b66 0xdd140aef 0xace474da 0xba694990 0x6db581c0 0x91c8db89 0xdbe77158 0x9a0f22e1 0x64033d37 0x2a7237c5 0xe3a94458 0x42f87f7d 0x2b5542a4 0x9be2fbe9 0x1cd92515 0x64e1705c 0xf1271c50 0x2ab63b70 0x834bb7d2 0x531620d7 0x3fb9e769 0xfa8db0bc 0xa72ea485 0xb7b0ba19 0x74460c42 0xab320738 0x52ad4654 0x10156399 0x0f075957 0xbd843dff 0xb377d381 0x89767265 0x456b4b23 0x33d1b88c 0x6bf973ea 0x67cd6bb2 0x3f58805a 0x1e130039 0x509dc91d 0xa564a202 0x23650763 0xf8c8f8d5 0x23faf7a4 0x7d0afe15 0x48581adf 0xe007c10b // method "verify_uint64_init(byte[])uint64", method "verify_uint64_add(uint64,uint64)uint64", method "verify_uint64_sub(uint64,uint64)uint64", method "verify_uint64_mul(uint64,uint64)uint64", method "verify_uint64_div(uint64,uint64)uint64", method "verify_uint64_mod(uint64,uint64)uint64", method "verify_uint64_and(uint64,uint64)uint64", method "verify_uint64_or(uint64,uint64)uint64", method "verify_uint64_xor(uint64,uint64)uint64", method "verify_uint64_not(uint64)uint64", method "verify_uint64_lshift(uint64,uint64)uint64", method "verify_uint64_rshift(uint64,uint64)uint64", method "verify_uint64_pow(uint64,uint64)uint64", method "verify_uint64_eq(uint64,uint64)bool", method "verify_uint64_ne(uint64,uint64)bool", method "verify_uint64_lt(uint64,uint64)bool", method "verify_uint64_le(uint64,uint64)bool", method "verify_uint64_gt(uint64,uint64)bool", method "verify_uint64_ge(uint64,uint64)bool", method "verify_bytes_init(uint64)byte[]", method "verify_bytes_add(byte[],byte[],uint64,uint64)byte[]", method "verify_bytes_eq(byte[],byte[])bool", method "verify_bytes_ne(byte[],byte[])bool", method "verify_bytes_and(byte[],byte[])byte[]", method "verify_bytes_or(byte[],byte[])byte[]", method "verify_bytes_xor(byte[],byte[])byte[]", method "verify_bytes_not(byte[],uint64)byte[]", method "verify_biguint_add(byte[],byte[])byte[]", method "verify_biguint_add_uint64(byte[],uint64)byte[]", method "verify_biguint_sub(byte[],byte[])byte[]", method "verify_biguint_sub_uint64(byte[],uint64)byte[]", method "verify_biguint_mul(byte[],byte[])byte[]", method "verify_biguint_mul_uint64(byte[],uint64)byte[]", method "verify_biguint_div(byte[],byte[])byte[]", method "verify_biguint_div_uint64(byte[],uint64)byte[]", method "verify_biguint_mod(byte[],byte[])byte[]", method "verify_biguint_mod_uint64(byte[],uint64)byte[]", method "verify_biguint_and(byte[],byte[])byte[]", method "verify_biguint_and_uint64(byte[],uint64)byte[]", method "verify_biguint_or(byte[],byte[])byte[]", method "verify_biguint_or_uint64(byte[],uint64)byte[]", method "verify_biguint_xor(byte[],byte[])byte[]", method "verify_biguint_xor_uint64(byte[],uint64)byte[]", method "verify_biguint_eq(byte[],byte[])bool", method "verify_biguint_eq_uint64(byte[],uint64)bool", method "verify_biguint_ne(byte[],byte[])bool", method "verify_biguint_ne_uint64(byte[],uint64)bool", method "verify_biguint_lt(byte[],byte[])bool", method "verify_biguint_lt_uint64(byte[],uint64)bool", method "verify_biguint_le(byte[],byte[])bool", method "verify_biguint_le_uint64(byte[],uint64)bool", method "verify_biguint_gt(byte[],byte[])bool", method "verify_biguint_gt_uint64(byte[],uint64)bool", method "verify_biguint_ge(byte[],byte[])bool", method "verify_biguint_ge_uint64(byte[],uint64)bool", method "verify_string_init(string)string", method "verify_string_startswith(string,string)bool", method "verify_string_endswith(string,string)bool", method "verify_string_join(string,string)string", method "verify_log(string,uint64,byte[],byte[],bool,string,uint64,uint256,ufixed32x8,ufixed256x16,byte[],byte[],byte[])void" - txna ApplicationArgs 0 - match main_verify_uint64_init_route@3 main_verify_uint64_add_route@4 main_verify_uint64_sub_route@5 main_verify_uint64_mul_route@6 main_verify_uint64_div_route@7 main_verify_uint64_mod_route@8 main_verify_uint64_and_route@9 main_verify_uint64_or_route@10 main_verify_uint64_xor_route@11 main_verify_uint64_not_route@12 main_verify_uint64_lshift_route@13 main_verify_uint64_rshift_route@14 main_verify_uint64_pow_route@15 main_verify_uint64_eq_route@16 main_verify_uint64_ne_route@17 main_verify_uint64_lt_route@18 main_verify_uint64_le_route@19 main_verify_uint64_gt_route@20 main_verify_uint64_ge_route@21 main_verify_bytes_init_route@22 main_verify_bytes_add_route@23 main_verify_bytes_eq_route@24 main_verify_bytes_ne_route@25 main_verify_bytes_and_route@26 main_verify_bytes_or_route@27 main_verify_bytes_xor_route@28 main_verify_bytes_not_route@29 main_verify_biguint_add_route@30 main_verify_biguint_add_uint64_route@31 main_verify_biguint_sub_route@32 main_verify_biguint_sub_uint64_route@33 main_verify_biguint_mul_route@34 main_verify_biguint_mul_uint64_route@35 main_verify_biguint_div_route@36 main_verify_biguint_div_uint64_route@37 main_verify_biguint_mod_route@38 main_verify_biguint_mod_uint64_route@39 main_verify_biguint_and_route@40 main_verify_biguint_and_uint64_route@41 main_verify_biguint_or_route@42 main_verify_biguint_or_uint64_route@43 main_verify_biguint_xor_route@44 main_verify_biguint_xor_uint64_route@45 main_verify_biguint_eq_route@46 main_verify_biguint_eq_uint64_route@47 main_verify_biguint_ne_route@48 main_verify_biguint_ne_uint64_route@49 main_verify_biguint_lt_route@50 main_verify_biguint_lt_uint64_route@51 main_verify_biguint_le_route@52 main_verify_biguint_le_uint64_route@53 main_verify_biguint_gt_route@54 main_verify_biguint_gt_uint64_route@55 main_verify_biguint_ge_route@56 main_verify_biguint_ge_uint64_route@57 main_verify_string_init_route@58 main_verify_string_startswith_route@59 main_verify_string_endswith_route@60 main_verify_string_join_route@61 main_verify_log_route@62 - -main_after_if_else@69: - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - intc_1 // 0 - return - -main_verify_log_route@62: - // tests/artifacts/PrimitiveOps/contract.py:351 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - txna ApplicationArgs 3 - extract 2 0 - txna ApplicationArgs 4 - extract 2 0 - txna ApplicationArgs 5 - txna ApplicationArgs 6 - txna ApplicationArgs 7 - txna ApplicationArgs 8 - txna ApplicationArgs 9 - txna ApplicationArgs 10 - txna ApplicationArgs 11 - extract 2 0 - txna ApplicationArgs 12 - extract 2 0 - txna ApplicationArgs 13 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:351 - // @arc4.abimethod - callsub verify_log - intc_0 // 1 - return - -main_verify_string_join_route@61: - // tests/artifacts/PrimitiveOps/contract.py:346 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:346 - // @arc4.abimethod - callsub verify_string_join - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_endswith_route@60: - // tests/artifacts/PrimitiveOps/contract.py:341 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:341 - // @arc4.abimethod - callsub verify_string_endswith - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_startswith_route@59: - // tests/artifacts/PrimitiveOps/contract.py:336 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:336 - // @arc4.abimethod - callsub verify_string_startswith - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_string_init_route@58: - // tests/artifacts/PrimitiveOps/contract.py:331 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:331 - // @arc4.abimethod - callsub verify_string_init - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_ge_uint64_route@57: - // tests/artifacts/PrimitiveOps/contract.py:325 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:325 - // @arc4.abimethod() - callsub verify_biguint_ge_uint64 - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_ge_route@56: - // tests/artifacts/PrimitiveOps/contract.py:318 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:318 - // @arc4.abimethod() - callsub verify_biguint_ge - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_gt_uint64_route@55: - // tests/artifacts/PrimitiveOps/contract.py:312 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:312 - // @arc4.abimethod() - callsub verify_biguint_gt_uint64 - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_gt_route@54: - // tests/artifacts/PrimitiveOps/contract.py:305 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:305 - // @arc4.abimethod() - callsub verify_biguint_gt - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_le_uint64_route@53: - // tests/artifacts/PrimitiveOps/contract.py:299 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:299 - // @arc4.abimethod() - callsub verify_biguint_le_uint64 - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_le_route@52: - // tests/artifacts/PrimitiveOps/contract.py:292 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:292 - // @arc4.abimethod() - callsub verify_biguint_le - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_lt_uint64_route@51: - // tests/artifacts/PrimitiveOps/contract.py:286 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:286 - // @arc4.abimethod() - callsub verify_biguint_lt_uint64 - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_lt_route@50: - // tests/artifacts/PrimitiveOps/contract.py:279 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:279 - // @arc4.abimethod() - callsub verify_biguint_lt - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_ne_uint64_route@49: - // tests/artifacts/PrimitiveOps/contract.py:273 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:273 - // @arc4.abimethod() - callsub verify_biguint_ne_uint64 - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_ne_route@48: - // tests/artifacts/PrimitiveOps/contract.py:266 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:266 - // @arc4.abimethod() - callsub verify_biguint_ne - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_eq_uint64_route@47: - // tests/artifacts/PrimitiveOps/contract.py:260 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:260 - // @arc4.abimethod() - callsub verify_biguint_eq_uint64 - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_eq_route@46: - // tests/artifacts/PrimitiveOps/contract.py:253 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:253 - // @arc4.abimethod() - callsub verify_biguint_eq - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_xor_uint64_route@45: - // tests/artifacts/PrimitiveOps/contract.py:247 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:247 - // @arc4.abimethod() - callsub verify_biguint_xor_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_xor_route@44: - // tests/artifacts/PrimitiveOps/contract.py:240 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:240 - // @arc4.abimethod() - callsub verify_biguint_xor - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_or_uint64_route@43: - // tests/artifacts/PrimitiveOps/contract.py:234 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:234 - // @arc4.abimethod() - callsub verify_biguint_or_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_or_route@42: - // tests/artifacts/PrimitiveOps/contract.py:227 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:227 - // @arc4.abimethod() - callsub verify_biguint_or - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_and_uint64_route@41: - // tests/artifacts/PrimitiveOps/contract.py:221 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:221 - // @arc4.abimethod() - callsub verify_biguint_and_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_and_route@40: - // tests/artifacts/PrimitiveOps/contract.py:214 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:214 - // @arc4.abimethod() - callsub verify_biguint_and - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_mod_uint64_route@39: - // tests/artifacts/PrimitiveOps/contract.py:208 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:208 - // @arc4.abimethod() - callsub verify_biguint_mod_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_mod_route@38: - // tests/artifacts/PrimitiveOps/contract.py:201 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:201 - // @arc4.abimethod() - callsub verify_biguint_mod - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_div_uint64_route@37: - // tests/artifacts/PrimitiveOps/contract.py:195 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:195 - // @arc4.abimethod() - callsub verify_biguint_div_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_div_route@36: - // tests/artifacts/PrimitiveOps/contract.py:188 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:188 - // @arc4.abimethod() - callsub verify_biguint_div - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_mul_uint64_route@35: - // tests/artifacts/PrimitiveOps/contract.py:182 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:182 - // @arc4.abimethod() - callsub verify_biguint_mul_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_mul_route@34: - // tests/artifacts/PrimitiveOps/contract.py:175 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:175 - // @arc4.abimethod() - callsub verify_biguint_mul - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_sub_uint64_route@33: - // tests/artifacts/PrimitiveOps/contract.py:169 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:169 - // @arc4.abimethod() - callsub verify_biguint_sub_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_sub_route@32: - // tests/artifacts/PrimitiveOps/contract.py:162 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:162 - // @arc4.abimethod() - callsub verify_biguint_sub - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_add_uint64_route@31: - // tests/artifacts/PrimitiveOps/contract.py:156 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:156 - // @arc4.abimethod() - callsub verify_biguint_add_uint64 - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_biguint_add_route@30: - // tests/artifacts/PrimitiveOps/contract.py:149 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:149 - // @arc4.abimethod() - callsub verify_biguint_add - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_not_route@29: - // tests/artifacts/PrimitiveOps/contract.py:142 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:142 - // @arc4.abimethod() - callsub verify_bytes_not - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_xor_route@28: - // tests/artifacts/PrimitiveOps/contract.py:137 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:137 - // @arc4.abimethod() - callsub verify_bytes_xor - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_or_route@27: - // tests/artifacts/PrimitiveOps/contract.py:132 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:132 - // @arc4.abimethod() - callsub verify_bytes_or - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_and_route@26: - // tests/artifacts/PrimitiveOps/contract.py:127 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:127 - // @arc4.abimethod() - callsub verify_bytes_and - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_ne_route@25: - // tests/artifacts/PrimitiveOps/contract.py:122 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:122 - // @arc4.abimethod() - callsub verify_bytes_ne - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_eq_route@24: - // tests/artifacts/PrimitiveOps/contract.py:117 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:117 - // @arc4.abimethod() - callsub verify_bytes_eq - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_add_route@23: - // tests/artifacts/PrimitiveOps/contract.py:107 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - btoi - txna ApplicationArgs 4 - btoi - // tests/artifacts/PrimitiveOps/contract.py:107 - // @arc4.abimethod() - callsub verify_bytes_add - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_bytes_init_route@22: - // tests/artifacts/PrimitiveOps/contract.py:102 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/PrimitiveOps/contract.py:102 - // @arc4.abimethod() - callsub verify_bytes_init - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_ge_route@21: - // tests/artifacts/PrimitiveOps/contract.py:97 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:97 - // @arc4.abimethod() - callsub verify_uint64_ge - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_gt_route@20: - // tests/artifacts/PrimitiveOps/contract.py:92 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:92 - // @arc4.abimethod() - callsub verify_uint64_gt - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_le_route@19: - // tests/artifacts/PrimitiveOps/contract.py:87 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:87 - // @arc4.abimethod() - callsub verify_uint64_le - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_lt_route@18: - // tests/artifacts/PrimitiveOps/contract.py:82 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:82 - // @arc4.abimethod() - callsub verify_uint64_lt - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_ne_route@17: - // tests/artifacts/PrimitiveOps/contract.py:77 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:77 - // @arc4.abimethod() - callsub verify_uint64_ne - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_eq_route@16: - // tests/artifacts/PrimitiveOps/contract.py:72 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:72 - // @arc4.abimethod() - callsub verify_uint64_eq - bytec_1 // 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_pow_route@15: - // tests/artifacts/PrimitiveOps/contract.py:67 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:67 - // @arc4.abimethod() - callsub verify_uint64_pow - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_rshift_route@14: - // tests/artifacts/PrimitiveOps/contract.py:62 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:62 - // @arc4.abimethod() - callsub verify_uint64_rshift - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_lshift_route@13: - // tests/artifacts/PrimitiveOps/contract.py:57 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:57 - // @arc4.abimethod() - callsub verify_uint64_lshift - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_not_route@12: - // tests/artifacts/PrimitiveOps/contract.py:52 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - // tests/artifacts/PrimitiveOps/contract.py:52 - // @arc4.abimethod() - callsub verify_uint64_not - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_xor_route@11: - // tests/artifacts/PrimitiveOps/contract.py:47 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:47 - // @arc4.abimethod() - callsub verify_uint64_xor - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_or_route@10: - // tests/artifacts/PrimitiveOps/contract.py:42 - // @arc4.abimethod() + bz main___algopy_default_create@67 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:42 - // @arc4.abimethod() - callsub verify_uint64_or - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + assert + pushbytess 0x725c692b 0x17314559 0x53f34893 0x88c8b269 0xa464b7ab 0x9c8b11b8 0x6f40654e 0xec9a2974 0xc793708f 0x7ddb7499 0xa21c443d 0x6e7fb212 0xb007fcb0 0x2ebc20d4 0xb0954b66 0xdd140aef 0xace474da 0xba694990 0x6db581c0 0x91c8db89 0xdbe77158 0x9a0f22e1 0x64033d37 0x2a7237c5 0xe3a94458 0x42f87f7d 0x2b5542a4 0x9be2fbe9 0x1cd92515 0x64e1705c 0xf1271c50 0x2ab63b70 0x834bb7d2 0x531620d7 0x3fb9e769 0xfa8db0bc 0xa72ea485 0xb7b0ba19 0x74460c42 0xab320738 0x52ad4654 0x10156399 0x0f075957 0xbd843dff 0xb377d381 0x89767265 0x456b4b23 0x33d1b88c 0x6bf973ea 0x67cd6bb2 0x3f58805a 0x1e130039 0x509dc91d 0xa564a202 0x23650763 0xf8c8f8d5 0x23faf7a4 0x7d0afe15 0x48581adf 0xe007c10b // method "verify_uint64_init(byte[])uint64", method "verify_uint64_add(uint64,uint64)uint64", method "verify_uint64_sub(uint64,uint64)uint64", method "verify_uint64_mul(uint64,uint64)uint64", method "verify_uint64_div(uint64,uint64)uint64", method "verify_uint64_mod(uint64,uint64)uint64", method "verify_uint64_and(uint64,uint64)uint64", method "verify_uint64_or(uint64,uint64)uint64", method "verify_uint64_xor(uint64,uint64)uint64", method "verify_uint64_not(uint64)uint64", method "verify_uint64_lshift(uint64,uint64)uint64", method "verify_uint64_rshift(uint64,uint64)uint64", method "verify_uint64_pow(uint64,uint64)uint64", method "verify_uint64_eq(uint64,uint64)bool", method "verify_uint64_ne(uint64,uint64)bool", method "verify_uint64_lt(uint64,uint64)bool", method "verify_uint64_le(uint64,uint64)bool", method "verify_uint64_gt(uint64,uint64)bool", method "verify_uint64_ge(uint64,uint64)bool", method "verify_bytes_init(uint64)byte[]", method "verify_bytes_add(byte[],byte[],uint64,uint64)byte[]", method "verify_bytes_eq(byte[],byte[])bool", method "verify_bytes_ne(byte[],byte[])bool", method "verify_bytes_and(byte[],byte[])byte[]", method "verify_bytes_or(byte[],byte[])byte[]", method "verify_bytes_xor(byte[],byte[])byte[]", method "verify_bytes_not(byte[],uint64)byte[]", method "verify_biguint_add(byte[],byte[])byte[]", method "verify_biguint_add_uint64(byte[],uint64)byte[]", method "verify_biguint_sub(byte[],byte[])byte[]", method "verify_biguint_sub_uint64(byte[],uint64)byte[]", method "verify_biguint_mul(byte[],byte[])byte[]", method "verify_biguint_mul_uint64(byte[],uint64)byte[]", method "verify_biguint_div(byte[],byte[])byte[]", method "verify_biguint_div_uint64(byte[],uint64)byte[]", method "verify_biguint_mod(byte[],byte[])byte[]", method "verify_biguint_mod_uint64(byte[],uint64)byte[]", method "verify_biguint_and(byte[],byte[])byte[]", method "verify_biguint_and_uint64(byte[],uint64)byte[]", method "verify_biguint_or(byte[],byte[])byte[]", method "verify_biguint_or_uint64(byte[],uint64)byte[]", method "verify_biguint_xor(byte[],byte[])byte[]", method "verify_biguint_xor_uint64(byte[],uint64)byte[]", method "verify_biguint_eq(byte[],byte[])bool", method "verify_biguint_eq_uint64(byte[],uint64)bool", method "verify_biguint_ne(byte[],byte[])bool", method "verify_biguint_ne_uint64(byte[],uint64)bool", method "verify_biguint_lt(byte[],byte[])bool", method "verify_biguint_lt_uint64(byte[],uint64)bool", method "verify_biguint_le(byte[],byte[])bool", method "verify_biguint_le_uint64(byte[],uint64)bool", method "verify_biguint_gt(byte[],byte[])bool", method "verify_biguint_gt_uint64(byte[],uint64)bool", method "verify_biguint_ge(byte[],byte[])bool", method "verify_biguint_ge_uint64(byte[],uint64)bool", method "verify_string_init(string)string", method "verify_string_startswith(string,string)bool", method "verify_string_endswith(string,string)bool", method "verify_string_join(string,string)string", method "verify_log(string,uint64,byte[],byte[],bool,string,uint64,uint256,ufixed32x8,ufixed256x16,byte[],byte[],byte[])void" + txna ApplicationArgs 0 + match verify_uint64_init verify_uint64_add verify_uint64_sub verify_uint64_mul verify_uint64_div verify_uint64_mod verify_uint64_and verify_uint64_or verify_uint64_xor verify_uint64_not verify_uint64_lshift verify_uint64_rshift verify_uint64_pow verify_uint64_eq verify_uint64_ne verify_uint64_lt verify_uint64_le verify_uint64_gt verify_uint64_ge verify_bytes_init verify_bytes_add verify_bytes_eq verify_bytes_ne verify_bytes_and verify_bytes_or verify_bytes_xor verify_bytes_not verify_biguint_add verify_biguint_add_uint64 verify_biguint_sub verify_biguint_sub_uint64 verify_biguint_mul verify_biguint_mul_uint64 verify_biguint_div verify_biguint_div_uint64 verify_biguint_mod verify_biguint_mod_uint64 verify_biguint_and verify_biguint_and_uint64 verify_biguint_or verify_biguint_or_uint64 verify_biguint_xor verify_biguint_xor_uint64 verify_biguint_eq verify_biguint_eq_uint64 verify_biguint_ne verify_biguint_ne_uint64 verify_biguint_lt verify_biguint_lt_uint64 verify_biguint_le verify_biguint_le_uint64 verify_biguint_gt verify_biguint_gt_uint64 verify_biguint_ge verify_biguint_ge_uint64 verify_string_init verify_string_startswith verify_string_endswith verify_string_join verify_log + err -main_verify_uint64_and_route@9: - // tests/artifacts/PrimitiveOps/contract.py:37 - // @arc4.abimethod() +main___algopy_default_create@67: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:37 - // @arc4.abimethod() - callsub verify_uint64_and - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_mod_route@8: - // tests/artifacts/PrimitiveOps/contract.py:32 - // @arc4.abimethod() - txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:32 - // @arc4.abimethod() - callsub verify_uint64_mod - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_uint64_div_route@7: - // tests/artifacts/PrimitiveOps/contract.py:27 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:27 - // @arc4.abimethod() - callsub verify_uint64_div - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_uint64_mul_route@6: - // tests/artifacts/PrimitiveOps/contract.py:22 +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_init[routing]() -> void: +verify_uint64_init: + // tests/artifacts/PrimitiveOps/contract.py:7 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): txna ApplicationArgs 1 + extract 2 0 + // tests/artifacts/PrimitiveOps/contract.py:9 + // result = op.btoi(raw_value) btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:22 + // tests/artifacts/PrimitiveOps/contract.py:7 // @arc4.abimethod() - callsub verify_uint64_mul itob bytec_0 // 0x151f7c75 swap @@ -1639,1196 +47,1621 @@ main_verify_uint64_mul_route@6: intc_0 // 1 return -main_verify_uint64_sub_route@5: - // tests/artifacts/PrimitiveOps/contract.py:17 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txna ApplicationArgs 2 - btoi - // tests/artifacts/PrimitiveOps/contract.py:17 - // @arc4.abimethod() - callsub verify_uint64_sub - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_uint64_add_route@4: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_add[routing]() -> void: +verify_uint64_add: // tests/artifacts/PrimitiveOps/contract.py:12 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): txna ApplicationArgs 1 btoi txna ApplicationArgs 2 btoi - // tests/artifacts/PrimitiveOps/contract.py:12 - // @arc4.abimethod() - callsub verify_uint64_add - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_uint64_init_route@3: - // tests/artifacts/PrimitiveOps/contract.py:7 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/PrimitiveOps/contract.py:7 - // @arc4.abimethod() - callsub verify_uint64_init - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_bare_routing@65: - // tests/artifacts/PrimitiveOps/contract.py:6 - // class PrimitiveOpsContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@69 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_init(raw_value: bytes) -> uint64: -verify_uint64_init: - // tests/artifacts/PrimitiveOps/contract.py:7-8 - // @arc4.abimethod() - // def verify_uint64_init(self, raw_value: Bytes) -> UInt64: - proto 1 1 - // tests/artifacts/PrimitiveOps/contract.py:9 - // result = op.btoi(raw_value) - frame_dig -1 - btoi - // tests/artifacts/PrimitiveOps/contract.py:10 - // return result - retsub - - -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_add(a: uint64, b: uint64) -> uint64: -verify_uint64_add: - // tests/artifacts/PrimitiveOps/contract.py:12-13 - // @arc4.abimethod() - // def verify_uint64_add(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 // tests/artifacts/PrimitiveOps/contract.py:14 // result = a + b - frame_dig -2 - frame_dig -1 + - // tests/artifacts/PrimitiveOps/contract.py:15 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:12 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_sub(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_sub[routing]() -> void: verify_uint64_sub: - // tests/artifacts/PrimitiveOps/contract.py:17-18 + // tests/artifacts/PrimitiveOps/contract.py:17 // @arc4.abimethod() - // def verify_uint64_sub(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:19 // result = a - b - frame_dig -2 - frame_dig -1 - - // tests/artifacts/PrimitiveOps/contract.py:20 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:17 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mul(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mul[routing]() -> void: verify_uint64_mul: - // tests/artifacts/PrimitiveOps/contract.py:22-23 + // tests/artifacts/PrimitiveOps/contract.py:22 // @arc4.abimethod() - // def verify_uint64_mul(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:24 // result = a * b - frame_dig -2 - frame_dig -1 * - // tests/artifacts/PrimitiveOps/contract.py:25 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:22 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_div(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_div[routing]() -> void: verify_uint64_div: - // tests/artifacts/PrimitiveOps/contract.py:27-28 + // tests/artifacts/PrimitiveOps/contract.py:27 // @arc4.abimethod() - // def verify_uint64_div(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:29 // result = a // b - frame_dig -2 - frame_dig -1 / - // tests/artifacts/PrimitiveOps/contract.py:30 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:27 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mod(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mod[routing]() -> void: verify_uint64_mod: - // tests/artifacts/PrimitiveOps/contract.py:32-33 + // tests/artifacts/PrimitiveOps/contract.py:32 // @arc4.abimethod() - // def verify_uint64_mod(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:34 // result = a % b - frame_dig -2 - frame_dig -1 % - // tests/artifacts/PrimitiveOps/contract.py:35 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:32 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_and(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_and[routing]() -> void: verify_uint64_and: - // tests/artifacts/PrimitiveOps/contract.py:37-38 + // tests/artifacts/PrimitiveOps/contract.py:37 // @arc4.abimethod() - // def verify_uint64_and(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:39 // result = a & b - frame_dig -2 - frame_dig -1 & - // tests/artifacts/PrimitiveOps/contract.py:40 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:37 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_or(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_or[routing]() -> void: verify_uint64_or: - // tests/artifacts/PrimitiveOps/contract.py:42-43 + // tests/artifacts/PrimitiveOps/contract.py:42 // @arc4.abimethod() - // def verify_uint64_or(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:44 // result = a | b - frame_dig -2 - frame_dig -1 | - // tests/artifacts/PrimitiveOps/contract.py:45 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:42 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_xor(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_xor[routing]() -> void: verify_uint64_xor: - // tests/artifacts/PrimitiveOps/contract.py:47-48 + // tests/artifacts/PrimitiveOps/contract.py:47 // @arc4.abimethod() - // def verify_uint64_xor(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:49 // result = a ^ b - frame_dig -2 - frame_dig -1 ^ - // tests/artifacts/PrimitiveOps/contract.py:50 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:47 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_not(a: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_not[routing]() -> void: verify_uint64_not: - // tests/artifacts/PrimitiveOps/contract.py:52-53 + // tests/artifacts/PrimitiveOps/contract.py:52 // @arc4.abimethod() - // def verify_uint64_not(self, a: UInt64) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/PrimitiveOps/contract.py:54 // result = ~a - frame_dig -1 ~ - // tests/artifacts/PrimitiveOps/contract.py:55 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:52 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lshift(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lshift[routing]() -> void: verify_uint64_lshift: - // tests/artifacts/PrimitiveOps/contract.py:57-58 + // tests/artifacts/PrimitiveOps/contract.py:57 // @arc4.abimethod() - // def verify_uint64_lshift(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:59 // result = a << b - frame_dig -2 - frame_dig -1 shl - // tests/artifacts/PrimitiveOps/contract.py:60 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:57 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_rshift(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_rshift[routing]() -> void: verify_uint64_rshift: - // tests/artifacts/PrimitiveOps/contract.py:62-63 + // tests/artifacts/PrimitiveOps/contract.py:62 // @arc4.abimethod() - // def verify_uint64_rshift(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:64 // result = a >> b - frame_dig -2 - frame_dig -1 shr - // tests/artifacts/PrimitiveOps/contract.py:65 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:62 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_pow(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_pow[routing]() -> void: verify_uint64_pow: - // tests/artifacts/PrimitiveOps/contract.py:67-68 + // tests/artifacts/PrimitiveOps/contract.py:67 // @arc4.abimethod() - // def verify_uint64_pow(self, a: UInt64, b: UInt64) -> UInt64: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:69 // result = a**b - frame_dig -2 - frame_dig -1 exp - // tests/artifacts/PrimitiveOps/contract.py:70 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:67 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_eq(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_eq[routing]() -> void: verify_uint64_eq: - // tests/artifacts/PrimitiveOps/contract.py:72-73 + // tests/artifacts/PrimitiveOps/contract.py:72 // @arc4.abimethod() - // def verify_uint64_eq(self, a: UInt64, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:74 // result = a == b - frame_dig -2 - frame_dig -1 == - // tests/artifacts/PrimitiveOps/contract.py:75 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:72 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ne(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ne[routing]() -> void: verify_uint64_ne: - // tests/artifacts/PrimitiveOps/contract.py:77-78 + // tests/artifacts/PrimitiveOps/contract.py:77 // @arc4.abimethod() - // def verify_uint64_ne(self, a: UInt64, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:79 // result = a != b - frame_dig -2 - frame_dig -1 != - // tests/artifacts/PrimitiveOps/contract.py:80 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:77 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lt(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lt[routing]() -> void: verify_uint64_lt: - // tests/artifacts/PrimitiveOps/contract.py:82-83 + // tests/artifacts/PrimitiveOps/contract.py:82 // @arc4.abimethod() - // def verify_uint64_lt(self, a: UInt64, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:84 // result = a < b - frame_dig -2 - frame_dig -1 < - // tests/artifacts/PrimitiveOps/contract.py:85 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:82 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_le(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_le[routing]() -> void: verify_uint64_le: - // tests/artifacts/PrimitiveOps/contract.py:87-88 + // tests/artifacts/PrimitiveOps/contract.py:87 // @arc4.abimethod() - // def verify_uint64_le(self, a: UInt64, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:89 // result = a <= b - frame_dig -2 - frame_dig -1 <= - // tests/artifacts/PrimitiveOps/contract.py:90 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:87 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_gt(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_gt[routing]() -> void: verify_uint64_gt: - // tests/artifacts/PrimitiveOps/contract.py:92-93 + // tests/artifacts/PrimitiveOps/contract.py:92 // @arc4.abimethod() - // def verify_uint64_gt(self, a: UInt64, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:94 // result = a > b - frame_dig -2 - frame_dig -1 > - // tests/artifacts/PrimitiveOps/contract.py:95 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:92 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ge(a: uint64, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ge[routing]() -> void: verify_uint64_ge: - // tests/artifacts/PrimitiveOps/contract.py:97-98 + // tests/artifacts/PrimitiveOps/contract.py:97 // @arc4.abimethod() - // def verify_uint64_ge(self, a: UInt64, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:99 // result = a >= b - frame_dig -2 - frame_dig -1 >= - // tests/artifacts/PrimitiveOps/contract.py:100 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:97 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_init(raw_value: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_init[routing]() -> void: verify_bytes_init: - // tests/artifacts/PrimitiveOps/contract.py:102-103 + // tests/artifacts/PrimitiveOps/contract.py:102 // @arc4.abimethod() - // def verify_bytes_init(self, raw_value: UInt64) -> Bytes: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/PrimitiveOps/contract.py:104 // result = op.itob(raw_value) - frame_dig -1 itob - // tests/artifacts/PrimitiveOps/contract.py:105 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:102 + // @arc4.abimethod() + pushbytes 0x151f7c750008 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_add(a: bytes, b: bytes, pad_a_size: uint64, pad_b_size: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_add[routing]() -> void: verify_bytes_add: - // tests/artifacts/PrimitiveOps/contract.py:107-110 + // tests/artifacts/PrimitiveOps/contract.py:107 // @arc4.abimethod() - // def verify_bytes_add( - // self, a: Bytes, b: Bytes, pad_a_size: UInt64, pad_b_size: UInt64 - // ) -> Bytes: - proto 4 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + btoi + txna ApplicationArgs 4 + btoi // tests/artifacts/PrimitiveOps/contract.py:111 // a = op.bzero(pad_a_size) + a - frame_dig -2 + swap bzero - frame_dig -4 + uncover 3 concat - frame_bury -4 // tests/artifacts/PrimitiveOps/contract.py:112 // b = op.bzero(pad_b_size) + b - frame_dig -1 + swap bzero - frame_dig -3 + uncover 2 concat - frame_bury -3 // tests/artifacts/PrimitiveOps/contract.py:113 // result = a + b - frame_dig -4 - frame_dig -3 concat // tests/artifacts/PrimitiveOps/contract.py:114 // result = op.sha256(result) sha256 - // tests/artifacts/PrimitiveOps/contract.py:115 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:107 + // @arc4.abimethod() + bytec_3 // 0x151f7c750020 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_eq(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_eq[routing]() -> void: verify_bytes_eq: - // tests/artifacts/PrimitiveOps/contract.py:117-118 + // tests/artifacts/PrimitiveOps/contract.py:117 // @arc4.abimethod() - // def verify_bytes_eq(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:119 // result = a == b - frame_dig -2 - frame_dig -1 == - // tests/artifacts/PrimitiveOps/contract.py:120 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:117 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_ne(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_ne[routing]() -> void: verify_bytes_ne: - // tests/artifacts/PrimitiveOps/contract.py:122-123 + // tests/artifacts/PrimitiveOps/contract.py:122 // @arc4.abimethod() - // def verify_bytes_ne(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:124 // result = a != b - frame_dig -2 - frame_dig -1 != - // tests/artifacts/PrimitiveOps/contract.py:125 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:122 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_and(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_and[routing]() -> void: verify_bytes_and: - // tests/artifacts/PrimitiveOps/contract.py:127-128 + // tests/artifacts/PrimitiveOps/contract.py:127 // @arc4.abimethod() - // def verify_bytes_and(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:129 // result = a & b - frame_dig -2 - frame_dig -1 b& - // tests/artifacts/PrimitiveOps/contract.py:130 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:127 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_or(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_or[routing]() -> void: verify_bytes_or: - // tests/artifacts/PrimitiveOps/contract.py:132-133 + // tests/artifacts/PrimitiveOps/contract.py:132 // @arc4.abimethod() - // def verify_bytes_or(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:134 // result = a | b - frame_dig -2 - frame_dig -1 b| - // tests/artifacts/PrimitiveOps/contract.py:135 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:132 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_xor(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_xor[routing]() -> void: verify_bytes_xor: - // tests/artifacts/PrimitiveOps/contract.py:137-138 + // tests/artifacts/PrimitiveOps/contract.py:137 // @arc4.abimethod() - // def verify_bytes_xor(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:139 // result = a ^ b - frame_dig -2 - frame_dig -1 b^ - // tests/artifacts/PrimitiveOps/contract.py:140 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:137 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_not(a: bytes, pad_size: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_not[routing]() -> void: verify_bytes_not: - // tests/artifacts/PrimitiveOps/contract.py:142-143 + // tests/artifacts/PrimitiveOps/contract.py:142 // @arc4.abimethod() - // def verify_bytes_not(self, a: Bytes, pad_size: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:144 // a = op.bzero(pad_size) + a - frame_dig -1 bzero - frame_dig -2 + swap concat - dup - frame_bury -2 // tests/artifacts/PrimitiveOps/contract.py:145 // result = ~a b~ // tests/artifacts/PrimitiveOps/contract.py:146 // result = op.sha256(result) sha256 - // tests/artifacts/PrimitiveOps/contract.py:147 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:142 + // @arc4.abimethod() + bytec_3 // 0x151f7c750020 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add[routing]() -> void: verify_biguint_add: - // tests/artifacts/PrimitiveOps/contract.py:149-150 + // tests/artifacts/PrimitiveOps/contract.py:149 // @arc4.abimethod() - // def verify_biguint_add(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:153 // result = a_biguint + b_biguint - frame_dig -2 - frame_dig -1 b+ - // tests/artifacts/PrimitiveOps/contract.py:154 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:149 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add_uint64[routing]() -> void: verify_biguint_add_uint64: - // tests/artifacts/PrimitiveOps/contract.py:156-157 + // tests/artifacts/PrimitiveOps/contract.py:156 // @arc4.abimethod() - // def verify_biguint_add_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:159 // result = a_biguint + b - frame_dig -1 itob - frame_dig -2 b+ - // tests/artifacts/PrimitiveOps/contract.py:160 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:156 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub[routing]() -> void: verify_biguint_sub: - // tests/artifacts/PrimitiveOps/contract.py:162-163 + // tests/artifacts/PrimitiveOps/contract.py:162 // @arc4.abimethod() - // def verify_biguint_sub(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:166 // result = a_biguint - b_biguint - frame_dig -2 - frame_dig -1 b- - // tests/artifacts/PrimitiveOps/contract.py:167 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:162 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub_uint64[routing]() -> void: verify_biguint_sub_uint64: - // tests/artifacts/PrimitiveOps/contract.py:169-170 + // tests/artifacts/PrimitiveOps/contract.py:169 // @arc4.abimethod() - // def verify_biguint_sub_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:172 // result = a_biguint - b - frame_dig -1 itob - frame_dig -2 - swap b- - // tests/artifacts/PrimitiveOps/contract.py:173 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:169 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul[routing]() -> void: verify_biguint_mul: - // tests/artifacts/PrimitiveOps/contract.py:175-176 + // tests/artifacts/PrimitiveOps/contract.py:175 // @arc4.abimethod() - // def verify_biguint_mul(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:179 // result = a_biguint * b_biguint - frame_dig -2 - frame_dig -1 b* - // tests/artifacts/PrimitiveOps/contract.py:180 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:175 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul_uint64[routing]() -> void: verify_biguint_mul_uint64: - // tests/artifacts/PrimitiveOps/contract.py:182-183 + // tests/artifacts/PrimitiveOps/contract.py:182 // @arc4.abimethod() - // def verify_biguint_mul_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:185 // result = a_biguint * b - frame_dig -1 itob - frame_dig -2 b* - // tests/artifacts/PrimitiveOps/contract.py:186 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:182 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div[routing]() -> void: verify_biguint_div: - // tests/artifacts/PrimitiveOps/contract.py:188-189 + // tests/artifacts/PrimitiveOps/contract.py:188 // @arc4.abimethod() - // def verify_biguint_div(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:192 // result = a_biguint // b_biguint - frame_dig -2 - frame_dig -1 b/ - // tests/artifacts/PrimitiveOps/contract.py:193 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:188 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div_uint64[routing]() -> void: verify_biguint_div_uint64: - // tests/artifacts/PrimitiveOps/contract.py:195-196 + // tests/artifacts/PrimitiveOps/contract.py:195 // @arc4.abimethod() - // def verify_biguint_div_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:198 // result = a_biguint // b - frame_dig -1 itob - frame_dig -2 - swap b/ - // tests/artifacts/PrimitiveOps/contract.py:199 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:195 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod[routing]() -> void: verify_biguint_mod: - // tests/artifacts/PrimitiveOps/contract.py:201-202 + // tests/artifacts/PrimitiveOps/contract.py:201 // @arc4.abimethod() - // def verify_biguint_mod(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:205 // result = a_biguint % b_biguint - frame_dig -2 - frame_dig -1 b% - // tests/artifacts/PrimitiveOps/contract.py:206 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:201 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod_uint64[routing]() -> void: verify_biguint_mod_uint64: - // tests/artifacts/PrimitiveOps/contract.py:208-209 + // tests/artifacts/PrimitiveOps/contract.py:208 // @arc4.abimethod() - // def verify_biguint_mod_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:211 // result = a_biguint % b - frame_dig -1 itob - frame_dig -2 - swap b% - // tests/artifacts/PrimitiveOps/contract.py:212 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:208 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and[routing]() -> void: verify_biguint_and: - // tests/artifacts/PrimitiveOps/contract.py:214-215 + // tests/artifacts/PrimitiveOps/contract.py:214 // @arc4.abimethod() - // def verify_biguint_and(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:218 // result = a_biguint & b_biguint - frame_dig -2 - frame_dig -1 b& - // tests/artifacts/PrimitiveOps/contract.py:219 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:214 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and_uint64[routing]() -> void: verify_biguint_and_uint64: - // tests/artifacts/PrimitiveOps/contract.py:221-222 + // tests/artifacts/PrimitiveOps/contract.py:221 // @arc4.abimethod() - // def verify_biguint_and_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:224 // result = a_biguint & b - frame_dig -1 itob - frame_dig -2 b& - // tests/artifacts/PrimitiveOps/contract.py:225 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:221 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or[routing]() -> void: verify_biguint_or: - // tests/artifacts/PrimitiveOps/contract.py:227-228 + // tests/artifacts/PrimitiveOps/contract.py:227 // @arc4.abimethod() - // def verify_biguint_or(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:231 // result = a_biguint | b_biguint - frame_dig -2 - frame_dig -1 b| - // tests/artifacts/PrimitiveOps/contract.py:232 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:227 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or_uint64[routing]() -> void: verify_biguint_or_uint64: - // tests/artifacts/PrimitiveOps/contract.py:234-235 + // tests/artifacts/PrimitiveOps/contract.py:234 // @arc4.abimethod() - // def verify_biguint_or_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:237 // result = a_biguint | b - frame_dig -1 itob - frame_dig -2 b| - // tests/artifacts/PrimitiveOps/contract.py:238 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:234 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor[routing]() -> void: verify_biguint_xor: - // tests/artifacts/PrimitiveOps/contract.py:240-241 + // tests/artifacts/PrimitiveOps/contract.py:240 // @arc4.abimethod() - // def verify_biguint_xor(self, a: Bytes, b: Bytes) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:244 // result = a_biguint ^ b_biguint - frame_dig -2 - frame_dig -1 b^ - // tests/artifacts/PrimitiveOps/contract.py:245 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:240 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor_uint64(a: bytes, b: uint64) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor_uint64[routing]() -> void: verify_biguint_xor_uint64: - // tests/artifacts/PrimitiveOps/contract.py:247-248 + // tests/artifacts/PrimitiveOps/contract.py:247 // @arc4.abimethod() - // def verify_biguint_xor_uint64(self, a: Bytes, b: UInt64) -> Bytes: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:250 // result = a_biguint ^ b - frame_dig -1 itob - frame_dig -2 b^ - // tests/artifacts/PrimitiveOps/contract.py:251 - // return result.bytes - retsub + // tests/artifacts/PrimitiveOps/contract.py:247 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq[routing]() -> void: verify_biguint_eq: - // tests/artifacts/PrimitiveOps/contract.py:253-254 + // tests/artifacts/PrimitiveOps/contract.py:253 // @arc4.abimethod() - // def verify_biguint_eq(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:257 // result = a_biguint == b_biguint - frame_dig -2 - frame_dig -1 b== - // tests/artifacts/PrimitiveOps/contract.py:258 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:253 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq_uint64(a: bytes, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq_uint64[routing]() -> void: verify_biguint_eq_uint64: - // tests/artifacts/PrimitiveOps/contract.py:260-261 + // tests/artifacts/PrimitiveOps/contract.py:260 // @arc4.abimethod() - // def verify_biguint_eq_uint64(self, a: Bytes, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:263 // result = a_biguint == b - frame_dig -1 itob - frame_dig -2 b== - // tests/artifacts/PrimitiveOps/contract.py:264 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:260 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne[routing]() -> void: verify_biguint_ne: - // tests/artifacts/PrimitiveOps/contract.py:266-267 + // tests/artifacts/PrimitiveOps/contract.py:266 // @arc4.abimethod() - // def verify_biguint_ne(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:270 // result = a_biguint != b_biguint - frame_dig -2 - frame_dig -1 b!= - // tests/artifacts/PrimitiveOps/contract.py:271 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:266 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne_uint64(a: bytes, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne_uint64[routing]() -> void: verify_biguint_ne_uint64: - // tests/artifacts/PrimitiveOps/contract.py:273-274 + // tests/artifacts/PrimitiveOps/contract.py:273 // @arc4.abimethod() - // def verify_biguint_ne_uint64(self, a: Bytes, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:276 // result = a_biguint != b - frame_dig -1 itob - frame_dig -2 b!= - // tests/artifacts/PrimitiveOps/contract.py:277 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:273 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt[routing]() -> void: verify_biguint_lt: - // tests/artifacts/PrimitiveOps/contract.py:279-280 + // tests/artifacts/PrimitiveOps/contract.py:279 // @arc4.abimethod() - // def verify_biguint_lt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:283 // result = a_biguint < b_biguint - frame_dig -2 - frame_dig -1 b< - // tests/artifacts/PrimitiveOps/contract.py:284 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:279 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt_uint64(a: bytes, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt_uint64[routing]() -> void: verify_biguint_lt_uint64: - // tests/artifacts/PrimitiveOps/contract.py:286-287 + // tests/artifacts/PrimitiveOps/contract.py:286 // @arc4.abimethod() - // def verify_biguint_lt_uint64(self, a: Bytes, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:289 // result = a_biguint < b - frame_dig -1 itob - frame_dig -2 - b> - // tests/artifacts/PrimitiveOps/contract.py:290 - // return result - retsub + b< + // tests/artifacts/PrimitiveOps/contract.py:286 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le[routing]() -> void: verify_biguint_le: - // tests/artifacts/PrimitiveOps/contract.py:292-293 + // tests/artifacts/PrimitiveOps/contract.py:292 // @arc4.abimethod() - // def verify_biguint_le(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:296 // result = a_biguint <= b_biguint - frame_dig -2 - frame_dig -1 b<= - // tests/artifacts/PrimitiveOps/contract.py:297 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:292 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le_uint64(a: bytes, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le_uint64[routing]() -> void: verify_biguint_le_uint64: - // tests/artifacts/PrimitiveOps/contract.py:299-300 + // tests/artifacts/PrimitiveOps/contract.py:299 // @arc4.abimethod() - // def verify_biguint_le_uint64(self, a: Bytes, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:302 // result = a_biguint <= b - frame_dig -1 itob - frame_dig -2 - b>= - // tests/artifacts/PrimitiveOps/contract.py:303 - // return result - retsub + b<= + // tests/artifacts/PrimitiveOps/contract.py:299 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt[routing]() -> void: verify_biguint_gt: - // tests/artifacts/PrimitiveOps/contract.py:305-306 + // tests/artifacts/PrimitiveOps/contract.py:305 // @arc4.abimethod() - // def verify_biguint_gt(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:309 // result = a_biguint > b_biguint - frame_dig -2 - frame_dig -1 b> - // tests/artifacts/PrimitiveOps/contract.py:310 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:305 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt_uint64(a: bytes, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt_uint64[routing]() -> void: verify_biguint_gt_uint64: - // tests/artifacts/PrimitiveOps/contract.py:312-313 + // tests/artifacts/PrimitiveOps/contract.py:312 // @arc4.abimethod() - // def verify_biguint_gt_uint64(self, a: Bytes, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:315 // result = a_biguint > b - frame_dig -1 itob - frame_dig -2 - b< - // tests/artifacts/PrimitiveOps/contract.py:316 - // return result - retsub + b> + // tests/artifacts/PrimitiveOps/contract.py:312 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge[routing]() -> void: verify_biguint_ge: - // tests/artifacts/PrimitiveOps/contract.py:318-319 + // tests/artifacts/PrimitiveOps/contract.py:318 // @arc4.abimethod() - // def verify_biguint_ge(self, a: Bytes, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:322 // result = a_biguint >= b_biguint - frame_dig -2 - frame_dig -1 b>= - // tests/artifacts/PrimitiveOps/contract.py:323 - // return result - retsub + // tests/artifacts/PrimitiveOps/contract.py:318 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge_uint64(a: bytes, b: uint64) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge_uint64[routing]() -> void: verify_biguint_ge_uint64: - // tests/artifacts/PrimitiveOps/contract.py:325-326 + // tests/artifacts/PrimitiveOps/contract.py:325 // @arc4.abimethod() - // def verify_biguint_ge_uint64(self, a: Bytes, b: UInt64) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/PrimitiveOps/contract.py:328 // result = a_biguint >= b - frame_dig -1 itob - frame_dig -2 - b<= - // tests/artifacts/PrimitiveOps/contract.py:329 - // return result - retsub + b>= + // tests/artifacts/PrimitiveOps/contract.py:325 + // @arc4.abimethod() + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_init(a: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_init[routing]() -> void: verify_string_init: - // tests/artifacts/PrimitiveOps/contract.py:331-332 + // tests/artifacts/PrimitiveOps/contract.py:331 // @arc4.abimethod - // def verify_string_init(self, a: String) -> String: - proto 1 1 + txna ApplicationArgs 1 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:333 // result = String("Hello, ") + a pushbytes "Hello, " - frame_dig -1 + swap + concat + // tests/artifacts/PrimitiveOps/contract.py:331 + // @arc4.abimethod + dup + len + itob + extract 6 2 + swap concat - // tests/artifacts/PrimitiveOps/contract.py:334 - // return result - retsub + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_startswith(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_startswith[routing]() -> void: verify_string_startswith: - // tests/artifacts/PrimitiveOps/contract.py:336-337 + // tests/artifacts/PrimitiveOps/contract.py:336 // @arc4.abimethod - // def verify_string_startswith(self, a: String, b: String) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + dup + txna ApplicationArgs 2 + extract 2 0 + dup + cover 2 // tests/artifacts/PrimitiveOps/contract.py:338 // result = a.startswith(b) - frame_dig -1 len dup - frame_dig -2 + uncover 2 len > - bz verify_string_startswith_ternary_false@2 + bz verify_string_startswith_ternary_false@3 intc_1 // 0 -verify_string_startswith_ternary_merge@3: - // tests/artifacts/PrimitiveOps/contract.py:339 - // return result +verify_string_startswith_ternary_merge@4: + // tests/artifacts/PrimitiveOps/contract.py:336 + // @arc4.abimethod + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 swap - retsub + concat + log + intc_0 // 1 + return -verify_string_startswith_ternary_false@2: +verify_string_startswith_ternary_false@3: // tests/artifacts/PrimitiveOps/contract.py:338 // result = a.startswith(b) - frame_dig -2 + dig 2 intc_1 // 0 - frame_dig 0 + dig 2 extract3 - frame_dig -1 + dig 2 == - b verify_string_startswith_ternary_merge@3 + b verify_string_startswith_ternary_merge@4 -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_endswith(a: bytes, b: bytes) -> uint64: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_endswith[routing]() -> void: verify_string_endswith: - // tests/artifacts/PrimitiveOps/contract.py:341-342 + // tests/artifacts/PrimitiveOps/contract.py:341 // @arc4.abimethod - // def verify_string_endswith(self, a: String, b: String) -> bool: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + dup + txna ApplicationArgs 2 + extract 2 0 + dup + cover 2 // tests/artifacts/PrimitiveOps/contract.py:343 // result = a.endswith(b) - frame_dig -1 len dup - frame_dig -2 + uncover 2 len dup cover 2 > - bz verify_string_endswith_ternary_false@2 + bz verify_string_endswith_ternary_false@3 intc_1 // 0 -verify_string_endswith_ternary_merge@3: - // tests/artifacts/PrimitiveOps/contract.py:344 - // return result - frame_bury 0 - retsub +verify_string_endswith_ternary_merge@4: + // tests/artifacts/PrimitiveOps/contract.py:341 + // @arc4.abimethod + bytec_1 // 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -verify_string_endswith_ternary_false@2: +verify_string_endswith_ternary_false@3: // tests/artifacts/PrimitiveOps/contract.py:343 // result = a.endswith(b) - frame_dig 1 - frame_dig 0 + dup + dig 2 dup cover 2 - - frame_dig -2 + dig 5 swap uncover 2 extract3 - frame_dig -1 + dig 3 == - b verify_string_endswith_ternary_merge@3 + b verify_string_endswith_ternary_merge@4 -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_join(a: bytes, b: bytes) -> bytes: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_join[routing]() -> void: verify_string_join: - // tests/artifacts/PrimitiveOps/contract.py:346-347 + // tests/artifacts/PrimitiveOps/contract.py:346 // @arc4.abimethod - // def verify_string_join(self, a: String, b: String) -> String: - proto 2 1 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:348 // result = String(", ").join((a, b)) - frame_dig -2 + swap pushbytes ", " concat - frame_dig -1 + swap + concat + // tests/artifacts/PrimitiveOps/contract.py:346 + // @arc4.abimethod + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap concat - // tests/artifacts/PrimitiveOps/contract.py:349 - // return result - retsub + log + intc_0 // 1 + return -// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_log(a: bytes, b: uint64, c: bytes, d: bytes, e: bytes, f: bytes, g: bytes, h: bytes, i: bytes, j: bytes, k: bytes, m: bytes, n: bytes) -> void: +// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_log[routing]() -> void: verify_log: - // tests/artifacts/PrimitiveOps/contract.py:351-367 + // tests/artifacts/PrimitiveOps/contract.py:351 // @arc4.abimethod - // def verify_log( # noqa: PLR0913 - // self, - // a: String, - // b: UInt64, - // c: Bytes, - // d: Bytes, - // e: arc4.Bool, - // f: arc4.String, - // g: arc4.UIntN[typing.Literal[64]], - // h: arc4.BigUIntN[typing.Literal[256]], - // i: arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]], - // j: arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]], - // k: Bytes, - // m: Bytes, - // n: Bytes, - // ) -> None: - proto 13 0 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + extract 2 0 + txna ApplicationArgs 4 + extract 2 0 + txna ApplicationArgs 5 + txna ApplicationArgs 6 + txna ApplicationArgs 7 + txna ApplicationArgs 8 + txna ApplicationArgs 9 + txna ApplicationArgs 10 + txna ApplicationArgs 11 + extract 2 0 + txna ApplicationArgs 12 + extract 2 0 + txna ApplicationArgs 13 + extract 2 0 // tests/artifacts/PrimitiveOps/contract.py:372 // log(a, b, c, d_biguint, e, f, g, h, i, j, arc4_k, arc4_m, arc4_n, sep="-") - frame_dig -13 + uncover 12 bytec_2 // "-" concat - frame_dig -12 + uncover 12 itob concat bytec_2 // "-" concat - frame_dig -11 + uncover 11 concat bytec_2 // "-" concat - frame_dig -10 + uncover 10 concat bytec_2 // "-" concat - frame_dig -9 + uncover 9 concat bytec_2 // "-" concat - frame_dig -8 + uncover 8 concat bytec_2 // "-" concat - frame_dig -7 + uncover 7 concat bytec_2 // "-" concat - frame_dig -6 + uncover 6 concat bytec_2 // "-" concat - frame_dig -5 + uncover 5 concat bytec_2 // "-" concat - frame_dig -4 + uncover 4 concat bytec_2 // "-" concat - frame_dig -3 + uncover 3 concat bytec_2 // "-" concat - frame_dig -2 + uncover 2 concat bytec_2 // "-" concat - frame_dig -1 + swap concat log - retsub + // tests/artifacts/PrimitiveOps/contract.py:351 + // @arc4.abimethod + intc_0 // 1 + return diff --git a/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc32.json b/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc32.json index 0d3b69d..35aaff2 100644 --- a/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc32.json +++ b/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc32.json @@ -302,7 +302,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x00 "-"
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@65
    pushbytess 0x725c692b 0x17314559 0x53f34893 0x88c8b269 0xa464b7ab 0x9c8b11b8 0x6f40654e 0xec9a2974 0xc793708f 0x7ddb7499 0xa21c443d 0x6e7fb212 0xb007fcb0 0x2ebc20d4 0xb0954b66 0xdd140aef 0xace474da 0xba694990 0x6db581c0 0x91c8db89 0xdbe77158 0x9a0f22e1 0x64033d37 0x2a7237c5 0xe3a94458 0x42f87f7d 0x2b5542a4 0x9be2fbe9 0x1cd92515 0x64e1705c 0xf1271c50 0x2ab63b70 0x834bb7d2 0x531620d7 0x3fb9e769 0xfa8db0bc 0xa72ea485 0xb7b0ba19 0x74460c42 0xab320738 0x52ad4654 0x10156399 0x0f075957 0xbd843dff 0xb377d381 0x89767265 0x456b4b23 0x33d1b88c 0x6bf973ea 0x67cd6bb2 0x3f58805a 0x1e130039 0x509dc91d 0xa564a202 0x23650763 0xf8c8f8d5 0x23faf7a4 0x7d0afe15 0x48581adf 0xe007c10b // method "verify_uint64_init(byte[])uint64", method "verify_uint64_add(uint64,uint64)uint64", method "verify_uint64_sub(uint64,uint64)uint64", method "verify_uint64_mul(uint64,uint64)uint64", method "verify_uint64_div(uint64,uint64)uint64", method "verify_uint64_mod(uint64,uint64)uint64", method "verify_uint64_and(uint64,uint64)uint64", method "verify_uint64_or(uint64,uint64)uint64", method "verify_uint64_xor(uint64,uint64)uint64", method "verify_uint64_not(uint64)uint64", method "verify_uint64_lshift(uint64,uint64)uint64", method "verify_uint64_rshift(uint64,uint64)uint64", method "verify_uint64_pow(uint64,uint64)uint64", method "verify_uint64_eq(uint64,uint64)bool", method "verify_uint64_ne(uint64,uint64)bool", method "verify_uint64_lt(uint64,uint64)bool", method "verify_uint64_le(uint64,uint64)bool", method "verify_uint64_gt(uint64,uint64)bool", method "verify_uint64_ge(uint64,uint64)bool", method "verify_bytes_init(uint64)byte[]", method "verify_bytes_add(byte[],byte[],uint64,uint64)byte[]", method "verify_bytes_eq(byte[],byte[])bool", method "verify_bytes_ne(byte[],byte[])bool", method "verify_bytes_and(byte[],byte[])byte[]", method "verify_bytes_or(byte[],byte[])byte[]", method "verify_bytes_xor(byte[],byte[])byte[]", method "verify_bytes_not(byte[],uint64)byte[]", method "verify_biguint_add(byte[],byte[])byte[]", method "verify_biguint_add_uint64(byte[],uint64)byte[]", method "verify_biguint_sub(byte[],byte[])byte[]", method "verify_biguint_sub_uint64(byte[],uint64)byte[]", method "verify_biguint_mul(byte[],byte[])byte[]", method "verify_biguint_mul_uint64(byte[],uint64)byte[]", method "verify_biguint_div(byte[],byte[])byte[]", method "verify_biguint_div_uint64(byte[],uint64)byte[]", method "verify_biguint_mod(byte[],byte[])byte[]", method "verify_biguint_mod_uint64(byte[],uint64)byte[]", method "verify_biguint_and(byte[],byte[])byte[]", method "verify_biguint_and_uint64(byte[],uint64)byte[]", method "verify_biguint_or(byte[],byte[])byte[]", method "verify_biguint_or_uint64(byte[],uint64)byte[]", method "verify_biguint_xor(byte[],byte[])byte[]", method "verify_biguint_xor_uint64(byte[],uint64)byte[]", method "verify_biguint_eq(byte[],byte[])bool", method "verify_biguint_eq_uint64(byte[],uint64)bool", method "verify_biguint_ne(byte[],byte[])bool", method "verify_biguint_ne_uint64(byte[],uint64)bool", method "verify_biguint_lt(byte[],byte[])bool", method "verify_biguint_lt_uint64(byte[],uint64)bool", method "verify_biguint_le(byte[],byte[])bool", method "verify_biguint_le_uint64(byte[],uint64)bool", method "verify_biguint_gt(byte[],byte[])bool", method "verify_biguint_gt_uint64(byte[],uint64)bool", method "verify_biguint_ge(byte[],byte[])bool", method "verify_biguint_ge_uint64(byte[],uint64)bool", method "verify_string_init(string)string", method "verify_string_startswith(string,string)bool", method "verify_string_endswith(string,string)bool", method "verify_string_join(string,string)string", method "verify_log(string,uint64,byte[],byte[],bool,string,uint64,uint256,ufixed32x8,ufixed256x16,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match main_verify_uint64_init_route@3 main_verify_uint64_add_route@4 main_verify_uint64_sub_route@5 main_verify_uint64_mul_route@6 main_verify_uint64_div_route@7 main_verify_uint64_mod_route@8 main_verify_uint64_and_route@9 main_verify_uint64_or_route@10 main_verify_uint64_xor_route@11 main_verify_uint64_not_route@12 main_verify_uint64_lshift_route@13 main_verify_uint64_rshift_route@14 main_verify_uint64_pow_route@15 main_verify_uint64_eq_route@16 main_verify_uint64_ne_route@17 main_verify_uint64_lt_route@18 main_verify_uint64_le_route@19 main_verify_uint64_gt_route@20 main_verify_uint64_ge_route@21 main_verify_bytes_init_route@22 main_verify_bytes_add_route@23 main_verify_bytes_eq_route@24 main_verify_bytes_ne_route@25 main_verify_bytes_and_route@26 main_verify_bytes_or_route@27 main_verify_bytes_xor_route@28 main_verify_bytes_not_route@29 main_verify_biguint_add_route@30 main_verify_biguint_add_uint64_route@31 main_verify_biguint_sub_route@32 main_verify_biguint_sub_uint64_route@33 main_verify_biguint_mul_route@34 main_verify_biguint_mul_uint64_route@35 main_verify_biguint_div_route@36 main_verify_biguint_div_uint64_route@37 main_verify_biguint_mod_route@38 main_verify_biguint_mod_uint64_route@39 main_verify_biguint_and_route@40 main_verify_biguint_and_uint64_route@41 main_verify_biguint_or_route@42 main_verify_biguint_or_uint64_route@43 main_verify_biguint_xor_route@44 main_verify_biguint_xor_uint64_route@45 main_verify_biguint_eq_route@46 main_verify_biguint_eq_uint64_route@47 main_verify_biguint_ne_route@48 main_verify_biguint_ne_uint64_route@49 main_verify_biguint_lt_route@50 main_verify_biguint_lt_uint64_route@51 main_verify_biguint_le_route@52 main_verify_biguint_le_uint64_route@53 main_verify_biguint_gt_route@54 main_verify_biguint_gt_uint64_route@55 main_verify_biguint_ge_route@56 main_verify_biguint_ge_uint64_route@57 main_verify_string_init_route@58 main_verify_string_startswith_route@59 main_verify_string_endswith_route@60 main_verify_string_join_route@61 main_verify_log_route@62

main_after_if_else@69:
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_log_route@62:
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    extract 2 0
    txna ApplicationArgs 12
    extract 2 0
    txna ApplicationArgs 13
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    callsub verify_log
    intc_0 // 1
    return

main_verify_string_join_route@61:
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    callsub verify_string_join
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_endswith_route@60:
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    callsub verify_string_endswith
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_startswith_route@59:
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    callsub verify_string_startswith
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_init_route@58:
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    callsub verify_string_init
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ge_uint64_route@57:
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    callsub verify_biguint_ge_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ge_route@56:
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    callsub verify_biguint_ge
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_gt_uint64_route@55:
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    callsub verify_biguint_gt_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_gt_route@54:
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    callsub verify_biguint_gt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_le_uint64_route@53:
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    callsub verify_biguint_le_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_le_route@52:
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    callsub verify_biguint_le
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_lt_uint64_route@51:
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    callsub verify_biguint_lt_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_lt_route@50:
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    callsub verify_biguint_lt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ne_uint64_route@49:
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    callsub verify_biguint_ne_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ne_route@48:
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    callsub verify_biguint_ne
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_eq_uint64_route@47:
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    callsub verify_biguint_eq_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_eq_route@46:
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    callsub verify_biguint_eq
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_xor_uint64_route@45:
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    callsub verify_biguint_xor_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_xor_route@44:
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    callsub verify_biguint_xor
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_or_uint64_route@43:
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    callsub verify_biguint_or_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_or_route@42:
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    callsub verify_biguint_or
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_and_uint64_route@41:
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    callsub verify_biguint_and_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_and_route@40:
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    callsub verify_biguint_and
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mod_uint64_route@39:
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    callsub verify_biguint_mod_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mod_route@38:
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    callsub verify_biguint_mod
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_div_uint64_route@37:
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    callsub verify_biguint_div_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_div_route@36:
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    callsub verify_biguint_div
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mul_uint64_route@35:
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    callsub verify_biguint_mul_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mul_route@34:
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    callsub verify_biguint_mul
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_sub_uint64_route@33:
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    callsub verify_biguint_sub_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_sub_route@32:
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    callsub verify_biguint_sub
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_add_uint64_route@31:
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    callsub verify_biguint_add_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_add_route@30:
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    callsub verify_biguint_add
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_not_route@29:
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    callsub verify_bytes_not
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_xor_route@28:
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    callsub verify_bytes_xor
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_or_route@27:
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    callsub verify_bytes_or
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_and_route@26:
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    callsub verify_bytes_and
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_ne_route@25:
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    callsub verify_bytes_ne
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_eq_route@24:
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    callsub verify_bytes_eq
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_add_route@23:
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    callsub verify_bytes_add
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_init_route@22:
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    callsub verify_bytes_init
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_ge_route@21:
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    callsub verify_uint64_ge
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_gt_route@20:
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    callsub verify_uint64_gt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_le_route@19:
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    callsub verify_uint64_le
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_lt_route@18:
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    callsub verify_uint64_lt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_ne_route@17:
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    callsub verify_uint64_ne
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_eq_route@16:
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    callsub verify_uint64_eq
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_pow_route@15:
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    callsub verify_uint64_pow
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_rshift_route@14:
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    callsub verify_uint64_rshift
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_lshift_route@13:
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    callsub verify_uint64_lshift
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_not_route@12:
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    callsub verify_uint64_not
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_xor_route@11:
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    callsub verify_uint64_xor
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_or_route@10:
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    callsub verify_uint64_or
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_and_route@9:
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    callsub verify_uint64_and
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_mod_route@8:
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    callsub verify_uint64_mod
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_div_route@7:
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    callsub verify_uint64_div
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_mul_route@6:
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    callsub verify_uint64_mul
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_sub_route@5:
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    callsub verify_uint64_sub
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_add_route@4:
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    callsub verify_uint64_add
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_init_route@3:
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    callsub verify_uint64_init
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@65:
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@69
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_init(raw_value: bytes) -> uint64:
verify_uint64_init:
    // tests/artifacts/PrimitiveOps/contract.py:7-8
    // @arc4.abimethod()
    // def verify_uint64_init(self, raw_value: Bytes) -> UInt64:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:9
    // result = op.btoi(raw_value)
    frame_dig -1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:10
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_add(a: uint64, b: uint64) -> uint64:
verify_uint64_add:
    // tests/artifacts/PrimitiveOps/contract.py:12-13
    // @arc4.abimethod()
    // def verify_uint64_add(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:14
    // result = a + b
    frame_dig -2
    frame_dig -1
    +
    // tests/artifacts/PrimitiveOps/contract.py:15
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_sub(a: uint64, b: uint64) -> uint64:
verify_uint64_sub:
    // tests/artifacts/PrimitiveOps/contract.py:17-18
    // @arc4.abimethod()
    // def verify_uint64_sub(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:19
    // result = a - b
    frame_dig -2
    frame_dig -1
    -
    // tests/artifacts/PrimitiveOps/contract.py:20
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mul(a: uint64, b: uint64) -> uint64:
verify_uint64_mul:
    // tests/artifacts/PrimitiveOps/contract.py:22-23
    // @arc4.abimethod()
    // def verify_uint64_mul(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:24
    // result = a * b
    frame_dig -2
    frame_dig -1
    *
    // tests/artifacts/PrimitiveOps/contract.py:25
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_div(a: uint64, b: uint64) -> uint64:
verify_uint64_div:
    // tests/artifacts/PrimitiveOps/contract.py:27-28
    // @arc4.abimethod()
    // def verify_uint64_div(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:29
    // result = a // b
    frame_dig -2
    frame_dig -1
    /
    // tests/artifacts/PrimitiveOps/contract.py:30
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mod(a: uint64, b: uint64) -> uint64:
verify_uint64_mod:
    // tests/artifacts/PrimitiveOps/contract.py:32-33
    // @arc4.abimethod()
    // def verify_uint64_mod(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:34
    // result = a % b
    frame_dig -2
    frame_dig -1
    %
    // tests/artifacts/PrimitiveOps/contract.py:35
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_and(a: uint64, b: uint64) -> uint64:
verify_uint64_and:
    // tests/artifacts/PrimitiveOps/contract.py:37-38
    // @arc4.abimethod()
    // def verify_uint64_and(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:39
    // result = a & b
    frame_dig -2
    frame_dig -1
    &
    // tests/artifacts/PrimitiveOps/contract.py:40
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_or(a: uint64, b: uint64) -> uint64:
verify_uint64_or:
    // tests/artifacts/PrimitiveOps/contract.py:42-43
    // @arc4.abimethod()
    // def verify_uint64_or(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:44
    // result = a | b
    frame_dig -2
    frame_dig -1
    |
    // tests/artifacts/PrimitiveOps/contract.py:45
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_xor(a: uint64, b: uint64) -> uint64:
verify_uint64_xor:
    // tests/artifacts/PrimitiveOps/contract.py:47-48
    // @arc4.abimethod()
    // def verify_uint64_xor(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:49
    // result = a ^ b
    frame_dig -2
    frame_dig -1
    ^
    // tests/artifacts/PrimitiveOps/contract.py:50
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_not(a: uint64) -> uint64:
verify_uint64_not:
    // tests/artifacts/PrimitiveOps/contract.py:52-53
    // @arc4.abimethod()
    // def verify_uint64_not(self, a: UInt64) -> UInt64:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:54
    // result = ~a
    frame_dig -1
    ~
    // tests/artifacts/PrimitiveOps/contract.py:55
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lshift(a: uint64, b: uint64) -> uint64:
verify_uint64_lshift:
    // tests/artifacts/PrimitiveOps/contract.py:57-58
    // @arc4.abimethod()
    // def verify_uint64_lshift(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:59
    // result = a << b
    frame_dig -2
    frame_dig -1
    shl
    // tests/artifacts/PrimitiveOps/contract.py:60
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_rshift(a: uint64, b: uint64) -> uint64:
verify_uint64_rshift:
    // tests/artifacts/PrimitiveOps/contract.py:62-63
    // @arc4.abimethod()
    // def verify_uint64_rshift(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:64
    // result = a >> b
    frame_dig -2
    frame_dig -1
    shr
    // tests/artifacts/PrimitiveOps/contract.py:65
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_pow(a: uint64, b: uint64) -> uint64:
verify_uint64_pow:
    // tests/artifacts/PrimitiveOps/contract.py:67-68
    // @arc4.abimethod()
    // def verify_uint64_pow(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:69
    // result = a**b
    frame_dig -2
    frame_dig -1
    exp
    // tests/artifacts/PrimitiveOps/contract.py:70
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_eq(a: uint64, b: uint64) -> uint64:
verify_uint64_eq:
    // tests/artifacts/PrimitiveOps/contract.py:72-73
    // @arc4.abimethod()
    // def verify_uint64_eq(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:74
    // result = a == b
    frame_dig -2
    frame_dig -1
    ==
    // tests/artifacts/PrimitiveOps/contract.py:75
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ne(a: uint64, b: uint64) -> uint64:
verify_uint64_ne:
    // tests/artifacts/PrimitiveOps/contract.py:77-78
    // @arc4.abimethod()
    // def verify_uint64_ne(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:79
    // result = a != b
    frame_dig -2
    frame_dig -1
    !=
    // tests/artifacts/PrimitiveOps/contract.py:80
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lt(a: uint64, b: uint64) -> uint64:
verify_uint64_lt:
    // tests/artifacts/PrimitiveOps/contract.py:82-83
    // @arc4.abimethod()
    // def verify_uint64_lt(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:84
    // result = a < b
    frame_dig -2
    frame_dig -1
    <
    // tests/artifacts/PrimitiveOps/contract.py:85
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_le(a: uint64, b: uint64) -> uint64:
verify_uint64_le:
    // tests/artifacts/PrimitiveOps/contract.py:87-88
    // @arc4.abimethod()
    // def verify_uint64_le(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:89
    // result = a <= b
    frame_dig -2
    frame_dig -1
    <=
    // tests/artifacts/PrimitiveOps/contract.py:90
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_gt(a: uint64, b: uint64) -> uint64:
verify_uint64_gt:
    // tests/artifacts/PrimitiveOps/contract.py:92-93
    // @arc4.abimethod()
    // def verify_uint64_gt(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:94
    // result = a > b
    frame_dig -2
    frame_dig -1
    >
    // tests/artifacts/PrimitiveOps/contract.py:95
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ge(a: uint64, b: uint64) -> uint64:
verify_uint64_ge:
    // tests/artifacts/PrimitiveOps/contract.py:97-98
    // @arc4.abimethod()
    // def verify_uint64_ge(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:99
    // result = a >= b
    frame_dig -2
    frame_dig -1
    >=
    // tests/artifacts/PrimitiveOps/contract.py:100
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_init(raw_value: uint64) -> bytes:
verify_bytes_init:
    // tests/artifacts/PrimitiveOps/contract.py:102-103
    // @arc4.abimethod()
    // def verify_bytes_init(self, raw_value: UInt64) -> Bytes:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:104
    // result = op.itob(raw_value)
    frame_dig -1
    itob
    // tests/artifacts/PrimitiveOps/contract.py:105
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_add(a: bytes, b: bytes, pad_a_size: uint64, pad_b_size: uint64) -> bytes:
verify_bytes_add:
    // tests/artifacts/PrimitiveOps/contract.py:107-110
    // @arc4.abimethod()
    // def verify_bytes_add(
    //     self, a: Bytes, b: Bytes, pad_a_size: UInt64, pad_b_size: UInt64
    // ) -> Bytes:
    proto 4 1
    // tests/artifacts/PrimitiveOps/contract.py:111
    // a = op.bzero(pad_a_size) + a
    frame_dig -2
    bzero
    frame_dig -4
    concat
    frame_bury -4
    // tests/artifacts/PrimitiveOps/contract.py:112
    // b = op.bzero(pad_b_size) + b
    frame_dig -1
    bzero
    frame_dig -3
    concat
    frame_bury -3
    // tests/artifacts/PrimitiveOps/contract.py:113
    // result = a + b
    frame_dig -4
    frame_dig -3
    concat
    // tests/artifacts/PrimitiveOps/contract.py:114
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:115
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_eq(a: bytes, b: bytes) -> uint64:
verify_bytes_eq:
    // tests/artifacts/PrimitiveOps/contract.py:117-118
    // @arc4.abimethod()
    // def verify_bytes_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:119
    // result = a == b
    frame_dig -2
    frame_dig -1
    ==
    // tests/artifacts/PrimitiveOps/contract.py:120
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_ne(a: bytes, b: bytes) -> uint64:
verify_bytes_ne:
    // tests/artifacts/PrimitiveOps/contract.py:122-123
    // @arc4.abimethod()
    // def verify_bytes_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:124
    // result = a != b
    frame_dig -2
    frame_dig -1
    !=
    // tests/artifacts/PrimitiveOps/contract.py:125
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_and(a: bytes, b: bytes) -> bytes:
verify_bytes_and:
    // tests/artifacts/PrimitiveOps/contract.py:127-128
    // @arc4.abimethod()
    // def verify_bytes_and(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:129
    // result = a & b
    frame_dig -2
    frame_dig -1
    b&
    // tests/artifacts/PrimitiveOps/contract.py:130
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_or(a: bytes, b: bytes) -> bytes:
verify_bytes_or:
    // tests/artifacts/PrimitiveOps/contract.py:132-133
    // @arc4.abimethod()
    // def verify_bytes_or(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:134
    // result = a | b
    frame_dig -2
    frame_dig -1
    b|
    // tests/artifacts/PrimitiveOps/contract.py:135
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_xor(a: bytes, b: bytes) -> bytes:
verify_bytes_xor:
    // tests/artifacts/PrimitiveOps/contract.py:137-138
    // @arc4.abimethod()
    // def verify_bytes_xor(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:139
    // result = a ^ b
    frame_dig -2
    frame_dig -1
    b^
    // tests/artifacts/PrimitiveOps/contract.py:140
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_not(a: bytes, pad_size: uint64) -> bytes:
verify_bytes_not:
    // tests/artifacts/PrimitiveOps/contract.py:142-143
    // @arc4.abimethod()
    // def verify_bytes_not(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:144
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/PrimitiveOps/contract.py:145
    // result = ~a
    b~
    // tests/artifacts/PrimitiveOps/contract.py:146
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:147
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add(a: bytes, b: bytes) -> bytes:
verify_biguint_add:
    // tests/artifacts/PrimitiveOps/contract.py:149-150
    // @arc4.abimethod()
    // def verify_biguint_add(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:153
    // result = a_biguint + b_biguint
    frame_dig -2
    frame_dig -1
    b+
    // tests/artifacts/PrimitiveOps/contract.py:154
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_add_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:156-157
    // @arc4.abimethod()
    // def verify_biguint_add_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:159
    // result = a_biguint + b
    frame_dig -1
    itob
    frame_dig -2
    b+
    // tests/artifacts/PrimitiveOps/contract.py:160
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub(a: bytes, b: bytes) -> bytes:
verify_biguint_sub:
    // tests/artifacts/PrimitiveOps/contract.py:162-163
    // @arc4.abimethod()
    // def verify_biguint_sub(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:166
    // result = a_biguint - b_biguint
    frame_dig -2
    frame_dig -1
    b-
    // tests/artifacts/PrimitiveOps/contract.py:167
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_sub_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:169-170
    // @arc4.abimethod()
    // def verify_biguint_sub_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:172
    // result = a_biguint - b
    frame_dig -1
    itob
    frame_dig -2
    swap
    b-
    // tests/artifacts/PrimitiveOps/contract.py:173
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul(a: bytes, b: bytes) -> bytes:
verify_biguint_mul:
    // tests/artifacts/PrimitiveOps/contract.py:175-176
    // @arc4.abimethod()
    // def verify_biguint_mul(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:179
    // result = a_biguint * b_biguint
    frame_dig -2
    frame_dig -1
    b*
    // tests/artifacts/PrimitiveOps/contract.py:180
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_mul_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:182-183
    // @arc4.abimethod()
    // def verify_biguint_mul_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:185
    // result = a_biguint * b
    frame_dig -1
    itob
    frame_dig -2
    b*
    // tests/artifacts/PrimitiveOps/contract.py:186
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div(a: bytes, b: bytes) -> bytes:
verify_biguint_div:
    // tests/artifacts/PrimitiveOps/contract.py:188-189
    // @arc4.abimethod()
    // def verify_biguint_div(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:192
    // result = a_biguint // b_biguint
    frame_dig -2
    frame_dig -1
    b/
    // tests/artifacts/PrimitiveOps/contract.py:193
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_div_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:195-196
    // @arc4.abimethod()
    // def verify_biguint_div_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:198
    // result = a_biguint // b
    frame_dig -1
    itob
    frame_dig -2
    swap
    b/
    // tests/artifacts/PrimitiveOps/contract.py:199
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod(a: bytes, b: bytes) -> bytes:
verify_biguint_mod:
    // tests/artifacts/PrimitiveOps/contract.py:201-202
    // @arc4.abimethod()
    // def verify_biguint_mod(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:205
    // result = a_biguint % b_biguint
    frame_dig -2
    frame_dig -1
    b%
    // tests/artifacts/PrimitiveOps/contract.py:206
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_mod_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:208-209
    // @arc4.abimethod()
    // def verify_biguint_mod_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:211
    // result = a_biguint % b
    frame_dig -1
    itob
    frame_dig -2
    swap
    b%
    // tests/artifacts/PrimitiveOps/contract.py:212
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and(a: bytes, b: bytes) -> bytes:
verify_biguint_and:
    // tests/artifacts/PrimitiveOps/contract.py:214-215
    // @arc4.abimethod()
    // def verify_biguint_and(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:218
    // result = a_biguint & b_biguint
    frame_dig -2
    frame_dig -1
    b&
    // tests/artifacts/PrimitiveOps/contract.py:219
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_and_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:221-222
    // @arc4.abimethod()
    // def verify_biguint_and_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:224
    // result = a_biguint & b
    frame_dig -1
    itob
    frame_dig -2
    b&
    // tests/artifacts/PrimitiveOps/contract.py:225
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or(a: bytes, b: bytes) -> bytes:
verify_biguint_or:
    // tests/artifacts/PrimitiveOps/contract.py:227-228
    // @arc4.abimethod()
    // def verify_biguint_or(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:231
    // result = a_biguint | b_biguint
    frame_dig -2
    frame_dig -1
    b|
    // tests/artifacts/PrimitiveOps/contract.py:232
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_or_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:234-235
    // @arc4.abimethod()
    // def verify_biguint_or_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:237
    // result = a_biguint | b
    frame_dig -1
    itob
    frame_dig -2
    b|
    // tests/artifacts/PrimitiveOps/contract.py:238
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor(a: bytes, b: bytes) -> bytes:
verify_biguint_xor:
    // tests/artifacts/PrimitiveOps/contract.py:240-241
    // @arc4.abimethod()
    // def verify_biguint_xor(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:244
    // result = a_biguint ^ b_biguint
    frame_dig -2
    frame_dig -1
    b^
    // tests/artifacts/PrimitiveOps/contract.py:245
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_xor_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:247-248
    // @arc4.abimethod()
    // def verify_biguint_xor_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:250
    // result = a_biguint ^ b
    frame_dig -1
    itob
    frame_dig -2
    b^
    // tests/artifacts/PrimitiveOps/contract.py:251
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq(a: bytes, b: bytes) -> uint64:
verify_biguint_eq:
    // tests/artifacts/PrimitiveOps/contract.py:253-254
    // @arc4.abimethod()
    // def verify_biguint_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:257
    // result = a_biguint == b_biguint
    frame_dig -2
    frame_dig -1
    b==
    // tests/artifacts/PrimitiveOps/contract.py:258
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_eq_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:260-261
    // @arc4.abimethod()
    // def verify_biguint_eq_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:263
    // result = a_biguint == b
    frame_dig -1
    itob
    frame_dig -2
    b==
    // tests/artifacts/PrimitiveOps/contract.py:264
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne(a: bytes, b: bytes) -> uint64:
verify_biguint_ne:
    // tests/artifacts/PrimitiveOps/contract.py:266-267
    // @arc4.abimethod()
    // def verify_biguint_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:270
    // result = a_biguint != b_biguint
    frame_dig -2
    frame_dig -1
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:271
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_ne_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:273-274
    // @arc4.abimethod()
    // def verify_biguint_ne_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:276
    // result = a_biguint != b
    frame_dig -1
    itob
    frame_dig -2
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:277
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt(a: bytes, b: bytes) -> uint64:
verify_biguint_lt:
    // tests/artifacts/PrimitiveOps/contract.py:279-280
    // @arc4.abimethod()
    // def verify_biguint_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:283
    // result = a_biguint < b_biguint
    frame_dig -2
    frame_dig -1
    b<
    // tests/artifacts/PrimitiveOps/contract.py:284
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_lt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:286-287
    // @arc4.abimethod()
    // def verify_biguint_lt_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:289
    // result = a_biguint < b
    frame_dig -1
    itob
    frame_dig -2
    b>
    // tests/artifacts/PrimitiveOps/contract.py:290
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le(a: bytes, b: bytes) -> uint64:
verify_biguint_le:
    // tests/artifacts/PrimitiveOps/contract.py:292-293
    // @arc4.abimethod()
    // def verify_biguint_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:296
    // result = a_biguint <= b_biguint
    frame_dig -2
    frame_dig -1
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:297
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_le_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:299-300
    // @arc4.abimethod()
    // def verify_biguint_le_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:302
    // result = a_biguint <= b
    frame_dig -1
    itob
    frame_dig -2
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:303
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt(a: bytes, b: bytes) -> uint64:
verify_biguint_gt:
    // tests/artifacts/PrimitiveOps/contract.py:305-306
    // @arc4.abimethod()
    // def verify_biguint_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:309
    // result = a_biguint > b_biguint
    frame_dig -2
    frame_dig -1
    b>
    // tests/artifacts/PrimitiveOps/contract.py:310
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_gt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:312-313
    // @arc4.abimethod()
    // def verify_biguint_gt_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:315
    // result = a_biguint > b
    frame_dig -1
    itob
    frame_dig -2
    b<
    // tests/artifacts/PrimitiveOps/contract.py:316
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge(a: bytes, b: bytes) -> uint64:
verify_biguint_ge:
    // tests/artifacts/PrimitiveOps/contract.py:318-319
    // @arc4.abimethod()
    // def verify_biguint_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:322
    // result = a_biguint >= b_biguint
    frame_dig -2
    frame_dig -1
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:323
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_ge_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:325-326
    // @arc4.abimethod()
    // def verify_biguint_ge_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:328
    // result = a_biguint >= b
    frame_dig -1
    itob
    frame_dig -2
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:329
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_init(a: bytes) -> bytes:
verify_string_init:
    // tests/artifacts/PrimitiveOps/contract.py:331-332
    // @arc4.abimethod
    // def verify_string_init(self, a: String) -> String:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:333
    // result = String("Hello, ") + a
    pushbytes "Hello, "
    frame_dig -1
    concat
    // tests/artifacts/PrimitiveOps/contract.py:334
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_startswith(a: bytes, b: bytes) -> uint64:
verify_string_startswith:
    // tests/artifacts/PrimitiveOps/contract.py:336-337
    // @arc4.abimethod
    // def verify_string_startswith(self, a: String, b: String) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    frame_dig -1
    len
    dup
    frame_dig -2
    len
    >
    bz verify_string_startswith_ternary_false@2
    intc_1 // 0

verify_string_startswith_ternary_merge@3:
    // tests/artifacts/PrimitiveOps/contract.py:339
    // return result
    swap
    retsub

verify_string_startswith_ternary_false@2:
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    frame_dig -2
    intc_1 // 0
    frame_dig 0
    extract3
    frame_dig -1
    ==
    b verify_string_startswith_ternary_merge@3


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_endswith(a: bytes, b: bytes) -> uint64:
verify_string_endswith:
    // tests/artifacts/PrimitiveOps/contract.py:341-342
    // @arc4.abimethod
    // def verify_string_endswith(self, a: String, b: String) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    frame_dig -1
    len
    dup
    frame_dig -2
    len
    dup
    cover 2
    >
    bz verify_string_endswith_ternary_false@2
    intc_1 // 0

verify_string_endswith_ternary_merge@3:
    // tests/artifacts/PrimitiveOps/contract.py:344
    // return result
    frame_bury 0
    retsub

verify_string_endswith_ternary_false@2:
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    frame_dig 1
    frame_dig 0
    dup
    cover 2
    -
    frame_dig -2
    swap
    uncover 2
    extract3
    frame_dig -1
    ==
    b verify_string_endswith_ternary_merge@3


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_join(a: bytes, b: bytes) -> bytes:
verify_string_join:
    // tests/artifacts/PrimitiveOps/contract.py:346-347
    // @arc4.abimethod
    // def verify_string_join(self, a: String, b: String) -> String:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:348
    // result = String(", ").join((a, b))
    frame_dig -2
    pushbytes ", "
    concat
    frame_dig -1
    concat
    // tests/artifacts/PrimitiveOps/contract.py:349
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_log(a: bytes, b: uint64, c: bytes, d: bytes, e: bytes, f: bytes, g: bytes, h: bytes, i: bytes, j: bytes, k: bytes, m: bytes, n: bytes) -> void:
verify_log:
    // tests/artifacts/PrimitiveOps/contract.py:351-367
    // @arc4.abimethod
    // def verify_log(  # noqa: PLR0913
    //     self,
    //     a: String,
    //     b: UInt64,
    //     c: Bytes,
    //     d: Bytes,
    //     e: arc4.Bool,
    //     f: arc4.String,
    //     g: arc4.UIntN[typing.Literal[64]],
    //     h: arc4.BigUIntN[typing.Literal[256]],
    //     i: arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]],
    //     j: arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]],
    //     k: Bytes,
    //     m: Bytes,
    //     n: Bytes,
    // ) -> None:
    proto 13 0
    // tests/artifacts/PrimitiveOps/contract.py:372
    // log(a, b, c, d_biguint, e, f, g, h, i, j, arc4_k, arc4_m, arc4_n, sep="-")
    frame_dig -13
    bytec_2 // "-"
    concat
    frame_dig -12
    itob
    concat
    bytec_2 // "-"
    concat
    frame_dig -11
    concat
    bytec_2 // "-"
    concat
    frame_dig -10
    concat
    bytec_2 // "-"
    concat
    frame_dig -9
    concat
    bytec_2 // "-"
    concat
    frame_dig -8
    concat
    bytec_2 // "-"
    concat
    frame_dig -7
    concat
    bytec_2 // "-"
    concat
    frame_dig -6
    concat
    bytec_2 // "-"
    concat
    frame_dig -5
    concat
    bytec_2 // "-"
    concat
    frame_dig -4
    concat
    bytec_2 // "-"
    concat
    frame_dig -3
    concat
    bytec_2 // "-"
    concat
    frame_dig -2
    concat
    bytec_2 // "-"
    concat
    frame_dig -1
    concat
    log
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x00 "-" 0x151f7c750020
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@67
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x725c692b 0x17314559 0x53f34893 0x88c8b269 0xa464b7ab 0x9c8b11b8 0x6f40654e 0xec9a2974 0xc793708f 0x7ddb7499 0xa21c443d 0x6e7fb212 0xb007fcb0 0x2ebc20d4 0xb0954b66 0xdd140aef 0xace474da 0xba694990 0x6db581c0 0x91c8db89 0xdbe77158 0x9a0f22e1 0x64033d37 0x2a7237c5 0xe3a94458 0x42f87f7d 0x2b5542a4 0x9be2fbe9 0x1cd92515 0x64e1705c 0xf1271c50 0x2ab63b70 0x834bb7d2 0x531620d7 0x3fb9e769 0xfa8db0bc 0xa72ea485 0xb7b0ba19 0x74460c42 0xab320738 0x52ad4654 0x10156399 0x0f075957 0xbd843dff 0xb377d381 0x89767265 0x456b4b23 0x33d1b88c 0x6bf973ea 0x67cd6bb2 0x3f58805a 0x1e130039 0x509dc91d 0xa564a202 0x23650763 0xf8c8f8d5 0x23faf7a4 0x7d0afe15 0x48581adf 0xe007c10b // method "verify_uint64_init(byte[])uint64", method "verify_uint64_add(uint64,uint64)uint64", method "verify_uint64_sub(uint64,uint64)uint64", method "verify_uint64_mul(uint64,uint64)uint64", method "verify_uint64_div(uint64,uint64)uint64", method "verify_uint64_mod(uint64,uint64)uint64", method "verify_uint64_and(uint64,uint64)uint64", method "verify_uint64_or(uint64,uint64)uint64", method "verify_uint64_xor(uint64,uint64)uint64", method "verify_uint64_not(uint64)uint64", method "verify_uint64_lshift(uint64,uint64)uint64", method "verify_uint64_rshift(uint64,uint64)uint64", method "verify_uint64_pow(uint64,uint64)uint64", method "verify_uint64_eq(uint64,uint64)bool", method "verify_uint64_ne(uint64,uint64)bool", method "verify_uint64_lt(uint64,uint64)bool", method "verify_uint64_le(uint64,uint64)bool", method "verify_uint64_gt(uint64,uint64)bool", method "verify_uint64_ge(uint64,uint64)bool", method "verify_bytes_init(uint64)byte[]", method "verify_bytes_add(byte[],byte[],uint64,uint64)byte[]", method "verify_bytes_eq(byte[],byte[])bool", method "verify_bytes_ne(byte[],byte[])bool", method "verify_bytes_and(byte[],byte[])byte[]", method "verify_bytes_or(byte[],byte[])byte[]", method "verify_bytes_xor(byte[],byte[])byte[]", method "verify_bytes_not(byte[],uint64)byte[]", method "verify_biguint_add(byte[],byte[])byte[]", method "verify_biguint_add_uint64(byte[],uint64)byte[]", method "verify_biguint_sub(byte[],byte[])byte[]", method "verify_biguint_sub_uint64(byte[],uint64)byte[]", method "verify_biguint_mul(byte[],byte[])byte[]", method "verify_biguint_mul_uint64(byte[],uint64)byte[]", method "verify_biguint_div(byte[],byte[])byte[]", method "verify_biguint_div_uint64(byte[],uint64)byte[]", method "verify_biguint_mod(byte[],byte[])byte[]", method "verify_biguint_mod_uint64(byte[],uint64)byte[]", method "verify_biguint_and(byte[],byte[])byte[]", method "verify_biguint_and_uint64(byte[],uint64)byte[]", method "verify_biguint_or(byte[],byte[])byte[]", method "verify_biguint_or_uint64(byte[],uint64)byte[]", method "verify_biguint_xor(byte[],byte[])byte[]", method "verify_biguint_xor_uint64(byte[],uint64)byte[]", method "verify_biguint_eq(byte[],byte[])bool", method "verify_biguint_eq_uint64(byte[],uint64)bool", method "verify_biguint_ne(byte[],byte[])bool", method "verify_biguint_ne_uint64(byte[],uint64)bool", method "verify_biguint_lt(byte[],byte[])bool", method "verify_biguint_lt_uint64(byte[],uint64)bool", method "verify_biguint_le(byte[],byte[])bool", method "verify_biguint_le_uint64(byte[],uint64)bool", method "verify_biguint_gt(byte[],byte[])bool", method "verify_biguint_gt_uint64(byte[],uint64)bool", method "verify_biguint_ge(byte[],byte[])bool", method "verify_biguint_ge_uint64(byte[],uint64)bool", method "verify_string_init(string)string", method "verify_string_startswith(string,string)bool", method "verify_string_endswith(string,string)bool", method "verify_string_join(string,string)string", method "verify_log(string,uint64,byte[],byte[],bool,string,uint64,uint256,ufixed32x8,ufixed256x16,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match verify_uint64_init verify_uint64_add verify_uint64_sub verify_uint64_mul verify_uint64_div verify_uint64_mod verify_uint64_and verify_uint64_or verify_uint64_xor verify_uint64_not verify_uint64_lshift verify_uint64_rshift verify_uint64_pow verify_uint64_eq verify_uint64_ne verify_uint64_lt verify_uint64_le verify_uint64_gt verify_uint64_ge verify_bytes_init verify_bytes_add verify_bytes_eq verify_bytes_ne verify_bytes_and verify_bytes_or verify_bytes_xor verify_bytes_not verify_biguint_add verify_biguint_add_uint64 verify_biguint_sub verify_biguint_sub_uint64 verify_biguint_mul verify_biguint_mul_uint64 verify_biguint_div verify_biguint_div_uint64 verify_biguint_mod verify_biguint_mod_uint64 verify_biguint_and verify_biguint_and_uint64 verify_biguint_or verify_biguint_or_uint64 verify_biguint_xor verify_biguint_xor_uint64 verify_biguint_eq verify_biguint_eq_uint64 verify_biguint_ne verify_biguint_ne_uint64 verify_biguint_lt verify_biguint_lt_uint64 verify_biguint_le verify_biguint_le_uint64 verify_biguint_gt verify_biguint_gt_uint64 verify_biguint_ge verify_biguint_ge_uint64 verify_string_init verify_string_startswith verify_string_endswith verify_string_join verify_log
    err

main___algopy_default_create@67:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_init[routing]() -> void:
verify_uint64_init:
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:9
    // result = op.btoi(raw_value)
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_add[routing]() -> void:
verify_uint64_add:
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:14
    // result = a + b
    +
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_sub[routing]() -> void:
verify_uint64_sub:
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:19
    // result = a - b
    -
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mul[routing]() -> void:
verify_uint64_mul:
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:24
    // result = a * b
    *
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_div[routing]() -> void:
verify_uint64_div:
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:29
    // result = a // b
    /
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mod[routing]() -> void:
verify_uint64_mod:
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:34
    // result = a % b
    %
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_and[routing]() -> void:
verify_uint64_and:
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:39
    // result = a & b
    &
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_or[routing]() -> void:
verify_uint64_or:
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:44
    // result = a | b
    |
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_xor[routing]() -> void:
verify_uint64_xor:
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:49
    // result = a ^ b
    ^
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_not[routing]() -> void:
verify_uint64_not:
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:54
    // result = ~a
    ~
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lshift[routing]() -> void:
verify_uint64_lshift:
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:59
    // result = a << b
    shl
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_rshift[routing]() -> void:
verify_uint64_rshift:
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:64
    // result = a >> b
    shr
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_pow[routing]() -> void:
verify_uint64_pow:
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:69
    // result = a**b
    exp
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_eq[routing]() -> void:
verify_uint64_eq:
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:74
    // result = a == b
    ==
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ne[routing]() -> void:
verify_uint64_ne:
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:79
    // result = a != b
    !=
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lt[routing]() -> void:
verify_uint64_lt:
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:84
    // result = a < b
    <
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_le[routing]() -> void:
verify_uint64_le:
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:89
    // result = a <= b
    <=
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_gt[routing]() -> void:
verify_uint64_gt:
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:94
    // result = a > b
    >
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ge[routing]() -> void:
verify_uint64_ge:
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:99
    // result = a >= b
    >=
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_init[routing]() -> void:
verify_bytes_init:
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:104
    // result = op.itob(raw_value)
    itob
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    pushbytes 0x151f7c750008
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_add[routing]() -> void:
verify_bytes_add:
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:111
    // a = op.bzero(pad_a_size) + a
    swap
    bzero
    uncover 3
    concat
    // tests/artifacts/PrimitiveOps/contract.py:112
    // b = op.bzero(pad_b_size) + b
    swap
    bzero
    uncover 2
    concat
    // tests/artifacts/PrimitiveOps/contract.py:113
    // result = a + b
    concat
    // tests/artifacts/PrimitiveOps/contract.py:114
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    bytec_3 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_eq[routing]() -> void:
verify_bytes_eq:
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:119
    // result = a == b
    ==
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_ne[routing]() -> void:
verify_bytes_ne:
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:124
    // result = a != b
    !=
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_and[routing]() -> void:
verify_bytes_and:
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:129
    // result = a & b
    b&
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_or[routing]() -> void:
verify_bytes_or:
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:134
    // result = a | b
    b|
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_xor[routing]() -> void:
verify_bytes_xor:
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:139
    // result = a ^ b
    b^
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_not[routing]() -> void:
verify_bytes_not:
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:144
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/PrimitiveOps/contract.py:145
    // result = ~a
    b~
    // tests/artifacts/PrimitiveOps/contract.py:146
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    bytec_3 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add[routing]() -> void:
verify_biguint_add:
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:153
    // result = a_biguint + b_biguint
    b+
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add_uint64[routing]() -> void:
verify_biguint_add_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:159
    // result = a_biguint + b
    itob
    b+
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub[routing]() -> void:
verify_biguint_sub:
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:166
    // result = a_biguint - b_biguint
    b-
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub_uint64[routing]() -> void:
verify_biguint_sub_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:172
    // result = a_biguint - b
    itob
    b-
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul[routing]() -> void:
verify_biguint_mul:
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:179
    // result = a_biguint * b_biguint
    b*
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul_uint64[routing]() -> void:
verify_biguint_mul_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:185
    // result = a_biguint * b
    itob
    b*
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div[routing]() -> void:
verify_biguint_div:
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:192
    // result = a_biguint // b_biguint
    b/
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div_uint64[routing]() -> void:
verify_biguint_div_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:198
    // result = a_biguint // b
    itob
    b/
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod[routing]() -> void:
verify_biguint_mod:
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:205
    // result = a_biguint % b_biguint
    b%
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod_uint64[routing]() -> void:
verify_biguint_mod_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:211
    // result = a_biguint % b
    itob
    b%
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and[routing]() -> void:
verify_biguint_and:
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:218
    // result = a_biguint & b_biguint
    b&
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and_uint64[routing]() -> void:
verify_biguint_and_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:224
    // result = a_biguint & b
    itob
    b&
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or[routing]() -> void:
verify_biguint_or:
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:231
    // result = a_biguint | b_biguint
    b|
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or_uint64[routing]() -> void:
verify_biguint_or_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:237
    // result = a_biguint | b
    itob
    b|
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor[routing]() -> void:
verify_biguint_xor:
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:244
    // result = a_biguint ^ b_biguint
    b^
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor_uint64[routing]() -> void:
verify_biguint_xor_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:250
    // result = a_biguint ^ b
    itob
    b^
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq[routing]() -> void:
verify_biguint_eq:
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:257
    // result = a_biguint == b_biguint
    b==
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq_uint64[routing]() -> void:
verify_biguint_eq_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:263
    // result = a_biguint == b
    itob
    b==
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne[routing]() -> void:
verify_biguint_ne:
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:270
    // result = a_biguint != b_biguint
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne_uint64[routing]() -> void:
verify_biguint_ne_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:276
    // result = a_biguint != b
    itob
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt[routing]() -> void:
verify_biguint_lt:
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:283
    // result = a_biguint < b_biguint
    b<
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt_uint64[routing]() -> void:
verify_biguint_lt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:289
    // result = a_biguint < b
    itob
    b<
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le[routing]() -> void:
verify_biguint_le:
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:296
    // result = a_biguint <= b_biguint
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le_uint64[routing]() -> void:
verify_biguint_le_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:302
    // result = a_biguint <= b
    itob
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt[routing]() -> void:
verify_biguint_gt:
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:309
    // result = a_biguint > b_biguint
    b>
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt_uint64[routing]() -> void:
verify_biguint_gt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:315
    // result = a_biguint > b
    itob
    b>
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge[routing]() -> void:
verify_biguint_ge:
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:322
    // result = a_biguint >= b_biguint
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge_uint64[routing]() -> void:
verify_biguint_ge_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:328
    // result = a_biguint >= b
    itob
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_init[routing]() -> void:
verify_string_init:
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:333
    // result = String("Hello, ") + a
    pushbytes "Hello, "
    swap
    concat
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_startswith[routing]() -> void:
verify_string_startswith:
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    dup
    txna ApplicationArgs 2
    extract 2 0
    dup
    cover 2
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    len
    dup
    uncover 2
    len
    >
    bz verify_string_startswith_ternary_false@3
    intc_1 // 0

verify_string_startswith_ternary_merge@4:
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

verify_string_startswith_ternary_false@3:
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    dig 2
    intc_1 // 0
    dig 2
    extract3
    dig 2
    ==
    b verify_string_startswith_ternary_merge@4


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_endswith[routing]() -> void:
verify_string_endswith:
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    dup
    txna ApplicationArgs 2
    extract 2 0
    dup
    cover 2
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    len
    dup
    uncover 2
    len
    dup
    cover 2
    >
    bz verify_string_endswith_ternary_false@3
    intc_1 // 0

verify_string_endswith_ternary_merge@4:
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

verify_string_endswith_ternary_false@3:
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    dup
    dig 2
    dup
    cover 2
    -
    dig 5
    swap
    uncover 2
    extract3
    dig 3
    ==
    b verify_string_endswith_ternary_merge@4


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_join[routing]() -> void:
verify_string_join:
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:348
    // result = String(", ").join((a, b))
    swap
    pushbytes ", "
    concat
    swap
    concat
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_log[routing]() -> void:
verify_log:
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    extract 2 0
    txna ApplicationArgs 12
    extract 2 0
    txna ApplicationArgs 13
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:372
    // log(a, b, c, d_biguint, e, f, g, h, i, j, arc4_k, arc4_m, arc4_n, sep="-")
    uncover 12
    bytec_2 // "-"
    concat
    uncover 12
    itob
    concat
    bytec_2 // "-"
    concat
    uncover 11
    concat
    bytec_2 // "-"
    concat
    uncover 10
    concat
    bytec_2 // "-"
    concat
    uncover 9
    concat
    bytec_2 // "-"
    concat
    uncover 8
    concat
    bytec_2 // "-"
    concat
    uncover 7
    concat
    bytec_2 // "-"
    concat
    uncover 6
    concat
    bytec_2 // "-"
    concat
    uncover 5
    concat
    bytec_2 // "-"
    concat
    uncover 4
    concat
    bytec_2 // "-"
    concat
    uncover 3
    concat
    bytec_2 // "-"
    concat
    uncover 2
    concat
    bytec_2 // "-"
    concat
    swap
    concat
    log
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc56.json b/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc56.json index 2876a70..c914c90 100644 --- a/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc56.json +++ b/tests/artifacts/PrimitiveOps/data/PrimitiveOpsContract.arc56.json @@ -1577,139 +1577,15 @@ "sourceInfo": [ { "pc": [ - 453, - 523, - 559, - 592, - 625, - 655, - 686, - 719, - 750, - 783, - 814, - 847, - 878, - 911, - 942, - 975, - 1006, - 1039, - 1073, - 1109, - 1143, - 1179, - 1213, - 1249, - 1283, - 1319, - 1353, - 1389, - 1423, - 1459, - 1493, - 1529, - 1563, - 1599, - 1633, - 1669, - 1705, - 1741, - 1774, - 1807, - 1851, - 1879, - 1908, - 1937, - 1966, - 1995, - 2024, - 2053, - 2078, - 2103, - 2128, - 2149, - 2174, - 2199, - 2224, - 2249, - 2274, - 2299, - 2324, - 2349 + 31 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 2377 + 470 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 456, - 526, - 562, - 595, - 628, - 658, - 689, - 722, - 753, - 786, - 817, - 850, - 881, - 914, - 945, - 978, - 1009, - 1042, - 1076, - 1112, - 1146, - 1182, - 1216, - 1252, - 1286, - 1322, - 1356, - 1392, - 1426, - 1462, - 1496, - 1532, - 1566, - 1602, - 1636, - 1672, - 1708, - 1744, - 1777, - 1810, - 1854, - 1882, - 1911, - 1940, - 1969, - 1998, - 2027, - 2056, - 2081, - 2106, - 2131, - 2152, - 2177, - 2202, - 2227, - 2252, - 2277, - 2302, - 2327, - 2352 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" } ], "pcOffsetMethod": "none" @@ -1720,18 +1596,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x00 "-"
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@65
    pushbytess 0x725c692b 0x17314559 0x53f34893 0x88c8b269 0xa464b7ab 0x9c8b11b8 0x6f40654e 0xec9a2974 0xc793708f 0x7ddb7499 0xa21c443d 0x6e7fb212 0xb007fcb0 0x2ebc20d4 0xb0954b66 0xdd140aef 0xace474da 0xba694990 0x6db581c0 0x91c8db89 0xdbe77158 0x9a0f22e1 0x64033d37 0x2a7237c5 0xe3a94458 0x42f87f7d 0x2b5542a4 0x9be2fbe9 0x1cd92515 0x64e1705c 0xf1271c50 0x2ab63b70 0x834bb7d2 0x531620d7 0x3fb9e769 0xfa8db0bc 0xa72ea485 0xb7b0ba19 0x74460c42 0xab320738 0x52ad4654 0x10156399 0x0f075957 0xbd843dff 0xb377d381 0x89767265 0x456b4b23 0x33d1b88c 0x6bf973ea 0x67cd6bb2 0x3f58805a 0x1e130039 0x509dc91d 0xa564a202 0x23650763 0xf8c8f8d5 0x23faf7a4 0x7d0afe15 0x48581adf 0xe007c10b // method "verify_uint64_init(byte[])uint64", method "verify_uint64_add(uint64,uint64)uint64", method "verify_uint64_sub(uint64,uint64)uint64", method "verify_uint64_mul(uint64,uint64)uint64", method "verify_uint64_div(uint64,uint64)uint64", method "verify_uint64_mod(uint64,uint64)uint64", method "verify_uint64_and(uint64,uint64)uint64", method "verify_uint64_or(uint64,uint64)uint64", method "verify_uint64_xor(uint64,uint64)uint64", method "verify_uint64_not(uint64)uint64", method "verify_uint64_lshift(uint64,uint64)uint64", method "verify_uint64_rshift(uint64,uint64)uint64", method "verify_uint64_pow(uint64,uint64)uint64", method "verify_uint64_eq(uint64,uint64)bool", method "verify_uint64_ne(uint64,uint64)bool", method "verify_uint64_lt(uint64,uint64)bool", method "verify_uint64_le(uint64,uint64)bool", method "verify_uint64_gt(uint64,uint64)bool", method "verify_uint64_ge(uint64,uint64)bool", method "verify_bytes_init(uint64)byte[]", method "verify_bytes_add(byte[],byte[],uint64,uint64)byte[]", method "verify_bytes_eq(byte[],byte[])bool", method "verify_bytes_ne(byte[],byte[])bool", method "verify_bytes_and(byte[],byte[])byte[]", method "verify_bytes_or(byte[],byte[])byte[]", method "verify_bytes_xor(byte[],byte[])byte[]", method "verify_bytes_not(byte[],uint64)byte[]", method "verify_biguint_add(byte[],byte[])byte[]", method "verify_biguint_add_uint64(byte[],uint64)byte[]", method "verify_biguint_sub(byte[],byte[])byte[]", method "verify_biguint_sub_uint64(byte[],uint64)byte[]", method "verify_biguint_mul(byte[],byte[])byte[]", method "verify_biguint_mul_uint64(byte[],uint64)byte[]", method "verify_biguint_div(byte[],byte[])byte[]", method "verify_biguint_div_uint64(byte[],uint64)byte[]", method "verify_biguint_mod(byte[],byte[])byte[]", method "verify_biguint_mod_uint64(byte[],uint64)byte[]", method "verify_biguint_and(byte[],byte[])byte[]", method "verify_biguint_and_uint64(byte[],uint64)byte[]", method "verify_biguint_or(byte[],byte[])byte[]", method "verify_biguint_or_uint64(byte[],uint64)byte[]", method "verify_biguint_xor(byte[],byte[])byte[]", method "verify_biguint_xor_uint64(byte[],uint64)byte[]", method "verify_biguint_eq(byte[],byte[])bool", method "verify_biguint_eq_uint64(byte[],uint64)bool", method "verify_biguint_ne(byte[],byte[])bool", method "verify_biguint_ne_uint64(byte[],uint64)bool", method "verify_biguint_lt(byte[],byte[])bool", method "verify_biguint_lt_uint64(byte[],uint64)bool", method "verify_biguint_le(byte[],byte[])bool", method "verify_biguint_le_uint64(byte[],uint64)bool", method "verify_biguint_gt(byte[],byte[])bool", method "verify_biguint_gt_uint64(byte[],uint64)bool", method "verify_biguint_ge(byte[],byte[])bool", method "verify_biguint_ge_uint64(byte[],uint64)bool", method "verify_string_init(string)string", method "verify_string_startswith(string,string)bool", method "verify_string_endswith(string,string)bool", method "verify_string_join(string,string)string", method "verify_log(string,uint64,byte[],byte[],bool,string,uint64,uint256,ufixed32x8,ufixed256x16,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match main_verify_uint64_init_route@3 main_verify_uint64_add_route@4 main_verify_uint64_sub_route@5 main_verify_uint64_mul_route@6 main_verify_uint64_div_route@7 main_verify_uint64_mod_route@8 main_verify_uint64_and_route@9 main_verify_uint64_or_route@10 main_verify_uint64_xor_route@11 main_verify_uint64_not_route@12 main_verify_uint64_lshift_route@13 main_verify_uint64_rshift_route@14 main_verify_uint64_pow_route@15 main_verify_uint64_eq_route@16 main_verify_uint64_ne_route@17 main_verify_uint64_lt_route@18 main_verify_uint64_le_route@19 main_verify_uint64_gt_route@20 main_verify_uint64_ge_route@21 main_verify_bytes_init_route@22 main_verify_bytes_add_route@23 main_verify_bytes_eq_route@24 main_verify_bytes_ne_route@25 main_verify_bytes_and_route@26 main_verify_bytes_or_route@27 main_verify_bytes_xor_route@28 main_verify_bytes_not_route@29 main_verify_biguint_add_route@30 main_verify_biguint_add_uint64_route@31 main_verify_biguint_sub_route@32 main_verify_biguint_sub_uint64_route@33 main_verify_biguint_mul_route@34 main_verify_biguint_mul_uint64_route@35 main_verify_biguint_div_route@36 main_verify_biguint_div_uint64_route@37 main_verify_biguint_mod_route@38 main_verify_biguint_mod_uint64_route@39 main_verify_biguint_and_route@40 main_verify_biguint_and_uint64_route@41 main_verify_biguint_or_route@42 main_verify_biguint_or_uint64_route@43 main_verify_biguint_xor_route@44 main_verify_biguint_xor_uint64_route@45 main_verify_biguint_eq_route@46 main_verify_biguint_eq_uint64_route@47 main_verify_biguint_ne_route@48 main_verify_biguint_ne_uint64_route@49 main_verify_biguint_lt_route@50 main_verify_biguint_lt_uint64_route@51 main_verify_biguint_le_route@52 main_verify_biguint_le_uint64_route@53 main_verify_biguint_gt_route@54 main_verify_biguint_gt_uint64_route@55 main_verify_biguint_ge_route@56 main_verify_biguint_ge_uint64_route@57 main_verify_string_init_route@58 main_verify_string_startswith_route@59 main_verify_string_endswith_route@60 main_verify_string_join_route@61 main_verify_log_route@62

main_after_if_else@69:
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_log_route@62:
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    extract 2 0
    txna ApplicationArgs 12
    extract 2 0
    txna ApplicationArgs 13
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    callsub verify_log
    intc_0 // 1
    return

main_verify_string_join_route@61:
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    callsub verify_string_join
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_endswith_route@60:
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    callsub verify_string_endswith
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_startswith_route@59:
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    callsub verify_string_startswith
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_string_init_route@58:
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    callsub verify_string_init
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ge_uint64_route@57:
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    callsub verify_biguint_ge_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ge_route@56:
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    callsub verify_biguint_ge
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_gt_uint64_route@55:
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    callsub verify_biguint_gt_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_gt_route@54:
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    callsub verify_biguint_gt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_le_uint64_route@53:
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    callsub verify_biguint_le_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_le_route@52:
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    callsub verify_biguint_le
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_lt_uint64_route@51:
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    callsub verify_biguint_lt_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_lt_route@50:
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    callsub verify_biguint_lt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ne_uint64_route@49:
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    callsub verify_biguint_ne_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_ne_route@48:
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    callsub verify_biguint_ne
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_eq_uint64_route@47:
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    callsub verify_biguint_eq_uint64
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_eq_route@46:
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    callsub verify_biguint_eq
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_xor_uint64_route@45:
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    callsub verify_biguint_xor_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_xor_route@44:
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    callsub verify_biguint_xor
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_or_uint64_route@43:
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    callsub verify_biguint_or_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_or_route@42:
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    callsub verify_biguint_or
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_and_uint64_route@41:
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    callsub verify_biguint_and_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_and_route@40:
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    callsub verify_biguint_and
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mod_uint64_route@39:
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    callsub verify_biguint_mod_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mod_route@38:
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    callsub verify_biguint_mod
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_div_uint64_route@37:
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    callsub verify_biguint_div_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_div_route@36:
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    callsub verify_biguint_div
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mul_uint64_route@35:
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    callsub verify_biguint_mul_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_mul_route@34:
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    callsub verify_biguint_mul
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_sub_uint64_route@33:
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    callsub verify_biguint_sub_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_sub_route@32:
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    callsub verify_biguint_sub
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_add_uint64_route@31:
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    callsub verify_biguint_add_uint64
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_biguint_add_route@30:
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    callsub verify_biguint_add
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_not_route@29:
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    callsub verify_bytes_not
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_xor_route@28:
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    callsub verify_bytes_xor
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_or_route@27:
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    callsub verify_bytes_or
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_and_route@26:
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    callsub verify_bytes_and
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_ne_route@25:
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    callsub verify_bytes_ne
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_eq_route@24:
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    callsub verify_bytes_eq
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_add_route@23:
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    callsub verify_bytes_add
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_bytes_init_route@22:
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    callsub verify_bytes_init
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_ge_route@21:
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    callsub verify_uint64_ge
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_gt_route@20:
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    callsub verify_uint64_gt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_le_route@19:
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    callsub verify_uint64_le
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_lt_route@18:
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    callsub verify_uint64_lt
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_ne_route@17:
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    callsub verify_uint64_ne
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_eq_route@16:
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    callsub verify_uint64_eq
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_pow_route@15:
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    callsub verify_uint64_pow
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_rshift_route@14:
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    callsub verify_uint64_rshift
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_lshift_route@13:
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    callsub verify_uint64_lshift
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_not_route@12:
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    callsub verify_uint64_not
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_xor_route@11:
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    callsub verify_uint64_xor
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_or_route@10:
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    callsub verify_uint64_or
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_and_route@9:
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    callsub verify_uint64_and
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_mod_route@8:
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    callsub verify_uint64_mod
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_div_route@7:
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    callsub verify_uint64_div
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_mul_route@6:
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    callsub verify_uint64_mul
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_sub_route@5:
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    callsub verify_uint64_sub
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_add_route@4:
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    callsub verify_uint64_add
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_uint64_init_route@3:
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    callsub verify_uint64_init
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@65:
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@69
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_init(raw_value: bytes) -> uint64:
verify_uint64_init:
    // tests/artifacts/PrimitiveOps/contract.py:7-8
    // @arc4.abimethod()
    // def verify_uint64_init(self, raw_value: Bytes) -> UInt64:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:9
    // result = op.btoi(raw_value)
    frame_dig -1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:10
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_add(a: uint64, b: uint64) -> uint64:
verify_uint64_add:
    // tests/artifacts/PrimitiveOps/contract.py:12-13
    // @arc4.abimethod()
    // def verify_uint64_add(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:14
    // result = a + b
    frame_dig -2
    frame_dig -1
    +
    // tests/artifacts/PrimitiveOps/contract.py:15
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_sub(a: uint64, b: uint64) -> uint64:
verify_uint64_sub:
    // tests/artifacts/PrimitiveOps/contract.py:17-18
    // @arc4.abimethod()
    // def verify_uint64_sub(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:19
    // result = a - b
    frame_dig -2
    frame_dig -1
    -
    // tests/artifacts/PrimitiveOps/contract.py:20
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mul(a: uint64, b: uint64) -> uint64:
verify_uint64_mul:
    // tests/artifacts/PrimitiveOps/contract.py:22-23
    // @arc4.abimethod()
    // def verify_uint64_mul(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:24
    // result = a * b
    frame_dig -2
    frame_dig -1
    *
    // tests/artifacts/PrimitiveOps/contract.py:25
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_div(a: uint64, b: uint64) -> uint64:
verify_uint64_div:
    // tests/artifacts/PrimitiveOps/contract.py:27-28
    // @arc4.abimethod()
    // def verify_uint64_div(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:29
    // result = a // b
    frame_dig -2
    frame_dig -1
    /
    // tests/artifacts/PrimitiveOps/contract.py:30
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mod(a: uint64, b: uint64) -> uint64:
verify_uint64_mod:
    // tests/artifacts/PrimitiveOps/contract.py:32-33
    // @arc4.abimethod()
    // def verify_uint64_mod(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:34
    // result = a % b
    frame_dig -2
    frame_dig -1
    %
    // tests/artifacts/PrimitiveOps/contract.py:35
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_and(a: uint64, b: uint64) -> uint64:
verify_uint64_and:
    // tests/artifacts/PrimitiveOps/contract.py:37-38
    // @arc4.abimethod()
    // def verify_uint64_and(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:39
    // result = a & b
    frame_dig -2
    frame_dig -1
    &
    // tests/artifacts/PrimitiveOps/contract.py:40
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_or(a: uint64, b: uint64) -> uint64:
verify_uint64_or:
    // tests/artifacts/PrimitiveOps/contract.py:42-43
    // @arc4.abimethod()
    // def verify_uint64_or(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:44
    // result = a | b
    frame_dig -2
    frame_dig -1
    |
    // tests/artifacts/PrimitiveOps/contract.py:45
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_xor(a: uint64, b: uint64) -> uint64:
verify_uint64_xor:
    // tests/artifacts/PrimitiveOps/contract.py:47-48
    // @arc4.abimethod()
    // def verify_uint64_xor(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:49
    // result = a ^ b
    frame_dig -2
    frame_dig -1
    ^
    // tests/artifacts/PrimitiveOps/contract.py:50
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_not(a: uint64) -> uint64:
verify_uint64_not:
    // tests/artifacts/PrimitiveOps/contract.py:52-53
    // @arc4.abimethod()
    // def verify_uint64_not(self, a: UInt64) -> UInt64:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:54
    // result = ~a
    frame_dig -1
    ~
    // tests/artifacts/PrimitiveOps/contract.py:55
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lshift(a: uint64, b: uint64) -> uint64:
verify_uint64_lshift:
    // tests/artifacts/PrimitiveOps/contract.py:57-58
    // @arc4.abimethod()
    // def verify_uint64_lshift(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:59
    // result = a << b
    frame_dig -2
    frame_dig -1
    shl
    // tests/artifacts/PrimitiveOps/contract.py:60
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_rshift(a: uint64, b: uint64) -> uint64:
verify_uint64_rshift:
    // tests/artifacts/PrimitiveOps/contract.py:62-63
    // @arc4.abimethod()
    // def verify_uint64_rshift(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:64
    // result = a >> b
    frame_dig -2
    frame_dig -1
    shr
    // tests/artifacts/PrimitiveOps/contract.py:65
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_pow(a: uint64, b: uint64) -> uint64:
verify_uint64_pow:
    // tests/artifacts/PrimitiveOps/contract.py:67-68
    // @arc4.abimethod()
    // def verify_uint64_pow(self, a: UInt64, b: UInt64) -> UInt64:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:69
    // result = a**b
    frame_dig -2
    frame_dig -1
    exp
    // tests/artifacts/PrimitiveOps/contract.py:70
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_eq(a: uint64, b: uint64) -> uint64:
verify_uint64_eq:
    // tests/artifacts/PrimitiveOps/contract.py:72-73
    // @arc4.abimethod()
    // def verify_uint64_eq(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:74
    // result = a == b
    frame_dig -2
    frame_dig -1
    ==
    // tests/artifacts/PrimitiveOps/contract.py:75
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ne(a: uint64, b: uint64) -> uint64:
verify_uint64_ne:
    // tests/artifacts/PrimitiveOps/contract.py:77-78
    // @arc4.abimethod()
    // def verify_uint64_ne(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:79
    // result = a != b
    frame_dig -2
    frame_dig -1
    !=
    // tests/artifacts/PrimitiveOps/contract.py:80
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lt(a: uint64, b: uint64) -> uint64:
verify_uint64_lt:
    // tests/artifacts/PrimitiveOps/contract.py:82-83
    // @arc4.abimethod()
    // def verify_uint64_lt(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:84
    // result = a < b
    frame_dig -2
    frame_dig -1
    <
    // tests/artifacts/PrimitiveOps/contract.py:85
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_le(a: uint64, b: uint64) -> uint64:
verify_uint64_le:
    // tests/artifacts/PrimitiveOps/contract.py:87-88
    // @arc4.abimethod()
    // def verify_uint64_le(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:89
    // result = a <= b
    frame_dig -2
    frame_dig -1
    <=
    // tests/artifacts/PrimitiveOps/contract.py:90
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_gt(a: uint64, b: uint64) -> uint64:
verify_uint64_gt:
    // tests/artifacts/PrimitiveOps/contract.py:92-93
    // @arc4.abimethod()
    // def verify_uint64_gt(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:94
    // result = a > b
    frame_dig -2
    frame_dig -1
    >
    // tests/artifacts/PrimitiveOps/contract.py:95
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ge(a: uint64, b: uint64) -> uint64:
verify_uint64_ge:
    // tests/artifacts/PrimitiveOps/contract.py:97-98
    // @arc4.abimethod()
    // def verify_uint64_ge(self, a: UInt64, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:99
    // result = a >= b
    frame_dig -2
    frame_dig -1
    >=
    // tests/artifacts/PrimitiveOps/contract.py:100
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_init(raw_value: uint64) -> bytes:
verify_bytes_init:
    // tests/artifacts/PrimitiveOps/contract.py:102-103
    // @arc4.abimethod()
    // def verify_bytes_init(self, raw_value: UInt64) -> Bytes:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:104
    // result = op.itob(raw_value)
    frame_dig -1
    itob
    // tests/artifacts/PrimitiveOps/contract.py:105
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_add(a: bytes, b: bytes, pad_a_size: uint64, pad_b_size: uint64) -> bytes:
verify_bytes_add:
    // tests/artifacts/PrimitiveOps/contract.py:107-110
    // @arc4.abimethod()
    // def verify_bytes_add(
    //     self, a: Bytes, b: Bytes, pad_a_size: UInt64, pad_b_size: UInt64
    // ) -> Bytes:
    proto 4 1
    // tests/artifacts/PrimitiveOps/contract.py:111
    // a = op.bzero(pad_a_size) + a
    frame_dig -2
    bzero
    frame_dig -4
    concat
    frame_bury -4
    // tests/artifacts/PrimitiveOps/contract.py:112
    // b = op.bzero(pad_b_size) + b
    frame_dig -1
    bzero
    frame_dig -3
    concat
    frame_bury -3
    // tests/artifacts/PrimitiveOps/contract.py:113
    // result = a + b
    frame_dig -4
    frame_dig -3
    concat
    // tests/artifacts/PrimitiveOps/contract.py:114
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:115
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_eq(a: bytes, b: bytes) -> uint64:
verify_bytes_eq:
    // tests/artifacts/PrimitiveOps/contract.py:117-118
    // @arc4.abimethod()
    // def verify_bytes_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:119
    // result = a == b
    frame_dig -2
    frame_dig -1
    ==
    // tests/artifacts/PrimitiveOps/contract.py:120
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_ne(a: bytes, b: bytes) -> uint64:
verify_bytes_ne:
    // tests/artifacts/PrimitiveOps/contract.py:122-123
    // @arc4.abimethod()
    // def verify_bytes_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:124
    // result = a != b
    frame_dig -2
    frame_dig -1
    !=
    // tests/artifacts/PrimitiveOps/contract.py:125
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_and(a: bytes, b: bytes) -> bytes:
verify_bytes_and:
    // tests/artifacts/PrimitiveOps/contract.py:127-128
    // @arc4.abimethod()
    // def verify_bytes_and(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:129
    // result = a & b
    frame_dig -2
    frame_dig -1
    b&
    // tests/artifacts/PrimitiveOps/contract.py:130
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_or(a: bytes, b: bytes) -> bytes:
verify_bytes_or:
    // tests/artifacts/PrimitiveOps/contract.py:132-133
    // @arc4.abimethod()
    // def verify_bytes_or(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:134
    // result = a | b
    frame_dig -2
    frame_dig -1
    b|
    // tests/artifacts/PrimitiveOps/contract.py:135
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_xor(a: bytes, b: bytes) -> bytes:
verify_bytes_xor:
    // tests/artifacts/PrimitiveOps/contract.py:137-138
    // @arc4.abimethod()
    // def verify_bytes_xor(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:139
    // result = a ^ b
    frame_dig -2
    frame_dig -1
    b^
    // tests/artifacts/PrimitiveOps/contract.py:140
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_not(a: bytes, pad_size: uint64) -> bytes:
verify_bytes_not:
    // tests/artifacts/PrimitiveOps/contract.py:142-143
    // @arc4.abimethod()
    // def verify_bytes_not(self, a: Bytes, pad_size: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:144
    // a = op.bzero(pad_size) + a
    frame_dig -1
    bzero
    frame_dig -2
    concat
    dup
    frame_bury -2
    // tests/artifacts/PrimitiveOps/contract.py:145
    // result = ~a
    b~
    // tests/artifacts/PrimitiveOps/contract.py:146
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:147
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add(a: bytes, b: bytes) -> bytes:
verify_biguint_add:
    // tests/artifacts/PrimitiveOps/contract.py:149-150
    // @arc4.abimethod()
    // def verify_biguint_add(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:153
    // result = a_biguint + b_biguint
    frame_dig -2
    frame_dig -1
    b+
    // tests/artifacts/PrimitiveOps/contract.py:154
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_add_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:156-157
    // @arc4.abimethod()
    // def verify_biguint_add_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:159
    // result = a_biguint + b
    frame_dig -1
    itob
    frame_dig -2
    b+
    // tests/artifacts/PrimitiveOps/contract.py:160
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub(a: bytes, b: bytes) -> bytes:
verify_biguint_sub:
    // tests/artifacts/PrimitiveOps/contract.py:162-163
    // @arc4.abimethod()
    // def verify_biguint_sub(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:166
    // result = a_biguint - b_biguint
    frame_dig -2
    frame_dig -1
    b-
    // tests/artifacts/PrimitiveOps/contract.py:167
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_sub_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:169-170
    // @arc4.abimethod()
    // def verify_biguint_sub_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:172
    // result = a_biguint - b
    frame_dig -1
    itob
    frame_dig -2
    swap
    b-
    // tests/artifacts/PrimitiveOps/contract.py:173
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul(a: bytes, b: bytes) -> bytes:
verify_biguint_mul:
    // tests/artifacts/PrimitiveOps/contract.py:175-176
    // @arc4.abimethod()
    // def verify_biguint_mul(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:179
    // result = a_biguint * b_biguint
    frame_dig -2
    frame_dig -1
    b*
    // tests/artifacts/PrimitiveOps/contract.py:180
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_mul_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:182-183
    // @arc4.abimethod()
    // def verify_biguint_mul_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:185
    // result = a_biguint * b
    frame_dig -1
    itob
    frame_dig -2
    b*
    // tests/artifacts/PrimitiveOps/contract.py:186
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div(a: bytes, b: bytes) -> bytes:
verify_biguint_div:
    // tests/artifacts/PrimitiveOps/contract.py:188-189
    // @arc4.abimethod()
    // def verify_biguint_div(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:192
    // result = a_biguint // b_biguint
    frame_dig -2
    frame_dig -1
    b/
    // tests/artifacts/PrimitiveOps/contract.py:193
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_div_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:195-196
    // @arc4.abimethod()
    // def verify_biguint_div_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:198
    // result = a_biguint // b
    frame_dig -1
    itob
    frame_dig -2
    swap
    b/
    // tests/artifacts/PrimitiveOps/contract.py:199
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod(a: bytes, b: bytes) -> bytes:
verify_biguint_mod:
    // tests/artifacts/PrimitiveOps/contract.py:201-202
    // @arc4.abimethod()
    // def verify_biguint_mod(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:205
    // result = a_biguint % b_biguint
    frame_dig -2
    frame_dig -1
    b%
    // tests/artifacts/PrimitiveOps/contract.py:206
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_mod_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:208-209
    // @arc4.abimethod()
    // def verify_biguint_mod_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:211
    // result = a_biguint % b
    frame_dig -1
    itob
    frame_dig -2
    swap
    b%
    // tests/artifacts/PrimitiveOps/contract.py:212
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and(a: bytes, b: bytes) -> bytes:
verify_biguint_and:
    // tests/artifacts/PrimitiveOps/contract.py:214-215
    // @arc4.abimethod()
    // def verify_biguint_and(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:218
    // result = a_biguint & b_biguint
    frame_dig -2
    frame_dig -1
    b&
    // tests/artifacts/PrimitiveOps/contract.py:219
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_and_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:221-222
    // @arc4.abimethod()
    // def verify_biguint_and_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:224
    // result = a_biguint & b
    frame_dig -1
    itob
    frame_dig -2
    b&
    // tests/artifacts/PrimitiveOps/contract.py:225
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or(a: bytes, b: bytes) -> bytes:
verify_biguint_or:
    // tests/artifacts/PrimitiveOps/contract.py:227-228
    // @arc4.abimethod()
    // def verify_biguint_or(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:231
    // result = a_biguint | b_biguint
    frame_dig -2
    frame_dig -1
    b|
    // tests/artifacts/PrimitiveOps/contract.py:232
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_or_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:234-235
    // @arc4.abimethod()
    // def verify_biguint_or_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:237
    // result = a_biguint | b
    frame_dig -1
    itob
    frame_dig -2
    b|
    // tests/artifacts/PrimitiveOps/contract.py:238
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor(a: bytes, b: bytes) -> bytes:
verify_biguint_xor:
    // tests/artifacts/PrimitiveOps/contract.py:240-241
    // @arc4.abimethod()
    // def verify_biguint_xor(self, a: Bytes, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:244
    // result = a_biguint ^ b_biguint
    frame_dig -2
    frame_dig -1
    b^
    // tests/artifacts/PrimitiveOps/contract.py:245
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor_uint64(a: bytes, b: uint64) -> bytes:
verify_biguint_xor_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:247-248
    // @arc4.abimethod()
    // def verify_biguint_xor_uint64(self, a: Bytes, b: UInt64) -> Bytes:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:250
    // result = a_biguint ^ b
    frame_dig -1
    itob
    frame_dig -2
    b^
    // tests/artifacts/PrimitiveOps/contract.py:251
    // return result.bytes
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq(a: bytes, b: bytes) -> uint64:
verify_biguint_eq:
    // tests/artifacts/PrimitiveOps/contract.py:253-254
    // @arc4.abimethod()
    // def verify_biguint_eq(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:257
    // result = a_biguint == b_biguint
    frame_dig -2
    frame_dig -1
    b==
    // tests/artifacts/PrimitiveOps/contract.py:258
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_eq_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:260-261
    // @arc4.abimethod()
    // def verify_biguint_eq_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:263
    // result = a_biguint == b
    frame_dig -1
    itob
    frame_dig -2
    b==
    // tests/artifacts/PrimitiveOps/contract.py:264
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne(a: bytes, b: bytes) -> uint64:
verify_biguint_ne:
    // tests/artifacts/PrimitiveOps/contract.py:266-267
    // @arc4.abimethod()
    // def verify_biguint_ne(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:270
    // result = a_biguint != b_biguint
    frame_dig -2
    frame_dig -1
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:271
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_ne_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:273-274
    // @arc4.abimethod()
    // def verify_biguint_ne_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:276
    // result = a_biguint != b
    frame_dig -1
    itob
    frame_dig -2
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:277
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt(a: bytes, b: bytes) -> uint64:
verify_biguint_lt:
    // tests/artifacts/PrimitiveOps/contract.py:279-280
    // @arc4.abimethod()
    // def verify_biguint_lt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:283
    // result = a_biguint < b_biguint
    frame_dig -2
    frame_dig -1
    b<
    // tests/artifacts/PrimitiveOps/contract.py:284
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_lt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:286-287
    // @arc4.abimethod()
    // def verify_biguint_lt_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:289
    // result = a_biguint < b
    frame_dig -1
    itob
    frame_dig -2
    b>
    // tests/artifacts/PrimitiveOps/contract.py:290
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le(a: bytes, b: bytes) -> uint64:
verify_biguint_le:
    // tests/artifacts/PrimitiveOps/contract.py:292-293
    // @arc4.abimethod()
    // def verify_biguint_le(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:296
    // result = a_biguint <= b_biguint
    frame_dig -2
    frame_dig -1
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:297
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_le_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:299-300
    // @arc4.abimethod()
    // def verify_biguint_le_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:302
    // result = a_biguint <= b
    frame_dig -1
    itob
    frame_dig -2
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:303
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt(a: bytes, b: bytes) -> uint64:
verify_biguint_gt:
    // tests/artifacts/PrimitiveOps/contract.py:305-306
    // @arc4.abimethod()
    // def verify_biguint_gt(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:309
    // result = a_biguint > b_biguint
    frame_dig -2
    frame_dig -1
    b>
    // tests/artifacts/PrimitiveOps/contract.py:310
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_gt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:312-313
    // @arc4.abimethod()
    // def verify_biguint_gt_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:315
    // result = a_biguint > b
    frame_dig -1
    itob
    frame_dig -2
    b<
    // tests/artifacts/PrimitiveOps/contract.py:316
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge(a: bytes, b: bytes) -> uint64:
verify_biguint_ge:
    // tests/artifacts/PrimitiveOps/contract.py:318-319
    // @arc4.abimethod()
    // def verify_biguint_ge(self, a: Bytes, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:322
    // result = a_biguint >= b_biguint
    frame_dig -2
    frame_dig -1
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:323
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge_uint64(a: bytes, b: uint64) -> uint64:
verify_biguint_ge_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:325-326
    // @arc4.abimethod()
    // def verify_biguint_ge_uint64(self, a: Bytes, b: UInt64) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:328
    // result = a_biguint >= b
    frame_dig -1
    itob
    frame_dig -2
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:329
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_init(a: bytes) -> bytes:
verify_string_init:
    // tests/artifacts/PrimitiveOps/contract.py:331-332
    // @arc4.abimethod
    // def verify_string_init(self, a: String) -> String:
    proto 1 1
    // tests/artifacts/PrimitiveOps/contract.py:333
    // result = String("Hello, ") + a
    pushbytes "Hello, "
    frame_dig -1
    concat
    // tests/artifacts/PrimitiveOps/contract.py:334
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_startswith(a: bytes, b: bytes) -> uint64:
verify_string_startswith:
    // tests/artifacts/PrimitiveOps/contract.py:336-337
    // @arc4.abimethod
    // def verify_string_startswith(self, a: String, b: String) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    frame_dig -1
    len
    dup
    frame_dig -2
    len
    >
    bz verify_string_startswith_ternary_false@2
    intc_1 // 0

verify_string_startswith_ternary_merge@3:
    // tests/artifacts/PrimitiveOps/contract.py:339
    // return result
    swap
    retsub

verify_string_startswith_ternary_false@2:
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    frame_dig -2
    intc_1 // 0
    frame_dig 0
    extract3
    frame_dig -1
    ==
    b verify_string_startswith_ternary_merge@3


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_endswith(a: bytes, b: bytes) -> uint64:
verify_string_endswith:
    // tests/artifacts/PrimitiveOps/contract.py:341-342
    // @arc4.abimethod
    // def verify_string_endswith(self, a: String, b: String) -> bool:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    frame_dig -1
    len
    dup
    frame_dig -2
    len
    dup
    cover 2
    >
    bz verify_string_endswith_ternary_false@2
    intc_1 // 0

verify_string_endswith_ternary_merge@3:
    // tests/artifacts/PrimitiveOps/contract.py:344
    // return result
    frame_bury 0
    retsub

verify_string_endswith_ternary_false@2:
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    frame_dig 1
    frame_dig 0
    dup
    cover 2
    -
    frame_dig -2
    swap
    uncover 2
    extract3
    frame_dig -1
    ==
    b verify_string_endswith_ternary_merge@3


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_join(a: bytes, b: bytes) -> bytes:
verify_string_join:
    // tests/artifacts/PrimitiveOps/contract.py:346-347
    // @arc4.abimethod
    // def verify_string_join(self, a: String, b: String) -> String:
    proto 2 1
    // tests/artifacts/PrimitiveOps/contract.py:348
    // result = String(", ").join((a, b))
    frame_dig -2
    pushbytes ", "
    concat
    frame_dig -1
    concat
    // tests/artifacts/PrimitiveOps/contract.py:349
    // return result
    retsub


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_log(a: bytes, b: uint64, c: bytes, d: bytes, e: bytes, f: bytes, g: bytes, h: bytes, i: bytes, j: bytes, k: bytes, m: bytes, n: bytes) -> void:
verify_log:
    // tests/artifacts/PrimitiveOps/contract.py:351-367
    // @arc4.abimethod
    // def verify_log(  # noqa: PLR0913
    //     self,
    //     a: String,
    //     b: UInt64,
    //     c: Bytes,
    //     d: Bytes,
    //     e: arc4.Bool,
    //     f: arc4.String,
    //     g: arc4.UIntN[typing.Literal[64]],
    //     h: arc4.BigUIntN[typing.Literal[256]],
    //     i: arc4.UFixedNxM[typing.Literal[32], typing.Literal[8]],
    //     j: arc4.BigUFixedNxM[typing.Literal[256], typing.Literal[16]],
    //     k: Bytes,
    //     m: Bytes,
    //     n: Bytes,
    // ) -> None:
    proto 13 0
    // tests/artifacts/PrimitiveOps/contract.py:372
    // log(a, b, c, d_biguint, e, f, g, h, i, j, arc4_k, arc4_m, arc4_n, sep="-")
    frame_dig -13
    bytec_2 // "-"
    concat
    frame_dig -12
    itob
    concat
    bytec_2 // "-"
    concat
    frame_dig -11
    concat
    bytec_2 // "-"
    concat
    frame_dig -10
    concat
    bytec_2 // "-"
    concat
    frame_dig -9
    concat
    bytec_2 // "-"
    concat
    frame_dig -8
    concat
    bytec_2 // "-"
    concat
    frame_dig -7
    concat
    bytec_2 // "-"
    concat
    frame_dig -6
    concat
    bytec_2 // "-"
    concat
    frame_dig -5
    concat
    bytec_2 // "-"
    concat
    frame_dig -4
    concat
    bytec_2 // "-"
    concat
    frame_dig -3
    concat
    bytec_2 // "-"
    concat
    frame_dig -2
    concat
    bytec_2 // "-"
    concat
    frame_dig -1
    concat
    log
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x00 "-" 0x151f7c750020
    // tests/artifacts/PrimitiveOps/contract.py:6
    // class PrimitiveOpsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@67
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x725c692b 0x17314559 0x53f34893 0x88c8b269 0xa464b7ab 0x9c8b11b8 0x6f40654e 0xec9a2974 0xc793708f 0x7ddb7499 0xa21c443d 0x6e7fb212 0xb007fcb0 0x2ebc20d4 0xb0954b66 0xdd140aef 0xace474da 0xba694990 0x6db581c0 0x91c8db89 0xdbe77158 0x9a0f22e1 0x64033d37 0x2a7237c5 0xe3a94458 0x42f87f7d 0x2b5542a4 0x9be2fbe9 0x1cd92515 0x64e1705c 0xf1271c50 0x2ab63b70 0x834bb7d2 0x531620d7 0x3fb9e769 0xfa8db0bc 0xa72ea485 0xb7b0ba19 0x74460c42 0xab320738 0x52ad4654 0x10156399 0x0f075957 0xbd843dff 0xb377d381 0x89767265 0x456b4b23 0x33d1b88c 0x6bf973ea 0x67cd6bb2 0x3f58805a 0x1e130039 0x509dc91d 0xa564a202 0x23650763 0xf8c8f8d5 0x23faf7a4 0x7d0afe15 0x48581adf 0xe007c10b // method "verify_uint64_init(byte[])uint64", method "verify_uint64_add(uint64,uint64)uint64", method "verify_uint64_sub(uint64,uint64)uint64", method "verify_uint64_mul(uint64,uint64)uint64", method "verify_uint64_div(uint64,uint64)uint64", method "verify_uint64_mod(uint64,uint64)uint64", method "verify_uint64_and(uint64,uint64)uint64", method "verify_uint64_or(uint64,uint64)uint64", method "verify_uint64_xor(uint64,uint64)uint64", method "verify_uint64_not(uint64)uint64", method "verify_uint64_lshift(uint64,uint64)uint64", method "verify_uint64_rshift(uint64,uint64)uint64", method "verify_uint64_pow(uint64,uint64)uint64", method "verify_uint64_eq(uint64,uint64)bool", method "verify_uint64_ne(uint64,uint64)bool", method "verify_uint64_lt(uint64,uint64)bool", method "verify_uint64_le(uint64,uint64)bool", method "verify_uint64_gt(uint64,uint64)bool", method "verify_uint64_ge(uint64,uint64)bool", method "verify_bytes_init(uint64)byte[]", method "verify_bytes_add(byte[],byte[],uint64,uint64)byte[]", method "verify_bytes_eq(byte[],byte[])bool", method "verify_bytes_ne(byte[],byte[])bool", method "verify_bytes_and(byte[],byte[])byte[]", method "verify_bytes_or(byte[],byte[])byte[]", method "verify_bytes_xor(byte[],byte[])byte[]", method "verify_bytes_not(byte[],uint64)byte[]", method "verify_biguint_add(byte[],byte[])byte[]", method "verify_biguint_add_uint64(byte[],uint64)byte[]", method "verify_biguint_sub(byte[],byte[])byte[]", method "verify_biguint_sub_uint64(byte[],uint64)byte[]", method "verify_biguint_mul(byte[],byte[])byte[]", method "verify_biguint_mul_uint64(byte[],uint64)byte[]", method "verify_biguint_div(byte[],byte[])byte[]", method "verify_biguint_div_uint64(byte[],uint64)byte[]", method "verify_biguint_mod(byte[],byte[])byte[]", method "verify_biguint_mod_uint64(byte[],uint64)byte[]", method "verify_biguint_and(byte[],byte[])byte[]", method "verify_biguint_and_uint64(byte[],uint64)byte[]", method "verify_biguint_or(byte[],byte[])byte[]", method "verify_biguint_or_uint64(byte[],uint64)byte[]", method "verify_biguint_xor(byte[],byte[])byte[]", method "verify_biguint_xor_uint64(byte[],uint64)byte[]", method "verify_biguint_eq(byte[],byte[])bool", method "verify_biguint_eq_uint64(byte[],uint64)bool", method "verify_biguint_ne(byte[],byte[])bool", method "verify_biguint_ne_uint64(byte[],uint64)bool", method "verify_biguint_lt(byte[],byte[])bool", method "verify_biguint_lt_uint64(byte[],uint64)bool", method "verify_biguint_le(byte[],byte[])bool", method "verify_biguint_le_uint64(byte[],uint64)bool", method "verify_biguint_gt(byte[],byte[])bool", method "verify_biguint_gt_uint64(byte[],uint64)bool", method "verify_biguint_ge(byte[],byte[])bool", method "verify_biguint_ge_uint64(byte[],uint64)bool", method "verify_string_init(string)string", method "verify_string_startswith(string,string)bool", method "verify_string_endswith(string,string)bool", method "verify_string_join(string,string)string", method "verify_log(string,uint64,byte[],byte[],bool,string,uint64,uint256,ufixed32x8,ufixed256x16,byte[],byte[],byte[])void"
    txna ApplicationArgs 0
    match verify_uint64_init verify_uint64_add verify_uint64_sub verify_uint64_mul verify_uint64_div verify_uint64_mod verify_uint64_and verify_uint64_or verify_uint64_xor verify_uint64_not verify_uint64_lshift verify_uint64_rshift verify_uint64_pow verify_uint64_eq verify_uint64_ne verify_uint64_lt verify_uint64_le verify_uint64_gt verify_uint64_ge verify_bytes_init verify_bytes_add verify_bytes_eq verify_bytes_ne verify_bytes_and verify_bytes_or verify_bytes_xor verify_bytes_not verify_biguint_add verify_biguint_add_uint64 verify_biguint_sub verify_biguint_sub_uint64 verify_biguint_mul verify_biguint_mul_uint64 verify_biguint_div verify_biguint_div_uint64 verify_biguint_mod verify_biguint_mod_uint64 verify_biguint_and verify_biguint_and_uint64 verify_biguint_or verify_biguint_or_uint64 verify_biguint_xor verify_biguint_xor_uint64 verify_biguint_eq verify_biguint_eq_uint64 verify_biguint_ne verify_biguint_ne_uint64 verify_biguint_lt verify_biguint_lt_uint64 verify_biguint_le verify_biguint_le_uint64 verify_biguint_gt verify_biguint_gt_uint64 verify_biguint_ge verify_biguint_ge_uint64 verify_string_init verify_string_startswith verify_string_endswith verify_string_join verify_log
    err

main___algopy_default_create@67:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_init[routing]() -> void:
verify_uint64_init:
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:9
    // result = op.btoi(raw_value)
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:7
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_add[routing]() -> void:
verify_uint64_add:
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:14
    // result = a + b
    +
    // tests/artifacts/PrimitiveOps/contract.py:12
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_sub[routing]() -> void:
verify_uint64_sub:
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:19
    // result = a - b
    -
    // tests/artifacts/PrimitiveOps/contract.py:17
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mul[routing]() -> void:
verify_uint64_mul:
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:24
    // result = a * b
    *
    // tests/artifacts/PrimitiveOps/contract.py:22
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_div[routing]() -> void:
verify_uint64_div:
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:29
    // result = a // b
    /
    // tests/artifacts/PrimitiveOps/contract.py:27
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_mod[routing]() -> void:
verify_uint64_mod:
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:34
    // result = a % b
    %
    // tests/artifacts/PrimitiveOps/contract.py:32
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_and[routing]() -> void:
verify_uint64_and:
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:39
    // result = a & b
    &
    // tests/artifacts/PrimitiveOps/contract.py:37
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_or[routing]() -> void:
verify_uint64_or:
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:44
    // result = a | b
    |
    // tests/artifacts/PrimitiveOps/contract.py:42
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_xor[routing]() -> void:
verify_uint64_xor:
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:49
    // result = a ^ b
    ^
    // tests/artifacts/PrimitiveOps/contract.py:47
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_not[routing]() -> void:
verify_uint64_not:
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:54
    // result = ~a
    ~
    // tests/artifacts/PrimitiveOps/contract.py:52
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lshift[routing]() -> void:
verify_uint64_lshift:
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:59
    // result = a << b
    shl
    // tests/artifacts/PrimitiveOps/contract.py:57
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_rshift[routing]() -> void:
verify_uint64_rshift:
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:64
    // result = a >> b
    shr
    // tests/artifacts/PrimitiveOps/contract.py:62
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_pow[routing]() -> void:
verify_uint64_pow:
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:69
    // result = a**b
    exp
    // tests/artifacts/PrimitiveOps/contract.py:67
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_eq[routing]() -> void:
verify_uint64_eq:
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:74
    // result = a == b
    ==
    // tests/artifacts/PrimitiveOps/contract.py:72
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ne[routing]() -> void:
verify_uint64_ne:
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:79
    // result = a != b
    !=
    // tests/artifacts/PrimitiveOps/contract.py:77
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_lt[routing]() -> void:
verify_uint64_lt:
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:84
    // result = a < b
    <
    // tests/artifacts/PrimitiveOps/contract.py:82
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_le[routing]() -> void:
verify_uint64_le:
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:89
    // result = a <= b
    <=
    // tests/artifacts/PrimitiveOps/contract.py:87
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_gt[routing]() -> void:
verify_uint64_gt:
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:94
    // result = a > b
    >
    // tests/artifacts/PrimitiveOps/contract.py:92
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_uint64_ge[routing]() -> void:
verify_uint64_ge:
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:99
    // result = a >= b
    >=
    // tests/artifacts/PrimitiveOps/contract.py:97
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_init[routing]() -> void:
verify_bytes_init:
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:104
    // result = op.itob(raw_value)
    itob
    // tests/artifacts/PrimitiveOps/contract.py:102
    // @arc4.abimethod()
    pushbytes 0x151f7c750008
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_add[routing]() -> void:
verify_bytes_add:
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:111
    // a = op.bzero(pad_a_size) + a
    swap
    bzero
    uncover 3
    concat
    // tests/artifacts/PrimitiveOps/contract.py:112
    // b = op.bzero(pad_b_size) + b
    swap
    bzero
    uncover 2
    concat
    // tests/artifacts/PrimitiveOps/contract.py:113
    // result = a + b
    concat
    // tests/artifacts/PrimitiveOps/contract.py:114
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:107
    // @arc4.abimethod()
    bytec_3 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_eq[routing]() -> void:
verify_bytes_eq:
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:119
    // result = a == b
    ==
    // tests/artifacts/PrimitiveOps/contract.py:117
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_ne[routing]() -> void:
verify_bytes_ne:
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:124
    // result = a != b
    !=
    // tests/artifacts/PrimitiveOps/contract.py:122
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_and[routing]() -> void:
verify_bytes_and:
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:129
    // result = a & b
    b&
    // tests/artifacts/PrimitiveOps/contract.py:127
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_or[routing]() -> void:
verify_bytes_or:
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:134
    // result = a | b
    b|
    // tests/artifacts/PrimitiveOps/contract.py:132
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_xor[routing]() -> void:
verify_bytes_xor:
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:139
    // result = a ^ b
    b^
    // tests/artifacts/PrimitiveOps/contract.py:137
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_bytes_not[routing]() -> void:
verify_bytes_not:
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:144
    // a = op.bzero(pad_size) + a
    bzero
    swap
    concat
    // tests/artifacts/PrimitiveOps/contract.py:145
    // result = ~a
    b~
    // tests/artifacts/PrimitiveOps/contract.py:146
    // result = op.sha256(result)
    sha256
    // tests/artifacts/PrimitiveOps/contract.py:142
    // @arc4.abimethod()
    bytec_3 // 0x151f7c750020
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add[routing]() -> void:
verify_biguint_add:
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:153
    // result = a_biguint + b_biguint
    b+
    // tests/artifacts/PrimitiveOps/contract.py:149
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_add_uint64[routing]() -> void:
verify_biguint_add_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:159
    // result = a_biguint + b
    itob
    b+
    // tests/artifacts/PrimitiveOps/contract.py:156
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub[routing]() -> void:
verify_biguint_sub:
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:166
    // result = a_biguint - b_biguint
    b-
    // tests/artifacts/PrimitiveOps/contract.py:162
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_sub_uint64[routing]() -> void:
verify_biguint_sub_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:172
    // result = a_biguint - b
    itob
    b-
    // tests/artifacts/PrimitiveOps/contract.py:169
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul[routing]() -> void:
verify_biguint_mul:
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:179
    // result = a_biguint * b_biguint
    b*
    // tests/artifacts/PrimitiveOps/contract.py:175
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mul_uint64[routing]() -> void:
verify_biguint_mul_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:185
    // result = a_biguint * b
    itob
    b*
    // tests/artifacts/PrimitiveOps/contract.py:182
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div[routing]() -> void:
verify_biguint_div:
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:192
    // result = a_biguint // b_biguint
    b/
    // tests/artifacts/PrimitiveOps/contract.py:188
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_div_uint64[routing]() -> void:
verify_biguint_div_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:198
    // result = a_biguint // b
    itob
    b/
    // tests/artifacts/PrimitiveOps/contract.py:195
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod[routing]() -> void:
verify_biguint_mod:
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:205
    // result = a_biguint % b_biguint
    b%
    // tests/artifacts/PrimitiveOps/contract.py:201
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_mod_uint64[routing]() -> void:
verify_biguint_mod_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:211
    // result = a_biguint % b
    itob
    b%
    // tests/artifacts/PrimitiveOps/contract.py:208
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and[routing]() -> void:
verify_biguint_and:
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:218
    // result = a_biguint & b_biguint
    b&
    // tests/artifacts/PrimitiveOps/contract.py:214
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_and_uint64[routing]() -> void:
verify_biguint_and_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:224
    // result = a_biguint & b
    itob
    b&
    // tests/artifacts/PrimitiveOps/contract.py:221
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or[routing]() -> void:
verify_biguint_or:
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:231
    // result = a_biguint | b_biguint
    b|
    // tests/artifacts/PrimitiveOps/contract.py:227
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_or_uint64[routing]() -> void:
verify_biguint_or_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:237
    // result = a_biguint | b
    itob
    b|
    // tests/artifacts/PrimitiveOps/contract.py:234
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor[routing]() -> void:
verify_biguint_xor:
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:244
    // result = a_biguint ^ b_biguint
    b^
    // tests/artifacts/PrimitiveOps/contract.py:240
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_xor_uint64[routing]() -> void:
verify_biguint_xor_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:250
    // result = a_biguint ^ b
    itob
    b^
    // tests/artifacts/PrimitiveOps/contract.py:247
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq[routing]() -> void:
verify_biguint_eq:
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:257
    // result = a_biguint == b_biguint
    b==
    // tests/artifacts/PrimitiveOps/contract.py:253
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_eq_uint64[routing]() -> void:
verify_biguint_eq_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:263
    // result = a_biguint == b
    itob
    b==
    // tests/artifacts/PrimitiveOps/contract.py:260
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne[routing]() -> void:
verify_biguint_ne:
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:270
    // result = a_biguint != b_biguint
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:266
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ne_uint64[routing]() -> void:
verify_biguint_ne_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:276
    // result = a_biguint != b
    itob
    b!=
    // tests/artifacts/PrimitiveOps/contract.py:273
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt[routing]() -> void:
verify_biguint_lt:
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:283
    // result = a_biguint < b_biguint
    b<
    // tests/artifacts/PrimitiveOps/contract.py:279
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_lt_uint64[routing]() -> void:
verify_biguint_lt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:289
    // result = a_biguint < b
    itob
    b<
    // tests/artifacts/PrimitiveOps/contract.py:286
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le[routing]() -> void:
verify_biguint_le:
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:296
    // result = a_biguint <= b_biguint
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:292
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_le_uint64[routing]() -> void:
verify_biguint_le_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:302
    // result = a_biguint <= b
    itob
    b<=
    // tests/artifacts/PrimitiveOps/contract.py:299
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt[routing]() -> void:
verify_biguint_gt:
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:309
    // result = a_biguint > b_biguint
    b>
    // tests/artifacts/PrimitiveOps/contract.py:305
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_gt_uint64[routing]() -> void:
verify_biguint_gt_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:315
    // result = a_biguint > b
    itob
    b>
    // tests/artifacts/PrimitiveOps/contract.py:312
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge[routing]() -> void:
verify_biguint_ge:
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:322
    // result = a_biguint >= b_biguint
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:318
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_biguint_ge_uint64[routing]() -> void:
verify_biguint_ge_uint64:
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/PrimitiveOps/contract.py:328
    // result = a_biguint >= b
    itob
    b>=
    // tests/artifacts/PrimitiveOps/contract.py:325
    // @arc4.abimethod()
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_init[routing]() -> void:
verify_string_init:
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:333
    // result = String("Hello, ") + a
    pushbytes "Hello, "
    swap
    concat
    // tests/artifacts/PrimitiveOps/contract.py:331
    // @arc4.abimethod
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_startswith[routing]() -> void:
verify_string_startswith:
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    dup
    txna ApplicationArgs 2
    extract 2 0
    dup
    cover 2
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    len
    dup
    uncover 2
    len
    >
    bz verify_string_startswith_ternary_false@3
    intc_1 // 0

verify_string_startswith_ternary_merge@4:
    // tests/artifacts/PrimitiveOps/contract.py:336
    // @arc4.abimethod
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

verify_string_startswith_ternary_false@3:
    // tests/artifacts/PrimitiveOps/contract.py:338
    // result = a.startswith(b)
    dig 2
    intc_1 // 0
    dig 2
    extract3
    dig 2
    ==
    b verify_string_startswith_ternary_merge@4


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_endswith[routing]() -> void:
verify_string_endswith:
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    dup
    txna ApplicationArgs 2
    extract 2 0
    dup
    cover 2
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    len
    dup
    uncover 2
    len
    dup
    cover 2
    >
    bz verify_string_endswith_ternary_false@3
    intc_1 // 0

verify_string_endswith_ternary_merge@4:
    // tests/artifacts/PrimitiveOps/contract.py:341
    // @arc4.abimethod
    bytec_1 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

verify_string_endswith_ternary_false@3:
    // tests/artifacts/PrimitiveOps/contract.py:343
    // result = a.endswith(b)
    dup
    dig 2
    dup
    cover 2
    -
    dig 5
    swap
    uncover 2
    extract3
    dig 3
    ==
    b verify_string_endswith_ternary_merge@4


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_string_join[routing]() -> void:
verify_string_join:
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:348
    // result = String(", ").join((a, b))
    swap
    pushbytes ", "
    concat
    swap
    concat
    // tests/artifacts/PrimitiveOps/contract.py:346
    // @arc4.abimethod
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.PrimitiveOps.contract.PrimitiveOpsContract.verify_log[routing]() -> void:
verify_log:
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    txna ApplicationArgs 4
    extract 2 0
    txna ApplicationArgs 5
    txna ApplicationArgs 6
    txna ApplicationArgs 7
    txna ApplicationArgs 8
    txna ApplicationArgs 9
    txna ApplicationArgs 10
    txna ApplicationArgs 11
    extract 2 0
    txna ApplicationArgs 12
    extract 2 0
    txna ApplicationArgs 13
    extract 2 0
    // tests/artifacts/PrimitiveOps/contract.py:372
    // log(a, b, c, d_biguint, e, f, g, h, i, j, arc4_k, arc4_m, arc4_n, sep="-")
    uncover 12
    bytec_2 // "-"
    concat
    uncover 12
    itob
    concat
    bytec_2 // "-"
    concat
    uncover 11
    concat
    bytec_2 // "-"
    concat
    uncover 10
    concat
    bytec_2 // "-"
    concat
    uncover 9
    concat
    bytec_2 // "-"
    concat
    uncover 8
    concat
    bytec_2 // "-"
    concat
    uncover 7
    concat
    bytec_2 // "-"
    concat
    uncover 6
    concat
    bytec_2 // "-"
    concat
    uncover 5
    concat
    bytec_2 // "-"
    concat
    uncover 4
    concat
    bytec_2 // "-"
    concat
    uncover 3
    concat
    bytec_2 // "-"
    concat
    uncover 2
    concat
    bytec_2 // "-"
    concat
    swap
    concat
    log
    // tests/artifacts/PrimitiveOps/contract.py:351
    // @arc4.abimethod
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiACAQAmAwQVH3x1AQABLTEbQQksgjwEclxpKwQXMUVZBFPzSJMEiMiyaQSkZLerBJyLEbgEb0BlTgTsmil0BMeTcI8Efdt0mQSiHEQ9BG5/shIEsAf8sAQuvCDUBLCVS2YE3RQK7wSs5HTaBLppSZAEbbWBwASRyNuJBNvncVgEmg8i4QRkAz03BCpyN8UE46lEWARC+H99BCtVQqQEm+L76QQc2SUVBGThcFwE8SccUAQqtjtwBINLt9IEUxYg1wQ/uedpBPqNsLwEpy6khQS3sLoZBHRGDEIEqzIHOARSrUZUBBAVY5kEDwdZVwS9hD3/BLN304EEiXZyZQRFa0sjBDPRuIwEa/lz6gRnzWuyBD9YgFoEHhMAOQRQnckdBKVkogIEI2UHYwT4yPjVBCP696QEfQr+FQRIWBrfBOAHwQs2GgCOPAdqB1EHOAcfBwYG7QbUBrsGogaNBnQGWwZCBiUGCAXrBc4FsQWUBXgFTAUrBQoE5gTCBJ4EfARYBDYEEgPwA8wDqgOGA2QDQAMeAvoC2AK0ApICbgJMAisCDAHrAcwBqwGMAWsBTAErAQwA6wDMAK4AjQBsAEgAAiNDMRkURDEYRDYaAVcCADYaAhc2GgNXAgA2GgRXAgA2GgU2GgY2Ggc2Ggg2Ggk2Ggo2GgtXAgA2GgxXAgA2Gg1XAgCICbsiQzEZFEQxGEQ2GgFXAgA2GgJXAgCICZVJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCICUgpI08CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCICQopI08CVChMULAiQzEZFEQxGEQ2GgFXAgCICN9JFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgIXiAizKSNPAlQoTFCwIkMxGRREMRhENhoBVwIANhoCVwIAiAiJKSNPAlQoTFCwIkMxGRREMRhENhoBVwIANhoCF4gIYCkjTwJUKExQsCJDMRkURDEYRDYaAVcCADYaAlcCAIgINikjTwJUKExQsCJDMRkURDEYRDYaAVcCADYaAheICA0pI08CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIB+MpI08CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgIXiAe6KSNPAlQoTFCwIkMxGRREMRhENhoBVwIANhoCVwIAiAeQKSNPAlQoTFCwIkMxGRREMRhENhoBVwIANhoCF4gHZykjTwJUKExQsCJDMRkURDEYRDYaAVcCADYaAlcCAIgHPSkjTwJUKExQsCJDMRkURDEYRDYaAVcCADYaAheIBxQpI08CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBuopI08CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgIXiAbBSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCVwIAiAaUSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCF4gGaEkVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAlcCAIgGO0kVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAheIBg9JFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBeJJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgIXiAW1SRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCVwIAiAWISRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCF4gFW0kVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAlcCAIgFLkkVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAheIBQJJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIBNVJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgIXiASoSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCVwIAiAR7SRUWVwYCTFAoTFCwIkMxGRREMRhENhoBVwIANhoCF4gET0kVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAlcCAIgEIkkVFlcGAkxQKExQsCJDMRkURDEYRDYaAVcCADYaAheIA/FJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIA8RJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIA5dJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIA2pJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAz0pI08CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgCIAxMpI08CVChMULAiQzEZFEQxGEQ2GgFXAgA2GgJXAgA2GgMXNhoEF4gC0EkVFlcGAkxQKExQsCJDMRkURDEYRDYaAReIAq1JFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXNhoCF4gChCkjTwJUKExQsCJDMRkURDEYRDYaARc2GgIXiAJeKSNPAlQoTFCwIkMxGRREMRhENhoBFzYaAheIAjgpI08CVChMULAiQzEZFEQxGEQ2GgEXNhoCF4gCEikjTwJUKExQsCJDMRkURDEYRDYaARc2GgIXiAHsKSNPAlQoTFCwIkMxGRREMRhENhoBFzYaAheIAcYpI08CVChMULAiQzEZFEQxGEQ2GgEXNhoCF4gBoBYoTFCwIkMxGRREMRhENhoBFzYaAheIAX4WKExQsCJDMRkURDEYRDYaARc2GgIXiAFcFihMULAiQzEZFEQxGEQ2GgEXiAFAFihMULAiQzEZFEQxGEQ2GgEXNhoCF4gBHhYoTFCwIkMxGRREMRhENhoBFzYaAheIAPwWKExQsCJDMRkURDEYRDYaARc2GgIXiADaFihMULAiQzEZFEQxGEQ2GgEXNhoCF4gAuBYoTFCwIkMxGRREMRhENhoBFzYaAheIAJYWKExQsCJDMRkURDEYRDYaARc2GgIXiAB0FihMULAiQzEZFEQxGEQ2GgEXNhoCF4gAUhYoTFCwIkMxGRREMRhENhoBFzYaAheIADAWKExQsCJDMRkURDEYRDYaAVcCAIgAEhYoTFCwIkMxGUD4ejEYFEQiQ4oBAYv/F4mKAgGL/ov/CImKAgGL/ov/CYmKAgGL/ov/C4mKAgGL/ov/ComKAgGL/ov/GImKAgGL/ov/GomKAgGL/ov/GYmKAgGL/ov/G4mKAQGL/xyJigIBi/6L/5CJigIBi/6L/5GJigIBi/6L/5SJigIBi/6L/xKJigIBi/6L/xOJigIBi/6L/wyJigIBi/6L/w6JigIBi/6L/w2JigIBi/6L/w+JigEBi/8WiYoEAYv+r4v8UIz8i/+vi/1QjP2L/Iv9UAGJigIBi/6L/xKJigIBi/6L/xOJigIBi/6L/6yJigIBi/6L/6uJigIBi/6L/62JigIBi/+vi/5QSYz+rgGJigIBi/6L/6CJigIBi/8Wi/6giYoCAYv+i/+hiYoCAYv/Fov+TKGJigIBi/6L/6OJigIBi/8Wi/6jiYoCAYv+i/+iiYoCAYv/Fov+TKKJigIBi/6L/6qJigIBi/8Wi/5MqomKAgGL/ov/rImKAgGL/xaL/qyJigIBi/6L/6uJigIBi/8Wi/6riYoCAYv+i/+tiYoCAYv/Fov+rYmKAgGL/ov/qImKAgGL/xaL/qiJigIBi/6L/6mJigIBi/8Wi/6piYoCAYv+i/+kiYoCAYv/Fov+pYmKAgGL/ov/pomKAgGL/xaL/qeJigIBi/6L/6WJigIBi/8Wi/6kiYoCAYv+i/+niYoCAYv/Fov+pomKAQGAB0hlbGxvLCCL/1CJigIBi/8VSYv+FQ1BAAMjTImL/iOLAFiL/xJC//KKAgGL/xVJi/4VSU4CDUEABCOMAImLAYsASU4CCYv+TE8CWIv/EkL/6YoCAYv+gAIsIFCL/1CJig0Ai/MqUIv0FlAqUIv1UCpQi/ZQKlCL91AqUIv4UCpQi/lQKlCL+lAqUIv7UCpQi/xQKlCL/VAqUIv+UCpQi/9QsIk=", + "approval": "CiACAQAmBAQVH3x1AQABLQYVH3x1ACAxG0EBszEZFEQxGESCPARyXGkrBBcxRVkEU/NIkwSIyLJpBKRkt6sEnIsRuARvQGVOBOyaKXQEx5NwjwR923SZBKIcRD0Ebn+yEgSwB/ywBC68INQEsJVLZgTdFArvBKzkdNoEumlJkARttYHABJHI24kE2+dxWASaDyLhBGQDPTcEKnI3xQTjqURYBEL4f30EK1VCpASb4vvpBBzZJRUEZOFwXATxJxxQBCq2O3AEg0u30gRTFiDXBD+552kE+o2wvASnLqSFBLewuhkEdEYMQgSrMgc4BFKtRlQEEBVjmQQPB1lXBL2EPf8Es3fTgQSJdnJlBEVrSyMEM9G4jARr+XPqBGfNa7IEP1iAWgQeEwA5BFCdyR0EpWSiAgQjZQdjBPjI+NUEI/r3pAR9Cv4VBEhYGt8E4AfBCzYaAI48AAkAFwAnADcARwBXAGcAdwCHAJcAowCzAMMA0wDnAPsBDwEjATcBSwFdAYMBmwGzAc4B6QIEAhkCNAJOAmkCgwKeArgC0wLtAwgDIgM9A1cDcgOMA6cDwQPZA/AECAQfBDcETgRmBH0ElQSsBMQE2wT6BSsFZgWIADEZFDEYFBBDNhoBVwIAFxYoTFCwIkM2GgEXNhoCFwgWKExQsCJDNhoBFzYaAhcJFihMULAiQzYaARc2GgIXCxYoTFCwIkM2GgEXNhoCFwoWKExQsCJDNhoBFzYaAhcYFihMULAiQzYaARc2GgIXGhYoTFCwIkM2GgEXNhoCFxkWKExQsCJDNhoBFzYaAhcbFihMULAiQzYaARccFihMULAiQzYaARc2GgIXkBYoTFCwIkM2GgEXNhoCF5EWKExQsCJDNhoBFzYaAheUFihMULAiQzYaARc2GgIXEikjTwJUKExQsCJDNhoBFzYaAhcTKSNPAlQoTFCwIkM2GgEXNhoCFwwpI08CVChMULAiQzYaARc2GgIXDikjTwJUKExQsCJDNhoBFzYaAhcNKSNPAlQoTFCwIkM2GgEXNhoCFw8pI08CVChMULAiQzYaARcWgAYVH3x1AAhMULAiQzYaAVcCADYaAlcCADYaAxc2GgQXTK9PA1BMr08CUFABK0xQsCJDNhoBVwIANhoCVwIAEikjTwJUKExQsCJDNhoBVwIANhoCVwIAEykjTwJUKExQsCJDNhoBVwIANhoCVwIArEkVFlcGAkxQKExQsCJDNhoBVwIANhoCVwIAq0kVFlcGAkxQKExQsCJDNhoBVwIANhoCVwIArUkVFlcGAkxQKExQsCJDNhoBVwIANhoCF69MUK4BK0xQsCJDNhoBVwIANhoCVwIAoEkVFlcGAkxQKExQsCJDNhoBVwIANhoCFxagSRUWVwYCTFAoTFCwIkM2GgFXAgA2GgJXAgChSRUWVwYCTFAoTFCwIkM2GgFXAgA2GgIXFqFJFRZXBgJMUChMULAiQzYaAVcCADYaAlcCAKNJFRZXBgJMUChMULAiQzYaAVcCADYaAhcWo0kVFlcGAkxQKExQsCJDNhoBVwIANhoCVwIAokkVFlcGAkxQKExQsCJDNhoBVwIANhoCFxaiSRUWVwYCTFAoTFCwIkM2GgFXAgA2GgJXAgCqSRUWVwYCTFAoTFCwIkM2GgFXAgA2GgIXFqpJFRZXBgJMUChMULAiQzYaAVcCADYaAlcCAKxJFRZXBgJMUChMULAiQzYaAVcCADYaAhcWrEkVFlcGAkxQKExQsCJDNhoBVwIANhoCVwIAq0kVFlcGAkxQKExQsCJDNhoBVwIANhoCFxarSRUWVwYCTFAoTFCwIkM2GgFXAgA2GgJXAgCtSRUWVwYCTFAoTFCwIkM2GgFXAgA2GgIXFq1JFRZXBgJMUChMULAiQzYaAVcCADYaAlcCAKgpI08CVChMULAiQzYaAVcCADYaAhcWqCkjTwJUKExQsCJDNhoBVwIANhoCVwIAqSkjTwJUKExQsCJDNhoBVwIANhoCFxapKSNPAlQoTFCwIkM2GgFXAgA2GgJXAgCkKSNPAlQoTFCwIkM2GgFXAgA2GgIXFqQpI08CVChMULAiQzYaAVcCADYaAlcCAKYpI08CVChMULAiQzYaAVcCADYaAhcWpikjTwJUKExQsCJDNhoBVwIANhoCVwIApSkjTwJUKExQsCJDNhoBVwIANhoCFxalKSNPAlQoTFCwIkM2GgFXAgA2GgJXAgCnKSNPAlQoTFCwIkM2GgFXAgA2GgIXFqcpI08CVChMULAiQzYaAVcCAIAHSGVsbG8sIExQSRUWVwYCTFAoTFCwIkM2GgFXAgBJNhoCVwIASU4CFUlPAhUNQQAMIykjTwJUKExQsCJDSwIjSwJYSwISQv/pNhoBVwIASTYaAlcCAElOAhVJTwIVSU4CDUEADCMpI08CVChMULAiQ0lLAklOAglLBUxPAlhLAxJC/+I2GgFXAgA2GgJXAgBMgAIsIFBMUEkVFlcGAkxQKExQsCJDNhoBVwIANhoCFzYaA1cCADYaBFcCADYaBTYaBjYaBzYaCDYaCTYaCjYaC1cCADYaDFcCADYaDVcCAE8MKlBPDBZQKlBPC1AqUE8KUCpQTwlQKlBPCFAqUE8HUCpQTwZQKlBPBVAqUE8EUCpQTwNQKlBPAlAqUExQsCJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateMutations/data/StateMutations.approval.teal b/tests/artifacts/StateMutations/data/StateMutations.approval.teal index 8d26148..4b6cdae 100644 --- a/tests/artifacts/StateMutations/data/StateMutations.approval.teal +++ b/tests/artifacts/StateMutations/data/StateMutations.approval.teal @@ -17,79 +17,88 @@ main_after_if_else@2: // tests/artifacts/StateMutations/statemutations.py:22 // class StateMutations(ARC4Contract): txn NumAppArgs - bz main_bare_routing@8 - pushbytess 0x526e8bbf 0x95fef13d 0x0c29444b // method "append()void", method "modify()void", method "get()(uint64,string)[]" - txna ApplicationArgs 0 - match main_append_route@5 main_modify_route@6 main_get_route@7 - -main_after_if_else@11: - // tests/artifacts/StateMutations/statemutations.py:22 - // class StateMutations(ARC4Contract): - intc_0 // 0 - return - -main_get_route@7: - // tests/artifacts/StateMutations/statemutations.py:66 - // @arc4.abimethod + bz main_bare_routing@9 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - callsub get - pushbytes 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_modify_route@6: - // tests/artifacts/StateMutations/statemutations.py:52 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub modify - intc_1 // 1 - return - -main_append_route@5: - // tests/artifacts/StateMutations/statemutations.py:39 - // @arc4.abimethod - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub append - intc_1 // 1 - return + assert + pushbytess 0x526e8bbf 0x95fef13d 0x0c29444b // method "append()void", method "modify()void", method "get()(uint64,string)[]" + txna ApplicationArgs 0 + match append modify get + err -main_bare_routing@8: +main_bare_routing@9: // tests/artifacts/StateMutations/statemutations.py:22 // class StateMutations(ARC4Contract): txn OnCompletion - switch main___algopy_default_create@10 main_opt_in@9 - b main_after_if_else@11 + switch main___algopy_default_create@10 main_opt_in@11 + err -main_opt_in@9: +main_opt_in@11: // tests/artifacts/StateMutations/statemutations.py:31 // @arc4.baremethod(allow_actions=["OptIn"]) txn ApplicationID assert // can only call when not creating - callsub opt_in + // tests/artifacts/StateMutations/statemutations.py:33 + // self.glob_assign.value = MyArray() + bytec_3 // "glob_assign" + bytec_2 // 0x0000 + app_global_put + // tests/artifacts/StateMutations/statemutations.py:34 + // self.glob.value = MyArray() + bytec 4 // "glob" + // tests/artifacts/StateMutations/statemutations.py:33 + // self.glob_assign.value = MyArray() + bytec_2 // 0x0000 + // tests/artifacts/StateMutations/statemutations.py:34 + // self.glob.value = MyArray() + app_global_put + // tests/artifacts/StateMutations/statemutations.py:35 + // self.box.value = MyArray() + bytec_0 // "box" + box_del + pop + bytec_0 // "box" + // tests/artifacts/StateMutations/statemutations.py:33 + // self.glob_assign.value = MyArray() + bytec_2 // 0x0000 + // tests/artifacts/StateMutations/statemutations.py:35 + // self.box.value = MyArray() + box_put + // tests/artifacts/StateMutations/statemutations.py:36 + // self.loc[Txn.sender] = MyArray() + txn Sender + bytec 5 // "loc" + // tests/artifacts/StateMutations/statemutations.py:33 + // self.glob_assign.value = MyArray() + bytec_2 // 0x0000 + // tests/artifacts/StateMutations/statemutations.py:36 + // self.loc[Txn.sender] = MyArray() + app_local_put + // tests/artifacts/StateMutations/statemutations.py:37 + // self.map[Txn.sender] = MyArray() + bytec 8 // "map" + txn Sender + concat + dup + box_del + pop + // tests/artifacts/StateMutations/statemutations.py:33 + // self.glob_assign.value = MyArray() + bytec_2 // 0x0000 + // tests/artifacts/StateMutations/statemutations.py:37 + // self.map[Txn.sender] = MyArray() + box_put + // tests/artifacts/StateMutations/statemutations.py:31 + // @arc4.baremethod(allow_actions=["OptIn"]) intc_1 // 1 return main___algopy_default_create@10: txn ApplicationID ! - assert // can only call when creating - intc_1 // 1 - return + return // on error: can only call when creating // _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes: @@ -274,62 +283,7 @@ dynamic_array_replace_dynamic_element_after_for@5: retsub -// tests.artifacts.StateMutations.statemutations.StateMutations.opt_in() -> void: -opt_in: - // tests/artifacts/StateMutations/statemutations.py:33 - // self.glob_assign.value = MyArray() - bytec_3 // "glob_assign" - bytec_2 // 0x0000 - app_global_put - // tests/artifacts/StateMutations/statemutations.py:34 - // self.glob.value = MyArray() - bytec 4 // "glob" - // tests/artifacts/StateMutations/statemutations.py:33 - // self.glob_assign.value = MyArray() - bytec_2 // 0x0000 - // tests/artifacts/StateMutations/statemutations.py:34 - // self.glob.value = MyArray() - app_global_put - // tests/artifacts/StateMutations/statemutations.py:35 - // self.box.value = MyArray() - bytec_0 // "box" - box_del - pop - bytec_0 // "box" - // tests/artifacts/StateMutations/statemutations.py:33 - // self.glob_assign.value = MyArray() - bytec_2 // 0x0000 - // tests/artifacts/StateMutations/statemutations.py:35 - // self.box.value = MyArray() - box_put - // tests/artifacts/StateMutations/statemutations.py:36 - // self.loc[Txn.sender] = MyArray() - txn Sender - bytec 5 // "loc" - // tests/artifacts/StateMutations/statemutations.py:33 - // self.glob_assign.value = MyArray() - bytec_2 // 0x0000 - // tests/artifacts/StateMutations/statemutations.py:36 - // self.loc[Txn.sender] = MyArray() - app_local_put - // tests/artifacts/StateMutations/statemutations.py:37 - // self.map[Txn.sender] = MyArray() - bytec 8 // "map" - txn Sender - concat - dup - box_del - pop - // tests/artifacts/StateMutations/statemutations.py:33 - // self.glob_assign.value = MyArray() - bytec_2 // 0x0000 - // tests/artifacts/StateMutations/statemutations.py:37 - // self.map[Txn.sender] = MyArray() - box_put - retsub - - -// tests.artifacts.StateMutations.statemutations.StateMutations.append() -> void: +// tests.artifacts.StateMutations.statemutations.StateMutations.append[routing]() -> void: append: // tests/artifacts/StateMutations/statemutations.py:42 // arr = self.glob_assign.value.copy() @@ -464,10 +418,13 @@ append: box_del pop box_put - retsub + // tests/artifacts/StateMutations/statemutations.py:39 + // @arc4.abimethod + intc_1 // 1 + return -// tests.artifacts.StateMutations.statemutations.StateMutations.modify() -> void: +// tests.artifacts.StateMutations.statemutations.StateMutations.modify[routing]() -> void: modify: // tests/artifacts/StateMutations/statemutations.py:56 // arr = self.glob_assign.value.copy() @@ -756,10 +713,13 @@ modify: box_del pop box_put - retsub + // tests/artifacts/StateMutations/statemutations.py:52 + // @arc4.abimethod + intc_1 // 1 + return -// tests.artifacts.StateMutations.statemutations.StateMutations.get() -> bytes: +// tests.artifacts.StateMutations.statemutations.StateMutations.get[routing]() -> void: get: // tests/artifacts/StateMutations/statemutations.py:68 // a0 = self.no_proxy.copy() @@ -827,6 +787,11 @@ get: dig 1 == assert // expected map == no_proxy - // tests/artifacts/StateMutations/statemutations.py:80 - // return a0 - retsub + // tests/artifacts/StateMutations/statemutations.py:66 + // @arc4.abimethod + pushbytes 0x151f7c75 + swap + concat + log + intc_1 // 1 + return diff --git a/tests/artifacts/StateMutations/data/StateMutations.arc32.json b/tests/artifacts/StateMutations/data/StateMutations.arc32.json index b82bdb3..4316a53 100644 --- a/tests/artifacts/StateMutations/data/StateMutations.arc32.json +++ b/tests/artifacts/StateMutations/data/StateMutations.arc32.json @@ -17,7 +17,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateMutations.statemutations.StateMutations.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock "box" "no_proxy" 0x0000 "glob_assign" "glob" "loc" 0x00020000000000000001000a000362617a 0x00086d6f646966696564 "map"
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateMutations/statemutations.py:24
    // self.no_proxy = MyArray()
    bytec_1 // "no_proxy"
    bytec_2 // 0x0000
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@8
    pushbytess 0x526e8bbf 0x95fef13d 0x0c29444b // method "append()void", method "modify()void", method "get()(uint64,string)[]"
    txna ApplicationArgs 0
    match main_append_route@5 main_modify_route@6 main_get_route@7

main_after_if_else@11:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    intc_0 // 0
    return

main_get_route@7:
    // tests/artifacts/StateMutations/statemutations.py:66
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get
    pushbytes 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_modify_route@6:
    // tests/artifacts/StateMutations/statemutations.py:52
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub modify
    intc_1 // 1
    return

main_append_route@5:
    // tests/artifacts/StateMutations/statemutations.py:39
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub append
    intc_1 // 1
    return

main_bare_routing@8:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn OnCompletion
    switch main___algopy_default_create@10 main_opt_in@9
    b main_after_if_else@11

main_opt_in@9:
    // tests/artifacts/StateMutations/statemutations.py:31
    // @arc4.baremethod(allow_actions=["OptIn"])
    txn ApplicationID
    assert // can only call when not creating
    callsub opt_in
    intc_1 // 1
    return

main___algopy_default_create@10:
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    pushbytes ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_replace_dynamic_element(source: bytes, new_item: bytes, index: uint64) -> bytes:
dynamic_array_replace_dynamic_element:
    proto 3 1
    frame_dig -3
    substring 0 2
    dup
    btoi
    frame_dig -3
    extract 2 0
    frame_dig -1
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    frame_dig -1
    intc_1 // 1
    +
    intc_2 // 2
    *
    dup
    cover 4
    dig 2
    swap
    extract_uint16
    dig 2
    len
    dig 4
    frame_dig -1
    -
    intc_1 // 1
    -
    dig 1
    uncover 3
    uncover 2
    select
    dup
    dig 3
    -
    cover 5
    frame_dig -2
    len
    cover 5
    dig 3
    intc_0 // 0
    uncover 4
    substring3
    frame_dig -2
    concat
    uncover 3
    uncover 2
    uncover 3
    substring3
    concat
    swap
    intc_2 // 2
    *

dynamic_array_replace_dynamic_element_for_header@2:
    frame_dig 1
    frame_dig 5
    <
    bz dynamic_array_replace_dynamic_element_after_for@5
    frame_dig 4
    dup
    frame_dig 1
    dup
    cover 3
    extract_uint16
    frame_dig 3
    +
    frame_dig 2
    -
    itob
    extract 6 2
    dig 2
    swap
    replace3
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 1
    b dynamic_array_replace_dynamic_element_for_header@2

dynamic_array_replace_dynamic_element_after_for@5:
    frame_dig 0
    frame_dig 4
    concat
    frame_bury 0
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.opt_in() -> void:
opt_in:
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_3 // "glob_assign"
    bytec_2 // 0x0000
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    bytec 4 // "glob"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    box_put
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    txn Sender
    bytec 5 // "loc"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_del
    pop
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    box_put
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.append() -> void:
append:
    // tests/artifacts/StateMutations/statemutations.py:42
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    bytec 6 // 0x00020000000000000001000a000362617a
    callsub dynamic_array_concat_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:45
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    dig 1
    box_del
    pop
    box_put
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.modify() -> void:
modify:
    // tests/artifacts/StateMutations/statemutations.py:56
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:58
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    dig 1
    box_del
    pop
    box_put
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.get() -> bytes:
get:
    // tests/artifacts/StateMutations/statemutations.py:68
    // a0 = self.no_proxy.copy()
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    // tests/artifacts/StateMutations/statemutations.py:69
    // a1 = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:70
    // a2 = self.glob.value.copy()
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    // tests/artifacts/StateMutations/statemutations.py:71
    // a3 = self.loc[Txn.sender].copy()
    txn Sender
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    // tests/artifacts/StateMutations/statemutations.py:72
    // a4 = self.box.value.copy()
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    // tests/artifacts/StateMutations/statemutations.py:73
    // a5 = self.map[Txn.sender].copy()
    bytec 8 // "map"
    txn Sender
    concat
    box_get
    assert // check self.map entry exists
    // tests/artifacts/StateMutations/statemutations.py:75
    // assert a0 == a1, "expected global assign == no_proxy"
    dig 5
    uncover 5
    ==
    assert // expected global assign == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:76
    // assert a0 == a2, "expected global == no_proxy"
    dig 4
    uncover 4
    ==
    assert // expected global == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:77
    // assert a0 == a3, "expected local == no_proxy"
    dig 3
    uncover 3
    ==
    assert // expected local == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:78
    // assert a0 == a4, "expected box == no_proxy"
    dig 2
    uncover 2
    ==
    assert // expected box == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:79
    // assert a0 == a5, "expected map == no_proxy"
    dig 1
    ==
    assert // expected map == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:80
    // return a0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateMutations.statemutations.StateMutations.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock "box" "no_proxy" 0x0000 "glob_assign" "glob" "loc" 0x00020000000000000001000a000362617a 0x00086d6f646966696564 "map"
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateMutations/statemutations.py:24
    // self.no_proxy = MyArray()
    bytec_1 // "no_proxy"
    bytec_2 // 0x0000
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@9
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x526e8bbf 0x95fef13d 0x0c29444b // method "append()void", method "modify()void", method "get()(uint64,string)[]"
    txna ApplicationArgs 0
    match append modify get
    err

main_bare_routing@9:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn OnCompletion
    switch main___algopy_default_create@10 main_opt_in@11
    err

main_opt_in@11:
    // tests/artifacts/StateMutations/statemutations.py:31
    // @arc4.baremethod(allow_actions=["OptIn"])
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_3 // "glob_assign"
    bytec_2 // 0x0000
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    bytec 4 // "glob"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    box_put
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    txn Sender
    bytec 5 // "loc"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_del
    pop
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    box_put
    // tests/artifacts/StateMutations/statemutations.py:31
    // @arc4.baremethod(allow_actions=["OptIn"])
    intc_1 // 1
    return

main___algopy_default_create@10:
    txn ApplicationID
    !
    return // on error: can only call when creating


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    pushbytes ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_replace_dynamic_element(source: bytes, new_item: bytes, index: uint64) -> bytes:
dynamic_array_replace_dynamic_element:
    proto 3 1
    frame_dig -3
    substring 0 2
    dup
    btoi
    frame_dig -3
    extract 2 0
    frame_dig -1
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    frame_dig -1
    intc_1 // 1
    +
    intc_2 // 2
    *
    dup
    cover 4
    dig 2
    swap
    extract_uint16
    dig 2
    len
    dig 4
    frame_dig -1
    -
    intc_1 // 1
    -
    dig 1
    uncover 3
    uncover 2
    select
    dup
    dig 3
    -
    cover 5
    frame_dig -2
    len
    cover 5
    dig 3
    intc_0 // 0
    uncover 4
    substring3
    frame_dig -2
    concat
    uncover 3
    uncover 2
    uncover 3
    substring3
    concat
    swap
    intc_2 // 2
    *

dynamic_array_replace_dynamic_element_for_header@2:
    frame_dig 1
    frame_dig 5
    <
    bz dynamic_array_replace_dynamic_element_after_for@5
    frame_dig 4
    dup
    frame_dig 1
    dup
    cover 3
    extract_uint16
    frame_dig 3
    +
    frame_dig 2
    -
    itob
    extract 6 2
    dig 2
    swap
    replace3
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 1
    b dynamic_array_replace_dynamic_element_for_header@2

dynamic_array_replace_dynamic_element_after_for@5:
    frame_dig 0
    frame_dig 4
    concat
    frame_bury 0
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.append[routing]() -> void:
append:
    // tests/artifacts/StateMutations/statemutations.py:42
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    bytec 6 // 0x00020000000000000001000a000362617a
    callsub dynamic_array_concat_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:45
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    dig 1
    box_del
    pop
    box_put
    // tests/artifacts/StateMutations/statemutations.py:39
    // @arc4.abimethod
    intc_1 // 1
    return


// tests.artifacts.StateMutations.statemutations.StateMutations.modify[routing]() -> void:
modify:
    // tests/artifacts/StateMutations/statemutations.py:56
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:58
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    dig 1
    box_del
    pop
    box_put
    // tests/artifacts/StateMutations/statemutations.py:52
    // @arc4.abimethod
    intc_1 // 1
    return


// tests.artifacts.StateMutations.statemutations.StateMutations.get[routing]() -> void:
get:
    // tests/artifacts/StateMutations/statemutations.py:68
    // a0 = self.no_proxy.copy()
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    // tests/artifacts/StateMutations/statemutations.py:69
    // a1 = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:70
    // a2 = self.glob.value.copy()
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    // tests/artifacts/StateMutations/statemutations.py:71
    // a3 = self.loc[Txn.sender].copy()
    txn Sender
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    // tests/artifacts/StateMutations/statemutations.py:72
    // a4 = self.box.value.copy()
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    // tests/artifacts/StateMutations/statemutations.py:73
    // a5 = self.map[Txn.sender].copy()
    bytec 8 // "map"
    txn Sender
    concat
    box_get
    assert // check self.map entry exists
    // tests/artifacts/StateMutations/statemutations.py:75
    // assert a0 == a1, "expected global assign == no_proxy"
    dig 5
    uncover 5
    ==
    assert // expected global assign == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:76
    // assert a0 == a2, "expected global == no_proxy"
    dig 4
    uncover 4
    ==
    assert // expected global == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:77
    // assert a0 == a3, "expected local == no_proxy"
    dig 3
    uncover 3
    ==
    assert // expected local == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:78
    // assert a0 == a4, "expected box == no_proxy"
    dig 2
    uncover 2
    ==
    assert // expected box == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:79
    // assert a0 == a5, "expected map == no_proxy"
    dig 1
    ==
    assert // expected map == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:66
    // @arc4.abimethod
    pushbytes 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/StateMutations/data/StateMutations.arc56.json b/tests/artifacts/StateMutations/data/StateMutations.arc56.json index 018eeac..2fb1fd1 100644 --- a/tests/artifacts/StateMutations/data/StateMutations.arc56.json +++ b/tests/artifacts/StateMutations/data/StateMutations.arc56.json @@ -125,119 +125,114 @@ "sourceInfo": [ { "pc": [ - 125, - 146, - 158 + 95 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 189 + 174 ], "errorMessage": "can only call when creating" }, { "pc": [ - 128, - 149, - 161, - 180 + 139 ], "errorMessage": "can only call when not creating" }, { "pc": [ - 572, - 840, - 975 + 525, + 794, + 930 ], "errorMessage": "check self.box exists" }, { "pc": [ - 527, - 729, - 965 + 480, + 683, + 920 ], "errorMessage": "check self.glob exists" }, { "pc": [ - 486, - 622, - 960 + 439, + 576, + 915 ], "errorMessage": "check self.glob_assign exists" }, { "pc": [ - 552, - 787, - 972 + 505, + 741, + 927 ], "errorMessage": "check self.loc exists for account" }, { "pc": [ - 599, - 900, - 982 + 552, + 854, + 937 ], "errorMessage": "check self.map entry exists" }, { "pc": [ - 506, - 675, - 956 + 459, + 629, + 911 ], "errorMessage": "check self.no_proxy exists" }, { "pc": [ - 1006 + 961 ], "errorMessage": "expected box == no_proxy" }, { "pc": [ - 994 + 949 ], "errorMessage": "expected global == no_proxy" }, { "pc": [ - 988 + 943 ], "errorMessage": "expected global assign == no_proxy" }, { "pc": [ - 1000 + 955 ], "errorMessage": "expected local == no_proxy" }, { "pc": [ - 1010 + 965 ], "errorMessage": "expected map == no_proxy" }, { "pc": [ - 638, - 664, - 691, - 717, - 745, - 771, - 803, - 829, - 856, - 882, - 916, - 942 + 592, + 618, + 645, + 671, + 699, + 725, + 757, + 783, + 810, + 836, + 870, + 896 ], "errorMessage": "index access is out of bounds" } @@ -250,18 +245,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateMutations.statemutations.StateMutations.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock "box" "no_proxy" 0x0000 "glob_assign" "glob" "loc" 0x00020000000000000001000a000362617a 0x00086d6f646966696564 "map"
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateMutations/statemutations.py:24
    // self.no_proxy = MyArray()
    bytec_1 // "no_proxy"
    bytec_2 // 0x0000
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@8
    pushbytess 0x526e8bbf 0x95fef13d 0x0c29444b // method "append()void", method "modify()void", method "get()(uint64,string)[]"
    txna ApplicationArgs 0
    match main_append_route@5 main_modify_route@6 main_get_route@7

main_after_if_else@11:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    intc_0 // 0
    return

main_get_route@7:
    // tests/artifacts/StateMutations/statemutations.py:66
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get
    pushbytes 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_modify_route@6:
    // tests/artifacts/StateMutations/statemutations.py:52
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub modify
    intc_1 // 1
    return

main_append_route@5:
    // tests/artifacts/StateMutations/statemutations.py:39
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub append
    intc_1 // 1
    return

main_bare_routing@8:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn OnCompletion
    switch main___algopy_default_create@10 main_opt_in@9
    b main_after_if_else@11

main_opt_in@9:
    // tests/artifacts/StateMutations/statemutations.py:31
    // @arc4.baremethod(allow_actions=["OptIn"])
    txn ApplicationID
    assert // can only call when not creating
    callsub opt_in
    intc_1 // 1
    return

main___algopy_default_create@10:
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    pushbytes ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_replace_dynamic_element(source: bytes, new_item: bytes, index: uint64) -> bytes:
dynamic_array_replace_dynamic_element:
    proto 3 1
    frame_dig -3
    substring 0 2
    dup
    btoi
    frame_dig -3
    extract 2 0
    frame_dig -1
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    frame_dig -1
    intc_1 // 1
    +
    intc_2 // 2
    *
    dup
    cover 4
    dig 2
    swap
    extract_uint16
    dig 2
    len
    dig 4
    frame_dig -1
    -
    intc_1 // 1
    -
    dig 1
    uncover 3
    uncover 2
    select
    dup
    dig 3
    -
    cover 5
    frame_dig -2
    len
    cover 5
    dig 3
    intc_0 // 0
    uncover 4
    substring3
    frame_dig -2
    concat
    uncover 3
    uncover 2
    uncover 3
    substring3
    concat
    swap
    intc_2 // 2
    *

dynamic_array_replace_dynamic_element_for_header@2:
    frame_dig 1
    frame_dig 5
    <
    bz dynamic_array_replace_dynamic_element_after_for@5
    frame_dig 4
    dup
    frame_dig 1
    dup
    cover 3
    extract_uint16
    frame_dig 3
    +
    frame_dig 2
    -
    itob
    extract 6 2
    dig 2
    swap
    replace3
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 1
    b dynamic_array_replace_dynamic_element_for_header@2

dynamic_array_replace_dynamic_element_after_for@5:
    frame_dig 0
    frame_dig 4
    concat
    frame_bury 0
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.opt_in() -> void:
opt_in:
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_3 // "glob_assign"
    bytec_2 // 0x0000
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    bytec 4 // "glob"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    box_put
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    txn Sender
    bytec 5 // "loc"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_del
    pop
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    box_put
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.append() -> void:
append:
    // tests/artifacts/StateMutations/statemutations.py:42
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    bytec 6 // 0x00020000000000000001000a000362617a
    callsub dynamic_array_concat_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:45
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    dig 1
    box_del
    pop
    box_put
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.modify() -> void:
modify:
    // tests/artifacts/StateMutations/statemutations.py:56
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:58
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    dig 1
    box_del
    pop
    box_put
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.get() -> bytes:
get:
    // tests/artifacts/StateMutations/statemutations.py:68
    // a0 = self.no_proxy.copy()
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    // tests/artifacts/StateMutations/statemutations.py:69
    // a1 = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:70
    // a2 = self.glob.value.copy()
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    // tests/artifacts/StateMutations/statemutations.py:71
    // a3 = self.loc[Txn.sender].copy()
    txn Sender
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    // tests/artifacts/StateMutations/statemutations.py:72
    // a4 = self.box.value.copy()
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    // tests/artifacts/StateMutations/statemutations.py:73
    // a5 = self.map[Txn.sender].copy()
    bytec 8 // "map"
    txn Sender
    concat
    box_get
    assert // check self.map entry exists
    // tests/artifacts/StateMutations/statemutations.py:75
    // assert a0 == a1, "expected global assign == no_proxy"
    dig 5
    uncover 5
    ==
    assert // expected global assign == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:76
    // assert a0 == a2, "expected global == no_proxy"
    dig 4
    uncover 4
    ==
    assert // expected global == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:77
    // assert a0 == a3, "expected local == no_proxy"
    dig 3
    uncover 3
    ==
    assert // expected local == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:78
    // assert a0 == a4, "expected box == no_proxy"
    dig 2
    uncover 2
    ==
    assert // expected box == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:79
    // assert a0 == a5, "expected map == no_proxy"
    dig 1
    ==
    assert // expected map == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:80
    // return a0
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateMutations.statemutations.StateMutations.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1 2 8
    bytecblock "box" "no_proxy" 0x0000 "glob_assign" "glob" "loc" 0x00020000000000000001000a000362617a 0x00086d6f646966696564 "map"
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateMutations/statemutations.py:24
    // self.no_proxy = MyArray()
    bytec_1 // "no_proxy"
    bytec_2 // 0x0000
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@9
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x526e8bbf 0x95fef13d 0x0c29444b // method "append()void", method "modify()void", method "get()(uint64,string)[]"
    txna ApplicationArgs 0
    match append modify get
    err

main_bare_routing@9:
    // tests/artifacts/StateMutations/statemutations.py:22
    // class StateMutations(ARC4Contract):
    txn OnCompletion
    switch main___algopy_default_create@10 main_opt_in@11
    err

main_opt_in@11:
    // tests/artifacts/StateMutations/statemutations.py:31
    // @arc4.baremethod(allow_actions=["OptIn"])
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_3 // "glob_assign"
    bytec_2 // 0x0000
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    bytec 4 // "glob"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:34
    // self.glob.value = MyArray()
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:35
    // self.box.value = MyArray()
    box_put
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    txn Sender
    bytec 5 // "loc"
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:36
    // self.loc[Txn.sender] = MyArray()
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_del
    pop
    // tests/artifacts/StateMutations/statemutations.py:33
    // self.glob_assign.value = MyArray()
    bytec_2 // 0x0000
    // tests/artifacts/StateMutations/statemutations.py:37
    // self.map[Txn.sender] = MyArray()
    box_put
    // tests/artifacts/StateMutations/statemutations.py:31
    // @arc4.baremethod(allow_actions=["OptIn"])
    intc_1 // 1
    return

main___algopy_default_create@10:
    txn ApplicationID
    !
    return // on error: can only call when creating


// _puya_lib.arc4.dynamic_array_concat_dynamic_element(array_items_count: uint64, array_head_and_tail: bytes, new_items_count: uint64, new_head_and_tail: bytes) -> bytes:
dynamic_array_concat_dynamic_element:
    proto 4 1
    pushbytes ""
    dup
    frame_dig -2
    intc_2 // 2
    *
    frame_dig -4
    intc_2 // 2
    *
    intc_0 // 0

dynamic_array_concat_dynamic_element_for_header@1:
    frame_dig 4
    frame_dig 3
    <
    bz dynamic_array_concat_dynamic_element_after_for@4
    frame_dig -3
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 2
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@1

dynamic_array_concat_dynamic_element_after_for@4:
    frame_dig -3
    len
    frame_bury 0
    intc_0 // 0
    frame_bury 4

dynamic_array_concat_dynamic_element_for_header@5:
    frame_dig 4
    frame_dig 2
    <
    bz dynamic_array_concat_dynamic_element_after_for@8
    frame_dig -1
    frame_dig 4
    dup
    cover 2
    extract_uint16
    frame_dig 0
    +
    itob
    extract 6 2
    frame_dig 1
    swap
    concat
    frame_bury 1
    intc_2 // 2
    +
    frame_bury 4
    b dynamic_array_concat_dynamic_element_for_header@5

dynamic_array_concat_dynamic_element_after_for@8:
    frame_dig -4
    frame_dig -2
    +
    itob
    extract 6 2
    frame_dig 1
    concat
    frame_dig -3
    frame_dig 3
    frame_dig 0
    substring3
    concat
    frame_dig -1
    len
    frame_dig -1
    frame_dig 2
    uncover 2
    substring3
    concat
    frame_bury 0
    retsub


// _puya_lib.arc4.dynamic_array_replace_dynamic_element(source: bytes, new_item: bytes, index: uint64) -> bytes:
dynamic_array_replace_dynamic_element:
    proto 3 1
    frame_dig -3
    substring 0 2
    dup
    btoi
    frame_dig -3
    extract 2 0
    frame_dig -1
    intc_2 // 2
    *
    dig 1
    swap
    extract_uint16
    frame_dig -1
    intc_1 // 1
    +
    intc_2 // 2
    *
    dup
    cover 4
    dig 2
    swap
    extract_uint16
    dig 2
    len
    dig 4
    frame_dig -1
    -
    intc_1 // 1
    -
    dig 1
    uncover 3
    uncover 2
    select
    dup
    dig 3
    -
    cover 5
    frame_dig -2
    len
    cover 5
    dig 3
    intc_0 // 0
    uncover 4
    substring3
    frame_dig -2
    concat
    uncover 3
    uncover 2
    uncover 3
    substring3
    concat
    swap
    intc_2 // 2
    *

dynamic_array_replace_dynamic_element_for_header@2:
    frame_dig 1
    frame_dig 5
    <
    bz dynamic_array_replace_dynamic_element_after_for@5
    frame_dig 4
    dup
    frame_dig 1
    dup
    cover 3
    extract_uint16
    frame_dig 3
    +
    frame_dig 2
    -
    itob
    extract 6 2
    dig 2
    swap
    replace3
    frame_bury 4
    intc_2 // 2
    +
    frame_bury 1
    b dynamic_array_replace_dynamic_element_for_header@2

dynamic_array_replace_dynamic_element_after_for@5:
    frame_dig 0
    frame_dig 4
    concat
    frame_bury 0
    retsub


// tests.artifacts.StateMutations.statemutations.StateMutations.append[routing]() -> void:
append:
    // tests/artifacts/StateMutations/statemutations.py:42
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    bytec 6 // 0x00020000000000000001000a000362617a
    callsub dynamic_array_concat_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:45
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:46
    // self.no_proxy.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:47
    // self.glob.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:48
    // self.loc[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:49
    // self.box.value.append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    intc_0 // 0
    extract_uint16
    swap
    extract 2 0
    intc_1 // 1
    // tests/artifacts/StateMutations/statemutations.py:43
    // arr.append(struct.copy())
    bytec 6 // 0x00020000000000000001000a000362617a
    // tests/artifacts/StateMutations/statemutations.py:50
    // self.map[Txn.sender].append(struct.copy())
    callsub dynamic_array_concat_dynamic_element
    dig 1
    box_del
    pop
    box_put
    // tests/artifacts/StateMutations/statemutations.py:39
    // @arc4.abimethod
    intc_1 // 1
    return


// tests.artifacts.StateMutations.statemutations.StateMutations.modify[routing]() -> void:
modify:
    // tests/artifacts/StateMutations/statemutations.py:56
    // arr = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:57
    // arr[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    // tests/artifacts/StateMutations/statemutations.py:58
    // self.glob_assign.value = arr.copy()
    bytec_3 // "glob_assign"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:60
    // self.no_proxy[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_1 // "no_proxy"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:61
    // self.glob.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 4 // "glob"
    swap
    app_global_put
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    txn Sender
    dup
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:62
    // self.loc[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec 5 // "loc"
    swap
    app_local_put
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:63
    // self.box.value[0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    bytec_0 // "box"
    box_del
    pop
    bytec_0 // "box"
    swap
    box_put
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    bytec 8 // "map"
    txn Sender
    concat
    dup
    box_get
    assert // check self.map entry exists
    dup
    extract 2 0
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_0 // 0
    extract_uint16
    dig 1
    intc_1 // 1
    - // on error: index access is out of bounds
    dig 3
    len
    dig 4
    intc_2 // 2
    extract_uint16
    uncover 2
    select
    uncover 3
    cover 2
    substring3
    dup
    intc_3 // 8
    extract_uint16
    intc_0 // 0
    swap
    extract3
    // tests/artifacts/StateMutations/statemutations.py:54
    // modified = arc4.String("modified")
    bytec 7 // 0x00086d6f646966696564
    // tests/artifacts/StateMutations/statemutations.py:64
    // self.map[Txn.sender][0].baz = modified
    concat
    swap
    assert // index access is out of bounds
    intc_0 // 0
    callsub dynamic_array_replace_dynamic_element
    dig 1
    box_del
    pop
    box_put
    // tests/artifacts/StateMutations/statemutations.py:52
    // @arc4.abimethod
    intc_1 // 1
    return


// tests.artifacts.StateMutations.statemutations.StateMutations.get[routing]() -> void:
get:
    // tests/artifacts/StateMutations/statemutations.py:68
    // a0 = self.no_proxy.copy()
    intc_0 // 0
    bytec_1 // "no_proxy"
    app_global_get_ex
    assert // check self.no_proxy exists
    // tests/artifacts/StateMutations/statemutations.py:69
    // a1 = self.glob_assign.value.copy()
    intc_0 // 0
    bytec_3 // "glob_assign"
    app_global_get_ex
    assert // check self.glob_assign exists
    // tests/artifacts/StateMutations/statemutations.py:70
    // a2 = self.glob.value.copy()
    intc_0 // 0
    bytec 4 // "glob"
    app_global_get_ex
    assert // check self.glob exists
    // tests/artifacts/StateMutations/statemutations.py:71
    // a3 = self.loc[Txn.sender].copy()
    txn Sender
    intc_0 // 0
    bytec 5 // "loc"
    app_local_get_ex
    assert // check self.loc exists for account
    // tests/artifacts/StateMutations/statemutations.py:72
    // a4 = self.box.value.copy()
    bytec_0 // "box"
    box_get
    assert // check self.box exists
    // tests/artifacts/StateMutations/statemutations.py:73
    // a5 = self.map[Txn.sender].copy()
    bytec 8 // "map"
    txn Sender
    concat
    box_get
    assert // check self.map entry exists
    // tests/artifacts/StateMutations/statemutations.py:75
    // assert a0 == a1, "expected global assign == no_proxy"
    dig 5
    uncover 5
    ==
    assert // expected global assign == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:76
    // assert a0 == a2, "expected global == no_proxy"
    dig 4
    uncover 4
    ==
    assert // expected global == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:77
    // assert a0 == a3, "expected local == no_proxy"
    dig 3
    uncover 3
    ==
    assert // expected local == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:78
    // assert a0 == a4, "expected box == no_proxy"
    dig 2
    uncover 2
    ==
    assert // expected box == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:79
    // assert a0 == a5, "expected map == no_proxy"
    dig 1
    ==
    assert // expected map == no_proxy
    // tests/artifacts/StateMutations/statemutations.py:66
    // @arc4.abimethod
    pushbytes 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAEAAECCCYJA2JveAhub19wcm94eQIAAAtnbG9iX2Fzc2lnbgRnbG9iA2xvYxEAAgAAAAAAAAABAAoAA2JhegoACG1vZGlmaWVkA21hcDEYQAADKSpnMRtBAEuCAwRSbou/BJX+8T0EDClESzYaAI4DACMAFwACIkMxGRREMRhEiAM1gAQVH3x1TFCwI0MxGRREMRhEiAHSI0MxGRREMRhEiAE+I0MxGY0CAAsAA0L/xjEYRIgBDSNDMRgURCNDigQBgABJi/4kC4v8JAsiiwSLAwxBAByL/YsESU4CWYsCCBZXBgKLAUxQjAEkCIwEQv/ci/0VjAAijASLBIsCDEEAHIv/iwRJTgJZiwAIFlcGAosBTFCMASQIjARC/9yL/Iv+CBZXBgKLAVCL/YsDiwBSUIv/FYv/iwJPAlJQjACJigMBi/1RAAJJF4v9VwIAi/8kC0sBTFmL/yMIJAtJTgRLAkxZSwIVSwSL/wkjCUsBTwNPAk1JSwMJTgWL/hVOBUsDIk8EUov+UE8DTwJPA1JQTCQLiwGLBQxBACCLBEmLAUlOA1mLAwiLAgkWVwYCSwJMXYwEJAiMAUL/2IsAiwRQjACJKypnJwQqZyi8SCgqvzEAJwUqZicIMQBQSbxIKr+JIitlREkiWUxXAgAjJwaI/swrTGciKWVESSJZTFcCACMnBoj+uClMZyInBGVESSJZTFcCACMnBoj+oycETGcxAEkiJwVjREkiWUxXAgAjJwaI/oonBUxmKL5ESSJZTFcCACMnBoj+dii8SChMvycIMQBQSb5ESSJZTFcCACMnBoj+W0sBvEi/iSIrZURJVwIASwEiWUsBIllLASMJSwMVSwQkWU8CTU8DTgJSSSVZIkxYJwdQTEQiiP6kK0xnIillRElXAgBLASJZSwEiWUsBIwlLAxVLBCRZTwJNTwNOAlJJJVkiTFgnB1BMRCKI/m8pTGciJwRlRElXAgBLASJZSwEiWUsBIwlLAxVLBCRZTwJNTwNOAlJJJVkiTFgnB1BMRCKI/jknBExnMQBJIicFY0RJVwIASwEiWUsBIllLASMJSwMVSwQkWU8CTU8DTgJSSSVZIkxYJwdQTEQiiP3/JwVMZii+RElXAgBLASJZSwEiWUsBIwlLAxVLBCRZTwJNTwNOAlJJJVkiTFgnB1BMRCKI/coovEgoTL8nCDEAUEm+RElXAgBLASJZSwEiWUsBIwlLAxVLBCRZTwJNTwNOAlJJJVkiTFgnB1BMRCKI/Y5LAbxIv4kiKWVEIitlRCInBGVEMQAiJwVjRCi+RCcIMQBQvkRLBU8FEkRLBE8EEkRLA08DEkRLAk8CEkRLARJEiQ==", + "approval": "CiAEAAECCCYJA2JveAhub19wcm94eQIAAAtnbG9iX2Fzc2lnbgRnbG9iA2xvYxEAAgAAAAAAAAABAAoAA2JhegoACG1vZGlmaWVkA21hcDEYQAADKSpnMRtBACQxGRREMRhEggMEUm6LvwSV/vE9BAwpREs2GgCOAwE1Ab4DDQAxGY0CACMAAQAxGEQrKmcnBCpnKLxIKCq/MQAnBSpmJwgxAFBJvEgqvyNDMRgUQ4oEAYAASYv+JAuL/CQLIosEiwMMQQAci/2LBElOAlmLAggWVwYCiwFMUIwBJAiMBEL/3Iv9FYwAIowEiwSLAgxBAByL/4sESU4CWYsACBZXBgKLAUxQjAEkCIwEQv/ci/yL/ggWVwYCiwFQi/2LA4sAUlCL/xWL/4sCTwJSUIwAiYoDAYv9UQACSReL/VcCAIv/JAtLAUxZi/8jCCQLSU4ESwJMWUsCFUsEi/8JIwlLAU8DTwJNSUsDCU4Fi/4VTgVLAyJPBFKL/lBPA08CTwNSUEwkC4sBiwUMQQAgiwRJiwFJTgNZiwMIiwIJFlcGAksCTF2MBCQIjAFC/9iLAIsEUIwAiSIrZURJIllMVwIAIycGiP7qK0xnIillREkiWUxXAgAjJwaI/tYpTGciJwRlREkiWUxXAgAjJwaI/sEnBExnMQBJIicFY0RJIllMVwIAIycGiP6oJwVMZii+REkiWUxXAgAjJwaI/pQovEgoTL8nCDEAUEm+REkiWUxXAgAjJwaI/nlLAbxIvyNDIitlRElXAgBLASJZSwEiWUsBIwlLAxVLBCRZTwJNTwNOAlJJJVkiTFgnB1BMRCKI/sErTGciKWVESVcCAEsBIllLASJZSwEjCUsDFUsEJFlPAk1PA04CUkklWSJMWCcHUExEIoj+jClMZyInBGVESVcCAEsBIllLASJZSwEjCUsDFUsEJFlPAk1PA04CUkklWSJMWCcHUExEIoj+VicETGcxAEkiJwVjRElXAgBLASJZSwEiWUsBIwlLAxVLBCRZTwJNTwNOAlJJJVkiTFgnB1BMRCKI/hwnBUxmKL5ESVcCAEsBIllLASJZSwEjCUsDFUsEJFlPAk1PA04CUkklWSJMWCcHUExEIoj95yi8SChMvycIMQBQSb5ESVcCAEsBIllLASJZSwEjCUsDFUsEJFlPAk1PA04CUkklWSJMWCcHUExEIoj9q0sBvEi/I0MiKWVEIitlRCInBGVEMQAiJwVjRCi+RCcIMQBQvkRLBU8FEkRLBE8EEkRLA08DEkRLAk8CEkRLARJEgAQVH3x1TFCwI0M=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/GlobalStateContract.approval.teal b/tests/artifacts/StateOps/data/GlobalStateContract.approval.teal index 26c1c54..7fd4aef 100644 --- a/tests/artifacts/StateOps/data/GlobalStateContract.approval.teal +++ b/tests/artifacts/StateOps/data/GlobalStateContract.approval.teal @@ -3,74 +3,74 @@ // tests.artifacts.StateOps.contract.GlobalStateContract.__algopy_entrypoint_with_init() -> uint64: main: - intcblock 1 0 8 80 - bytecblock 0x151f7c75 0x00 "implicit_key_arc4_uint" "implicit_key_arc4_string" "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" "implicit_key_arc4_dynamic_bytes" "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" 0x0000000000000539 0x000548656c6c6f 0x00000010000000000000000000000000 0x000d64796e616d6963206279746573 0x000b + intcblock 1 0 + bytecblock 0x151f7c75 "implicit_key_arc4_uint" "implicit_key_arc4_string" "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" "implicit_key_arc4_dynamic_bytes" "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" 0x0000000000000539 0x000548656c6c6f 0x00000010000000000000000000000000 0x000d64796e616d6963206279746573 txn ApplicationID bnz main_after_if_else@2 // tests/artifacts/StateOps/contract.py:515-516 // # Implicit key state variables // self.implicit_key_arc4_uint = GlobalState(arc4.UInt64(1337)) - bytec_2 // "implicit_key_arc4_uint" - bytec 17 // 0x0000000000000539 + bytec_1 // "implicit_key_arc4_uint" + bytec 16 // 0x0000000000000539 app_global_put // tests/artifacts/StateOps/contract.py:517 // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello")) - bytec_3 // "implicit_key_arc4_string" - bytec 18 // 0x000548656c6c6f + bytec_2 // "implicit_key_arc4_string" + bytec 17 // 0x000548656c6c6f app_global_put // tests/artifacts/StateOps/contract.py:518 // self.implicit_key_arc4_byte = GlobalState(arc4.Byte(0)) - bytec 4 // "implicit_key_arc4_byte" - bytec_1 // 0x00 + bytec_3 // "implicit_key_arc4_byte" + pushbytes 0x00 app_global_put // tests/artifacts/StateOps/contract.py:519 // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True)) - bytec 5 // "implicit_key_arc4_bool" + bytec 4 // "implicit_key_arc4_bool" pushbytes 0x80 app_global_put // tests/artifacts/StateOps/contract.py:520 // self.implicit_key_arc4_address = GlobalState(arc4.Address(Global.creator_address)) - bytec 6 // "implicit_key_arc4_address" + bytec 5 // "implicit_key_arc4_address" global CreatorAddress app_global_put // tests/artifacts/StateOps/contract.py:521 // self.implicit_key_arc4_uint128 = GlobalState(arc4.UInt128(2**100)) - bytec 7 // "implicit_key_arc4_uint128" - bytec 19 // 0x00000010000000000000000000000000 + bytec 6 // "implicit_key_arc4_uint128" + bytec 18 // 0x00000010000000000000000000000000 app_global_put // tests/artifacts/StateOps/contract.py:522 // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes")) - bytec 8 // "implicit_key_arc4_dynamic_bytes" - bytec 20 // 0x000d64796e616d6963206279746573 + bytec 7 // "implicit_key_arc4_dynamic_bytes" + bytec 19 // 0x000d64796e616d6963206279746573 app_global_put // tests/artifacts/StateOps/contract.py:523 // self.implicit_key_tuple = GlobalState((UInt64(10), Bytes(b"test"), False)) - bytec 9 // "implicit_key_tuple" + bytec 8 // "implicit_key_tuple" pushbytes 0x000000000000000a000b00000474657374 app_global_put // tests/artifacts/StateOps/contract.py:525-526 // # Explicit key state variables // self.arc4_uint = GlobalState(arc4.UInt64(1337), key="explicit_key_arc4_uint") - bytec 10 // "explicit_key_arc4_uint" - bytec 17 // 0x0000000000000539 + bytec 9 // "explicit_key_arc4_uint" + bytec 16 // 0x0000000000000539 app_global_put // tests/artifacts/StateOps/contract.py:527 // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string") - bytec 11 // "explicit_key_arc4_string" + bytec 10 // "explicit_key_arc4_string" // tests/artifacts/StateOps/contract.py:517 // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello")) - bytec 18 // 0x000548656c6c6f + bytec 17 // 0x000548656c6c6f // tests/artifacts/StateOps/contract.py:527 // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string") app_global_put // tests/artifacts/StateOps/contract.py:528 // self.arc4_byte = GlobalState(arc4.Byte(0), key="explicit_key_arc4_byte") - bytec 12 // "explicit_key_arc4_byte" - bytec_1 // 0x00 + bytec 11 // "explicit_key_arc4_byte" + pushbytes 0x00 app_global_put // tests/artifacts/StateOps/contract.py:529 // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool") - bytec 13 // "explicit_key_arc4_bool" + bytec 12 // "explicit_key_arc4_bool" // tests/artifacts/StateOps/contract.py:519 // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True)) pushbytes 0x80 @@ -79,7 +79,7 @@ main: app_global_put // tests/artifacts/StateOps/contract.py:531 // arc4.Address(Global.creator_address), key="explicit_key_arc4_address" - bytec 14 // "explicit_key_arc4_address" + bytec 13 // "explicit_key_arc4_address" global CreatorAddress // tests/artifacts/StateOps/contract.py:530-532 // self.arc4_address = GlobalState( @@ -88,15 +88,15 @@ main: app_global_put // tests/artifacts/StateOps/contract.py:533 // self.arc4_uint128 = GlobalState(arc4.UInt128(2**100), key="explicit_key_arc4_uint128") - bytec 15 // "explicit_key_arc4_uint128" - bytec 19 // 0x00000010000000000000000000000000 + bytec 14 // "explicit_key_arc4_uint128" + bytec 18 // 0x00000010000000000000000000000000 app_global_put // tests/artifacts/StateOps/contract.py:535 // arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes" - bytec 16 // "explicit_key_arc4_dynamic_bytes" + bytec 15 // "explicit_key_arc4_dynamic_bytes" // tests/artifacts/StateOps/contract.py:522 // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes")) - bytec 20 // 0x000d64796e616d6963206279746573 + bytec 19 // 0x000d64796e616d6963206279746573 // tests/artifacts/StateOps/contract.py:534-536 // self.arc4_dynamic_bytes = GlobalState( // arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes" @@ -107,968 +107,552 @@ main_after_if_else@2: // tests/artifacts/StateOps/contract.py:513 // class GlobalStateContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@35 - pushbytess 0x1cc966ee 0x2367cd4b 0x69128e90 0x68d590e2 0x44ef0681 0x1cd294ec 0xaac8ecb1 0x166c6afd 0x3cc3bb7b 0x9a6946ad 0xded75033 0x66279e93 0x096e927b 0x97531fbc 0x6ea3f996 0xa7f4f402 0xaaddcc4c 0x5ec3116d 0x20f56eee 0x1c149a43 0xa575ac7d 0x87f0869b 0x461afc6d 0x048116ea 0x30e34a93 0xd2e646ef 0xe674a270 0xa87e540d 0x720a3ca0 0x257708f7 // method "get_implicit_key_arc4_uint()uint64", method "get_implicit_key_arc4_string()string", method "get_implicit_key_arc4_byte()byte", method "get_implicit_key_arc4_bool()bool", method "get_implicit_key_arc4_address()address", method "get_implicit_key_arc4_uint128()uint128", method "get_implicit_key_arc4_dynamic_bytes()byte[]", method "get_implicit_key_tuple()(uint64,byte[],bool)", method "get_arc4_uint()uint64", method "get_arc4_string()string", method "get_arc4_byte()byte", method "get_arc4_bool()bool", method "get_arc4_address()address", method "get_arc4_uint128()uint128", method "get_arc4_dynamic_bytes()byte[]", method "set_implicit_key_arc4_uint(uint64)void", method "set_implicit_key_arc4_string(string)void", method "set_implicit_key_arc4_byte(byte)void", method "set_implicit_key_arc4_bool(bool)void", method "set_implicit_key_arc4_address(address)void", method "set_implicit_key_arc4_uint128(uint128)void", method "set_implicit_key_arc4_dynamic_bytes(byte[])void", method "set_implicit_key_tuple((uint64,byte[],bool))void", method "set_arc4_uint(uint64)void", method "set_arc4_string(string)void", method "set_arc4_byte(byte)void", method "set_arc4_bool(bool)void", method "set_arc4_address(address)void", method "set_arc4_uint128(uint128)void", method "set_arc4_dynamic_bytes(byte[])void" - txna ApplicationArgs 0 - match main_get_implicit_key_arc4_uint_route@5 main_get_implicit_key_arc4_string_route@6 main_get_implicit_key_arc4_byte_route@7 main_get_implicit_key_arc4_bool_route@8 main_get_implicit_key_arc4_address_route@9 main_get_implicit_key_arc4_uint128_route@10 main_get_implicit_key_arc4_dynamic_bytes_route@11 main_get_implicit_key_tuple_route@12 main_get_arc4_uint_route@13 main_get_arc4_string_route@14 main_get_arc4_byte_route@15 main_get_arc4_bool_route@16 main_get_arc4_address_route@17 main_get_arc4_uint128_route@18 main_get_arc4_dynamic_bytes_route@19 main_set_implicit_key_arc4_uint_route@20 main_set_implicit_key_arc4_string_route@21 main_set_implicit_key_arc4_byte_route@22 main_set_implicit_key_arc4_bool_route@23 main_set_implicit_key_arc4_address_route@24 main_set_implicit_key_arc4_uint128_route@25 main_set_implicit_key_arc4_dynamic_bytes_route@26 main_set_implicit_key_tuple_route@27 main_set_arc4_uint_route@28 main_set_arc4_string_route@29 main_set_arc4_byte_route@30 main_set_arc4_bool_route@31 main_set_arc4_address_route@32 main_set_arc4_uint128_route@33 main_set_arc4_dynamic_bytes_route@34 - -main_after_if_else@37: - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - intc_1 // 0 - return - -main_set_arc4_dynamic_bytes_route@34: - // tests/artifacts/StateOps/contract.py:658 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:658 - // @arc4.abimethod() - callsub set_arc4_dynamic_bytes - intc_0 // 1 - return - -main_set_arc4_uint128_route@33: - // tests/artifacts/StateOps/contract.py:654 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:654 - // @arc4.abimethod() - callsub set_arc4_uint128 - intc_0 // 1 - return - -main_set_arc4_address_route@32: - // tests/artifacts/StateOps/contract.py:650 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:650 - // @arc4.abimethod() - callsub set_arc4_address - intc_0 // 1 - return - -main_set_arc4_bool_route@31: - // tests/artifacts/StateOps/contract.py:646 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:646 - // @arc4.abimethod() - callsub set_arc4_bool - intc_0 // 1 - return - -main_set_arc4_byte_route@30: - // tests/artifacts/StateOps/contract.py:642 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:642 - // @arc4.abimethod() - callsub set_arc4_byte - intc_0 // 1 - return - -main_set_arc4_string_route@29: - // tests/artifacts/StateOps/contract.py:638 - // @arc4.abimethod() + bz main___algopy_default_create@37 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:638 - // @arc4.abimethod() - callsub set_arc4_string - intc_0 // 1 - return - -main_set_arc4_uint_route@28: - // tests/artifacts/StateOps/contract.py:633-634 - // # Setter methods for explicit key state variables - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:633-634 - // # Setter methods for explicit key state variables - // @arc4.abimethod() - callsub set_arc4_uint - intc_0 // 1 - return - -main_set_implicit_key_tuple_route@27: - // tests/artifacts/StateOps/contract.py:629 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - dup - intc_1 // 0 - extract_uint64 - dig 1 - intc_2 // 8 - extract_uint16 - dig 2 - len - dig 3 - cover 2 - substring3 - extract 2 0 - uncover 2 - intc_3 // 80 - getbit - // tests/artifacts/StateOps/contract.py:629 - // @arc4.abimethod() - callsub set_implicit_key_tuple - intc_0 // 1 - return - -main_set_implicit_key_arc4_dynamic_bytes_route@26: - // tests/artifacts/StateOps/contract.py:625 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:625 - // @arc4.abimethod() - callsub set_implicit_key_arc4_dynamic_bytes - intc_0 // 1 - return - -main_set_implicit_key_arc4_uint128_route@25: - // tests/artifacts/StateOps/contract.py:621 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:621 - // @arc4.abimethod() - callsub set_implicit_key_arc4_uint128 - intc_0 // 1 - return - -main_set_implicit_key_arc4_address_route@24: - // tests/artifacts/StateOps/contract.py:617 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:617 - // @arc4.abimethod() - callsub set_implicit_key_arc4_address - intc_0 // 1 - return - -main_set_implicit_key_arc4_bool_route@23: - // tests/artifacts/StateOps/contract.py:613 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:613 - // @arc4.abimethod() - callsub set_implicit_key_arc4_bool - intc_0 // 1 - return - -main_set_implicit_key_arc4_byte_route@22: - // tests/artifacts/StateOps/contract.py:609 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:609 - // @arc4.abimethod() - callsub set_implicit_key_arc4_byte - intc_0 // 1 - return - -main_set_implicit_key_arc4_string_route@21: - // tests/artifacts/StateOps/contract.py:605 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:605 - // @arc4.abimethod() - callsub set_implicit_key_arc4_string - intc_0 // 1 - return - -main_set_implicit_key_arc4_uint_route@20: - // tests/artifacts/StateOps/contract.py:600-601 - // # Setter methods for implicit key state variables - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): - txna ApplicationArgs 1 - // tests/artifacts/StateOps/contract.py:600-601 - // # Setter methods for implicit key state variables - // @arc4.abimethod() - callsub set_implicit_key_arc4_uint - intc_0 // 1 - return - -main_get_arc4_dynamic_bytes_route@19: - // tests/artifacts/StateOps/contract.py:596 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_arc4_dynamic_bytes - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_arc4_uint128_route@18: - // tests/artifacts/StateOps/contract.py:592 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_arc4_uint128 - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_arc4_address_route@17: - // tests/artifacts/StateOps/contract.py:588 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_arc4_address - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_arc4_bool_route@16: - // tests/artifacts/StateOps/contract.py:584 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_arc4_bool - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_arc4_byte_route@15: - // tests/artifacts/StateOps/contract.py:580 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_arc4_byte - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_arc4_string_route@14: - // tests/artifacts/StateOps/contract.py:576 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_arc4_string - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_arc4_uint_route@13: - // tests/artifacts/StateOps/contract.py:571-572 - // # Getter methods for explicit key state variables - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_arc4_uint - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_tuple_route@12: - // tests/artifacts/StateOps/contract.py:567 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_tuple - uncover 2 - itob - dig 2 - len - itob - extract 6 2 - uncover 3 - concat - swap - bytec 21 // 0x000b - concat - bytec_1 // 0x00 - intc_1 // 0 - uncover 4 - setbit - concat - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_arc4_dynamic_bytes_route@11: - // tests/artifacts/StateOps/contract.py:563 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_arc4_dynamic_bytes - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_arc4_uint128_route@10: - // tests/artifacts/StateOps/contract.py:559 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_arc4_uint128 - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_arc4_address_route@9: - // tests/artifacts/StateOps/contract.py:555 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_arc4_address - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_arc4_bool_route@8: - // tests/artifacts/StateOps/contract.py:551 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_arc4_bool - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_arc4_byte_route@7: - // tests/artifacts/StateOps/contract.py:547 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_arc4_byte - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_arc4_string_route@6: - // tests/artifacts/StateOps/contract.py:543 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_arc4_string - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_get_implicit_key_arc4_uint_route@5: - // tests/artifacts/StateOps/contract.py:538-539 - // # Getter methods for implicit key state variables - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - callsub get_implicit_key_arc4_uint - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + assert + pushbytess 0x1cc966ee 0x2367cd4b 0x69128e90 0x68d590e2 0x44ef0681 0x1cd294ec 0xaac8ecb1 0x166c6afd 0x3cc3bb7b 0x9a6946ad 0xded75033 0x66279e93 0x096e927b 0x97531fbc 0x6ea3f996 0xa7f4f402 0xaaddcc4c 0x5ec3116d 0x20f56eee 0x1c149a43 0xa575ac7d 0x87f0869b 0x461afc6d 0x048116ea 0x30e34a93 0xd2e646ef 0xe674a270 0xa87e540d 0x720a3ca0 0x257708f7 // method "get_implicit_key_arc4_uint()uint64", method "get_implicit_key_arc4_string()string", method "get_implicit_key_arc4_byte()byte", method "get_implicit_key_arc4_bool()bool", method "get_implicit_key_arc4_address()address", method "get_implicit_key_arc4_uint128()uint128", method "get_implicit_key_arc4_dynamic_bytes()byte[]", method "get_implicit_key_tuple()(uint64,byte[],bool)", method "get_arc4_uint()uint64", method "get_arc4_string()string", method "get_arc4_byte()byte", method "get_arc4_bool()bool", method "get_arc4_address()address", method "get_arc4_uint128()uint128", method "get_arc4_dynamic_bytes()byte[]", method "set_implicit_key_arc4_uint(uint64)void", method "set_implicit_key_arc4_string(string)void", method "set_implicit_key_arc4_byte(byte)void", method "set_implicit_key_arc4_bool(bool)void", method "set_implicit_key_arc4_address(address)void", method "set_implicit_key_arc4_uint128(uint128)void", method "set_implicit_key_arc4_dynamic_bytes(byte[])void", method "set_implicit_key_tuple((uint64,byte[],bool))void", method "set_arc4_uint(uint64)void", method "set_arc4_string(string)void", method "set_arc4_byte(byte)void", method "set_arc4_bool(bool)void", method "set_arc4_address(address)void", method "set_arc4_uint128(uint128)void", method "set_arc4_dynamic_bytes(byte[])void" + txna ApplicationArgs 0 + match get_implicit_key_arc4_uint get_implicit_key_arc4_string get_implicit_key_arc4_byte get_implicit_key_arc4_bool get_implicit_key_arc4_address get_implicit_key_arc4_uint128 get_implicit_key_arc4_dynamic_bytes get_implicit_key_tuple get_arc4_uint get_arc4_string get_arc4_byte get_arc4_bool get_arc4_address get_arc4_uint128 get_arc4_dynamic_bytes set_implicit_key_arc4_uint set_implicit_key_arc4_string set_implicit_key_arc4_byte set_implicit_key_arc4_bool set_implicit_key_arc4_address set_implicit_key_arc4_uint128 set_implicit_key_arc4_dynamic_bytes set_implicit_key_tuple set_arc4_uint set_arc4_string set_arc4_byte set_arc4_bool set_arc4_address set_arc4_uint128 set_arc4_dynamic_bytes + err -main_bare_routing@35: - // tests/artifacts/StateOps/contract.py:513 - // class GlobalStateContract(ARC4Contract): +main___algopy_default_create@37: txn OnCompletion - bnz main_after_if_else@37 + ! txn ApplicationID ! - assert // can only call when creating - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint[routing]() -> void: get_implicit_key_arc4_uint: // tests/artifacts/StateOps/contract.py:541 // return self.implicit_key_arc4_uint.value intc_1 // 0 - bytec_2 // "implicit_key_arc4_uint" + bytec_1 // "implicit_key_arc4_uint" app_global_get_ex assert // check self.implicit_key_arc4_uint exists - retsub + // tests/artifacts/StateOps/contract.py:538-539 + // # Getter methods for implicit key state variables + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_string() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_string[routing]() -> void: get_implicit_key_arc4_string: // tests/artifacts/StateOps/contract.py:545 // return self.implicit_key_arc4_string.value intc_1 // 0 - bytec_3 // "implicit_key_arc4_string" + bytec_2 // "implicit_key_arc4_string" app_global_get_ex assert // check self.implicit_key_arc4_string exists - retsub + // tests/artifacts/StateOps/contract.py:543 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_byte() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_byte[routing]() -> void: get_implicit_key_arc4_byte: // tests/artifacts/StateOps/contract.py:549 // return self.implicit_key_arc4_byte.value intc_1 // 0 - bytec 4 // "implicit_key_arc4_byte" + bytec_3 // "implicit_key_arc4_byte" app_global_get_ex assert // check self.implicit_key_arc4_byte exists - retsub + // tests/artifacts/StateOps/contract.py:547 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_bool() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_bool[routing]() -> void: get_implicit_key_arc4_bool: // tests/artifacts/StateOps/contract.py:553 // return self.implicit_key_arc4_bool.value intc_1 // 0 - bytec 5 // "implicit_key_arc4_bool" + bytec 4 // "implicit_key_arc4_bool" app_global_get_ex assert // check self.implicit_key_arc4_bool exists - retsub + // tests/artifacts/StateOps/contract.py:551 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_address() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_address[routing]() -> void: get_implicit_key_arc4_address: // tests/artifacts/StateOps/contract.py:557 // return self.implicit_key_arc4_address.value intc_1 // 0 - bytec 6 // "implicit_key_arc4_address" + bytec 5 // "implicit_key_arc4_address" app_global_get_ex assert // check self.implicit_key_arc4_address exists - retsub + // tests/artifacts/StateOps/contract.py:555 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint128() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint128[routing]() -> void: get_implicit_key_arc4_uint128: // tests/artifacts/StateOps/contract.py:561 // return self.implicit_key_arc4_uint128.value intc_1 // 0 - bytec 7 // "implicit_key_arc4_uint128" + bytec 6 // "implicit_key_arc4_uint128" app_global_get_ex assert // check self.implicit_key_arc4_uint128 exists - retsub + // tests/artifacts/StateOps/contract.py:559 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_dynamic_bytes() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_dynamic_bytes[routing]() -> void: get_implicit_key_arc4_dynamic_bytes: // tests/artifacts/StateOps/contract.py:565 // return self.implicit_key_arc4_dynamic_bytes.value intc_1 // 0 - bytec 8 // "implicit_key_arc4_dynamic_bytes" + bytec 7 // "implicit_key_arc4_dynamic_bytes" app_global_get_ex assert // check self.implicit_key_arc4_dynamic_bytes exists - retsub + // tests/artifacts/StateOps/contract.py:563 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_tuple() -> uint64, bytes, uint64: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_tuple[routing]() -> void: get_implicit_key_tuple: // tests/artifacts/StateOps/contract.py:569 // return self.implicit_key_tuple.value intc_1 // 0 - bytec 9 // "implicit_key_tuple" + bytec 8 // "implicit_key_tuple" app_global_get_ex assert // check self.implicit_key_tuple exists - dup - intc_1 // 0 - extract_uint64 - dig 1 - intc_2 // 8 - extract_uint16 - dig 2 - len - dig 3 - cover 2 - substring3 - extract 2 0 - uncover 2 - intc_3 // 80 - getbit - retsub + // tests/artifacts/StateOps/contract.py:567 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint[routing]() -> void: get_arc4_uint: // tests/artifacts/StateOps/contract.py:574 // return self.arc4_uint.value intc_1 // 0 - bytec 10 // "explicit_key_arc4_uint" + bytec 9 // "explicit_key_arc4_uint" app_global_get_ex assert // check self.arc4_uint exists - retsub + // tests/artifacts/StateOps/contract.py:571-572 + // # Getter methods for explicit key state variables + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_string() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_string[routing]() -> void: get_arc4_string: // tests/artifacts/StateOps/contract.py:578 // return self.arc4_string.value intc_1 // 0 - bytec 11 // "explicit_key_arc4_string" + bytec 10 // "explicit_key_arc4_string" app_global_get_ex assert // check self.arc4_string exists - retsub + // tests/artifacts/StateOps/contract.py:576 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_byte() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_byte[routing]() -> void: get_arc4_byte: // tests/artifacts/StateOps/contract.py:582 // return self.arc4_byte.value intc_1 // 0 - bytec 12 // "explicit_key_arc4_byte" + bytec 11 // "explicit_key_arc4_byte" app_global_get_ex assert // check self.arc4_byte exists - retsub + // tests/artifacts/StateOps/contract.py:580 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_bool() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_bool[routing]() -> void: get_arc4_bool: // tests/artifacts/StateOps/contract.py:586 // return self.arc4_bool.value intc_1 // 0 - bytec 13 // "explicit_key_arc4_bool" + bytec 12 // "explicit_key_arc4_bool" app_global_get_ex assert // check self.arc4_bool exists - retsub + // tests/artifacts/StateOps/contract.py:584 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_address() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_address[routing]() -> void: get_arc4_address: // tests/artifacts/StateOps/contract.py:590 // return self.arc4_address.value intc_1 // 0 - bytec 14 // "explicit_key_arc4_address" + bytec 13 // "explicit_key_arc4_address" app_global_get_ex assert // check self.arc4_address exists - retsub + // tests/artifacts/StateOps/contract.py:588 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint128() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint128[routing]() -> void: get_arc4_uint128: // tests/artifacts/StateOps/contract.py:594 // return self.arc4_uint128.value intc_1 // 0 - bytec 15 // "explicit_key_arc4_uint128" + bytec 14 // "explicit_key_arc4_uint128" app_global_get_ex assert // check self.arc4_uint128 exists - retsub + // tests/artifacts/StateOps/contract.py:592 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_dynamic_bytes() -> bytes: +// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_dynamic_bytes[routing]() -> void: get_arc4_dynamic_bytes: // tests/artifacts/StateOps/contract.py:598 // return self.arc4_dynamic_bytes.value intc_1 // 0 - bytec 16 // "explicit_key_arc4_dynamic_bytes" + bytec 15 // "explicit_key_arc4_dynamic_bytes" app_global_get_ex assert // check self.arc4_dynamic_bytes exists - retsub + // tests/artifacts/StateOps/contract.py:596 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint[routing]() -> void: set_implicit_key_arc4_uint: - // tests/artifacts/StateOps/contract.py:600-602 + // tests/artifacts/StateOps/contract.py:603 + // self.implicit_key_arc4_uint.value = value + bytec_1 // "implicit_key_arc4_uint" + // tests/artifacts/StateOps/contract.py:600-601 // # Setter methods for implicit key state variables // @arc4.abimethod() - // def set_implicit_key_arc4_uint(self, value: arc4.UInt64) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:603 // self.implicit_key_arc4_uint.value = value - bytec_2 // "implicit_key_arc4_uint" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:600-601 + // # Setter methods for implicit key state variables + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_string(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_string[routing]() -> void: set_implicit_key_arc4_string: - // tests/artifacts/StateOps/contract.py:605-606 + // tests/artifacts/StateOps/contract.py:607 + // self.implicit_key_arc4_string.value = value + bytec_2 // "implicit_key_arc4_string" + // tests/artifacts/StateOps/contract.py:605 // @arc4.abimethod() - // def set_implicit_key_arc4_string(self, value: arc4.String) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:607 // self.implicit_key_arc4_string.value = value - bytec_3 // "implicit_key_arc4_string" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:605 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_byte(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_byte[routing]() -> void: set_implicit_key_arc4_byte: - // tests/artifacts/StateOps/contract.py:609-610 + // tests/artifacts/StateOps/contract.py:611 + // self.implicit_key_arc4_byte.value = value + bytec_3 // "implicit_key_arc4_byte" + // tests/artifacts/StateOps/contract.py:609 // @arc4.abimethod() - // def set_implicit_key_arc4_byte(self, value: arc4.Byte) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:611 // self.implicit_key_arc4_byte.value = value - bytec 4 // "implicit_key_arc4_byte" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:609 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_bool(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_bool[routing]() -> void: set_implicit_key_arc4_bool: - // tests/artifacts/StateOps/contract.py:613-614 + // tests/artifacts/StateOps/contract.py:615 + // self.implicit_key_arc4_bool.value = value + bytec 4 // "implicit_key_arc4_bool" + // tests/artifacts/StateOps/contract.py:613 // @arc4.abimethod() - // def set_implicit_key_arc4_bool(self, value: arc4.Bool) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:615 // self.implicit_key_arc4_bool.value = value - bytec 5 // "implicit_key_arc4_bool" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:613 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_address(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_address[routing]() -> void: set_implicit_key_arc4_address: - // tests/artifacts/StateOps/contract.py:617-618 + // tests/artifacts/StateOps/contract.py:619 + // self.implicit_key_arc4_address.value = value + bytec 5 // "implicit_key_arc4_address" + // tests/artifacts/StateOps/contract.py:617 // @arc4.abimethod() - // def set_implicit_key_arc4_address(self, value: arc4.Address) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:619 // self.implicit_key_arc4_address.value = value - bytec 6 // "implicit_key_arc4_address" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:617 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint128(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint128[routing]() -> void: set_implicit_key_arc4_uint128: - // tests/artifacts/StateOps/contract.py:621-622 + // tests/artifacts/StateOps/contract.py:623 + // self.implicit_key_arc4_uint128.value = value + bytec 6 // "implicit_key_arc4_uint128" + // tests/artifacts/StateOps/contract.py:621 // @arc4.abimethod() - // def set_implicit_key_arc4_uint128(self, value: arc4.UInt128) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:623 // self.implicit_key_arc4_uint128.value = value - bytec 7 // "implicit_key_arc4_uint128" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:621 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_dynamic_bytes(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_dynamic_bytes[routing]() -> void: set_implicit_key_arc4_dynamic_bytes: - // tests/artifacts/StateOps/contract.py:625-626 + // tests/artifacts/StateOps/contract.py:627 + // self.implicit_key_arc4_dynamic_bytes.value = value.copy() + bytec 7 // "implicit_key_arc4_dynamic_bytes" + // tests/artifacts/StateOps/contract.py:625 // @arc4.abimethod() - // def set_implicit_key_arc4_dynamic_bytes(self, value: arc4.DynamicBytes) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:627 // self.implicit_key_arc4_dynamic_bytes.value = value.copy() - bytec 8 // "implicit_key_arc4_dynamic_bytes" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:625 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_tuple(value.0: uint64, value.1: bytes, value.2: uint64) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_tuple[routing]() -> void: set_implicit_key_tuple: - // tests/artifacts/StateOps/contract.py:629-630 + // tests/artifacts/StateOps/contract.py:631 + // self.implicit_key_tuple.value = value + bytec 8 // "implicit_key_tuple" + // tests/artifacts/StateOps/contract.py:629 // @arc4.abimethod() - // def set_implicit_key_tuple(self, value: tuple[UInt64, Bytes, bool]) -> None: - proto 3 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:631 // self.implicit_key_tuple.value = value - frame_dig -3 - itob - frame_dig -2 - len - itob - extract 6 2 - frame_dig -2 - concat - swap - bytec 21 // 0x000b - concat - bytec_1 // 0x00 - intc_1 // 0 - frame_dig -1 - setbit - concat - swap - concat - bytec 9 // "implicit_key_tuple" - swap app_global_put - retsub + // tests/artifacts/StateOps/contract.py:629 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint[routing]() -> void: set_arc4_uint: - // tests/artifacts/StateOps/contract.py:633-635 + // tests/artifacts/StateOps/contract.py:636 + // self.arc4_uint.value = value + bytec 9 // "explicit_key_arc4_uint" + // tests/artifacts/StateOps/contract.py:633-634 // # Setter methods for explicit key state variables // @arc4.abimethod() - // def set_arc4_uint(self, value: arc4.UInt64) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:636 // self.arc4_uint.value = value - bytec 10 // "explicit_key_arc4_uint" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:633-634 + // # Setter methods for explicit key state variables + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_string(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_string[routing]() -> void: set_arc4_string: - // tests/artifacts/StateOps/contract.py:638-639 + // tests/artifacts/StateOps/contract.py:640 + // self.arc4_string.value = value + bytec 10 // "explicit_key_arc4_string" + // tests/artifacts/StateOps/contract.py:638 // @arc4.abimethod() - // def set_arc4_string(self, value: arc4.String) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:640 // self.arc4_string.value = value - bytec 11 // "explicit_key_arc4_string" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:638 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_byte(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_byte[routing]() -> void: set_arc4_byte: - // tests/artifacts/StateOps/contract.py:642-643 + // tests/artifacts/StateOps/contract.py:644 + // self.arc4_byte.value = value + bytec 11 // "explicit_key_arc4_byte" + // tests/artifacts/StateOps/contract.py:642 // @arc4.abimethod() - // def set_arc4_byte(self, value: arc4.Byte) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:644 // self.arc4_byte.value = value - bytec 12 // "explicit_key_arc4_byte" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:642 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_bool(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_bool[routing]() -> void: set_arc4_bool: - // tests/artifacts/StateOps/contract.py:646-647 + // tests/artifacts/StateOps/contract.py:648 + // self.arc4_bool.value = value + bytec 12 // "explicit_key_arc4_bool" + // tests/artifacts/StateOps/contract.py:646 // @arc4.abimethod() - // def set_arc4_bool(self, value: arc4.Bool) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:648 // self.arc4_bool.value = value - bytec 13 // "explicit_key_arc4_bool" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:646 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_address(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_address[routing]() -> void: set_arc4_address: - // tests/artifacts/StateOps/contract.py:650-651 + // tests/artifacts/StateOps/contract.py:652 + // self.arc4_address.value = value + bytec 13 // "explicit_key_arc4_address" + // tests/artifacts/StateOps/contract.py:650 // @arc4.abimethod() - // def set_arc4_address(self, value: arc4.Address) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:652 // self.arc4_address.value = value - bytec 14 // "explicit_key_arc4_address" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:650 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint128(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint128[routing]() -> void: set_arc4_uint128: - // tests/artifacts/StateOps/contract.py:654-655 + // tests/artifacts/StateOps/contract.py:656 + // self.arc4_uint128.value = value + bytec 14 // "explicit_key_arc4_uint128" + // tests/artifacts/StateOps/contract.py:654 // @arc4.abimethod() - // def set_arc4_uint128(self, value: arc4.UInt128) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:656 // self.arc4_uint128.value = value - bytec 15 // "explicit_key_arc4_uint128" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:654 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_dynamic_bytes(value: bytes) -> void: +// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_dynamic_bytes[routing]() -> void: set_arc4_dynamic_bytes: - // tests/artifacts/StateOps/contract.py:658-659 + // tests/artifacts/StateOps/contract.py:660 + // self.arc4_dynamic_bytes.value = value.copy() + bytec 15 // "explicit_key_arc4_dynamic_bytes" + // tests/artifacts/StateOps/contract.py:658 // @arc4.abimethod() - // def set_arc4_dynamic_bytes(self, value: arc4.DynamicBytes) -> None: - proto 1 0 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:660 // self.arc4_dynamic_bytes.value = value.copy() - bytec 16 // "explicit_key_arc4_dynamic_bytes" - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:658 + // @arc4.abimethod() + intc_0 // 1 + return diff --git a/tests/artifacts/StateOps/data/GlobalStateContract.arc32.json b/tests/artifacts/StateOps/data/GlobalStateContract.arc32.json index f7262b7..0280a1c 100644 --- a/tests/artifacts/StateOps/data/GlobalStateContract.arc32.json +++ b/tests/artifacts/StateOps/data/GlobalStateContract.arc32.json @@ -152,7 +152,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.GlobalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0 8 80
    bytecblock 0x151f7c75 0x00 "implicit_key_arc4_uint" "implicit_key_arc4_string" "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" "implicit_key_arc4_dynamic_bytes" "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" 0x0000000000000539 0x000548656c6c6f 0x00000010000000000000000000000000 0x000d64796e616d6963206279746573 0x000b
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateOps/contract.py:515-516
    // # Implicit key state variables
    // self.implicit_key_arc4_uint = GlobalState(arc4.UInt64(1337))
    bytec_2 // "implicit_key_arc4_uint"
    bytec 17 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec_3 // "implicit_key_arc4_string"
    bytec 18 // 0x000548656c6c6f
    app_global_put
    // tests/artifacts/StateOps/contract.py:518
    // self.implicit_key_arc4_byte = GlobalState(arc4.Byte(0))
    bytec 4 // "implicit_key_arc4_byte"
    bytec_1 // 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    bytec 5 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_global_put
    // tests/artifacts/StateOps/contract.py:520
    // self.implicit_key_arc4_address = GlobalState(arc4.Address(Global.creator_address))
    bytec 6 // "implicit_key_arc4_address"
    global CreatorAddress
    app_global_put
    // tests/artifacts/StateOps/contract.py:521
    // self.implicit_key_arc4_uint128 = GlobalState(arc4.UInt128(2**100))
    bytec 7 // "implicit_key_arc4_uint128"
    bytec 19 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 8 // "implicit_key_arc4_dynamic_bytes"
    bytec 20 // 0x000d64796e616d6963206279746573
    app_global_put
    // tests/artifacts/StateOps/contract.py:523
    // self.implicit_key_tuple = GlobalState((UInt64(10), Bytes(b"test"), False))
    bytec 9 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_global_put
    // tests/artifacts/StateOps/contract.py:525-526
    // # Explicit key state variables
    // self.arc4_uint = GlobalState(arc4.UInt64(1337), key="explicit_key_arc4_uint")
    bytec 10 // "explicit_key_arc4_uint"
    bytec 17 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    bytec 11 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec 18 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    app_global_put
    // tests/artifacts/StateOps/contract.py:528
    // self.arc4_byte = GlobalState(arc4.Byte(0), key="explicit_key_arc4_byte")
    bytec 12 // "explicit_key_arc4_byte"
    bytec_1 // 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    bytec 13 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    app_global_put
    // tests/artifacts/StateOps/contract.py:531
    // arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    bytec 14 // "explicit_key_arc4_address"
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:530-532
    // self.arc4_address = GlobalState(
    //     arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    // )
    app_global_put
    // tests/artifacts/StateOps/contract.py:533
    // self.arc4_uint128 = GlobalState(arc4.UInt128(2**100), key="explicit_key_arc4_uint128")
    bytec 15 // "explicit_key_arc4_uint128"
    bytec 19 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:535
    // arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    bytec 16 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 20 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:534-536
    // self.arc4_dynamic_bytes = GlobalState(
    //     arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    // )
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@35
    pushbytess 0x1cc966ee 0x2367cd4b 0x69128e90 0x68d590e2 0x44ef0681 0x1cd294ec 0xaac8ecb1 0x166c6afd 0x3cc3bb7b 0x9a6946ad 0xded75033 0x66279e93 0x096e927b 0x97531fbc 0x6ea3f996 0xa7f4f402 0xaaddcc4c 0x5ec3116d 0x20f56eee 0x1c149a43 0xa575ac7d 0x87f0869b 0x461afc6d 0x048116ea 0x30e34a93 0xd2e646ef 0xe674a270 0xa87e540d 0x720a3ca0 0x257708f7 // method "get_implicit_key_arc4_uint()uint64", method "get_implicit_key_arc4_string()string", method "get_implicit_key_arc4_byte()byte", method "get_implicit_key_arc4_bool()bool", method "get_implicit_key_arc4_address()address", method "get_implicit_key_arc4_uint128()uint128", method "get_implicit_key_arc4_dynamic_bytes()byte[]", method "get_implicit_key_tuple()(uint64,byte[],bool)", method "get_arc4_uint()uint64", method "get_arc4_string()string", method "get_arc4_byte()byte", method "get_arc4_bool()bool", method "get_arc4_address()address", method "get_arc4_uint128()uint128", method "get_arc4_dynamic_bytes()byte[]", method "set_implicit_key_arc4_uint(uint64)void", method "set_implicit_key_arc4_string(string)void", method "set_implicit_key_arc4_byte(byte)void", method "set_implicit_key_arc4_bool(bool)void", method "set_implicit_key_arc4_address(address)void", method "set_implicit_key_arc4_uint128(uint128)void", method "set_implicit_key_arc4_dynamic_bytes(byte[])void", method "set_implicit_key_tuple((uint64,byte[],bool))void", method "set_arc4_uint(uint64)void", method "set_arc4_string(string)void", method "set_arc4_byte(byte)void", method "set_arc4_bool(bool)void", method "set_arc4_address(address)void", method "set_arc4_uint128(uint128)void", method "set_arc4_dynamic_bytes(byte[])void"
    txna ApplicationArgs 0
    match main_get_implicit_key_arc4_uint_route@5 main_get_implicit_key_arc4_string_route@6 main_get_implicit_key_arc4_byte_route@7 main_get_implicit_key_arc4_bool_route@8 main_get_implicit_key_arc4_address_route@9 main_get_implicit_key_arc4_uint128_route@10 main_get_implicit_key_arc4_dynamic_bytes_route@11 main_get_implicit_key_tuple_route@12 main_get_arc4_uint_route@13 main_get_arc4_string_route@14 main_get_arc4_byte_route@15 main_get_arc4_bool_route@16 main_get_arc4_address_route@17 main_get_arc4_uint128_route@18 main_get_arc4_dynamic_bytes_route@19 main_set_implicit_key_arc4_uint_route@20 main_set_implicit_key_arc4_string_route@21 main_set_implicit_key_arc4_byte_route@22 main_set_implicit_key_arc4_bool_route@23 main_set_implicit_key_arc4_address_route@24 main_set_implicit_key_arc4_uint128_route@25 main_set_implicit_key_arc4_dynamic_bytes_route@26 main_set_implicit_key_tuple_route@27 main_set_arc4_uint_route@28 main_set_arc4_string_route@29 main_set_arc4_byte_route@30 main_set_arc4_bool_route@31 main_set_arc4_address_route@32 main_set_arc4_uint128_route@33 main_set_arc4_dynamic_bytes_route@34

main_after_if_else@37:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    intc_1 // 0
    return

main_set_arc4_dynamic_bytes_route@34:
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    callsub set_arc4_dynamic_bytes
    intc_0 // 1
    return

main_set_arc4_uint128_route@33:
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    callsub set_arc4_uint128
    intc_0 // 1
    return

main_set_arc4_address_route@32:
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    callsub set_arc4_address
    intc_0 // 1
    return

main_set_arc4_bool_route@31:
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    callsub set_arc4_bool
    intc_0 // 1
    return

main_set_arc4_byte_route@30:
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    callsub set_arc4_byte
    intc_0 // 1
    return

main_set_arc4_string_route@29:
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    callsub set_arc4_string
    intc_0 // 1
    return

main_set_arc4_uint_route@28:
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    callsub set_arc4_uint
    intc_0 // 1
    return

main_set_implicit_key_tuple_route@27:
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    dup
    intc_1 // 0
    extract_uint64
    dig 1
    intc_2 // 8
    extract_uint16
    dig 2
    len
    dig 3
    cover 2
    substring3
    extract 2 0
    uncover 2
    intc_3 // 80
    getbit
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    callsub set_implicit_key_tuple
    intc_0 // 1
    return

main_set_implicit_key_arc4_dynamic_bytes_route@26:
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_dynamic_bytes
    intc_0 // 1
    return

main_set_implicit_key_arc4_uint128_route@25:
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_uint128
    intc_0 // 1
    return

main_set_implicit_key_arc4_address_route@24:
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_address
    intc_0 // 1
    return

main_set_implicit_key_arc4_bool_route@23:
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_bool
    intc_0 // 1
    return

main_set_implicit_key_arc4_byte_route@22:
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_byte
    intc_0 // 1
    return

main_set_implicit_key_arc4_string_route@21:
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_string
    intc_0 // 1
    return

main_set_implicit_key_arc4_uint_route@20:
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_uint
    intc_0 // 1
    return

main_get_arc4_dynamic_bytes_route@19:
    // tests/artifacts/StateOps/contract.py:596
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_uint128_route@18:
    // tests/artifacts/StateOps/contract.py:592
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_address_route@17:
    // tests/artifacts/StateOps/contract.py:588
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_bool_route@16:
    // tests/artifacts/StateOps/contract.py:584
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_byte_route@15:
    // tests/artifacts/StateOps/contract.py:580
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_string_route@14:
    // tests/artifacts/StateOps/contract.py:576
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_uint_route@13:
    // tests/artifacts/StateOps/contract.py:571-572
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_tuple_route@12:
    // tests/artifacts/StateOps/contract.py:567
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_tuple
    uncover 2
    itob
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    bytec 21 // 0x000b
    concat
    bytec_1 // 0x00
    intc_1 // 0
    uncover 4
    setbit
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_dynamic_bytes_route@11:
    // tests/artifacts/StateOps/contract.py:563
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_uint128_route@10:
    // tests/artifacts/StateOps/contract.py:559
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_address_route@9:
    // tests/artifacts/StateOps/contract.py:555
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_bool_route@8:
    // tests/artifacts/StateOps/contract.py:551
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_byte_route@7:
    // tests/artifacts/StateOps/contract.py:547
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_string_route@6:
    // tests/artifacts/StateOps/contract.py:543
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_uint_route@5:
    // tests/artifacts/StateOps/contract.py:538-539
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@35:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@37
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint() -> bytes:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:541
    // return self.implicit_key_arc4_uint.value
    intc_1 // 0
    bytec_2 // "implicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_string() -> bytes:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:545
    // return self.implicit_key_arc4_string.value
    intc_1 // 0
    bytec_3 // "implicit_key_arc4_string"
    app_global_get_ex
    assert // check self.implicit_key_arc4_string exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_byte() -> bytes:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:549
    // return self.implicit_key_arc4_byte.value
    intc_1 // 0
    bytec 4 // "implicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.implicit_key_arc4_byte exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_bool() -> bytes:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:553
    // return self.implicit_key_arc4_bool.value
    intc_1 // 0
    bytec 5 // "implicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.implicit_key_arc4_bool exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_address() -> bytes:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:557
    // return self.implicit_key_arc4_address.value
    intc_1 // 0
    bytec 6 // "implicit_key_arc4_address"
    app_global_get_ex
    assert // check self.implicit_key_arc4_address exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint128() -> bytes:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:561
    // return self.implicit_key_arc4_uint128.value
    intc_1 // 0
    bytec 7 // "implicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint128 exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_dynamic_bytes() -> bytes:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:565
    // return self.implicit_key_arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 8 // "implicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_tuple() -> uint64, bytes, uint64:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:569
    // return self.implicit_key_tuple.value
    intc_1 // 0
    bytec 9 // "implicit_key_tuple"
    app_global_get_ex
    assert // check self.implicit_key_tuple exists
    dup
    intc_1 // 0
    extract_uint64
    dig 1
    intc_2 // 8
    extract_uint16
    dig 2
    len
    dig 3
    cover 2
    substring3
    extract 2 0
    uncover 2
    intc_3 // 80
    getbit
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint() -> bytes:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:574
    // return self.arc4_uint.value
    intc_1 // 0
    bytec 10 // "explicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.arc4_uint exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_string() -> bytes:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:578
    // return self.arc4_string.value
    intc_1 // 0
    bytec 11 // "explicit_key_arc4_string"
    app_global_get_ex
    assert // check self.arc4_string exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_byte() -> bytes:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:582
    // return self.arc4_byte.value
    intc_1 // 0
    bytec 12 // "explicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.arc4_byte exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_bool() -> bytes:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:586
    // return self.arc4_bool.value
    intc_1 // 0
    bytec 13 // "explicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.arc4_bool exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_address() -> bytes:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:590
    // return self.arc4_address.value
    intc_1 // 0
    bytec 14 // "explicit_key_arc4_address"
    app_global_get_ex
    assert // check self.arc4_address exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint128() -> bytes:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:594
    // return self.arc4_uint128.value
    intc_1 // 0
    bytec 15 // "explicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.arc4_uint128 exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_dynamic_bytes() -> bytes:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:598
    // return self.arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 16 // "explicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.arc4_dynamic_bytes exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint(value: bytes) -> void:
set_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:600-602
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    // def set_implicit_key_arc4_uint(self, value: arc4.UInt64) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:603
    // self.implicit_key_arc4_uint.value = value
    bytec_2 // "implicit_key_arc4_uint"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_string(value: bytes) -> void:
set_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:605-606
    // @arc4.abimethod()
    // def set_implicit_key_arc4_string(self, value: arc4.String) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:607
    // self.implicit_key_arc4_string.value = value
    bytec_3 // "implicit_key_arc4_string"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_byte(value: bytes) -> void:
set_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:609-610
    // @arc4.abimethod()
    // def set_implicit_key_arc4_byte(self, value: arc4.Byte) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:611
    // self.implicit_key_arc4_byte.value = value
    bytec 4 // "implicit_key_arc4_byte"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_bool(value: bytes) -> void:
set_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:613-614
    // @arc4.abimethod()
    // def set_implicit_key_arc4_bool(self, value: arc4.Bool) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:615
    // self.implicit_key_arc4_bool.value = value
    bytec 5 // "implicit_key_arc4_bool"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_address(value: bytes) -> void:
set_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:617-618
    // @arc4.abimethod()
    // def set_implicit_key_arc4_address(self, value: arc4.Address) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:619
    // self.implicit_key_arc4_address.value = value
    bytec 6 // "implicit_key_arc4_address"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint128(value: bytes) -> void:
set_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:621-622
    // @arc4.abimethod()
    // def set_implicit_key_arc4_uint128(self, value: arc4.UInt128) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:623
    // self.implicit_key_arc4_uint128.value = value
    bytec 7 // "implicit_key_arc4_uint128"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_dynamic_bytes(value: bytes) -> void:
set_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:625-626
    // @arc4.abimethod()
    // def set_implicit_key_arc4_dynamic_bytes(self, value: arc4.DynamicBytes) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:627
    // self.implicit_key_arc4_dynamic_bytes.value = value.copy()
    bytec 8 // "implicit_key_arc4_dynamic_bytes"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_tuple(value.0: uint64, value.1: bytes, value.2: uint64) -> void:
set_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:629-630
    // @arc4.abimethod()
    // def set_implicit_key_tuple(self, value: tuple[UInt64, Bytes, bool]) -> None:
    proto 3 0
    // tests/artifacts/StateOps/contract.py:631
    // self.implicit_key_tuple.value = value
    frame_dig -3
    itob
    frame_dig -2
    len
    itob
    extract 6 2
    frame_dig -2
    concat
    swap
    bytec 21 // 0x000b
    concat
    bytec_1 // 0x00
    intc_1 // 0
    frame_dig -1
    setbit
    concat
    swap
    concat
    bytec 9 // "implicit_key_tuple"
    swap
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint(value: bytes) -> void:
set_arc4_uint:
    // tests/artifacts/StateOps/contract.py:633-635
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    // def set_arc4_uint(self, value: arc4.UInt64) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:636
    // self.arc4_uint.value = value
    bytec 10 // "explicit_key_arc4_uint"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_string(value: bytes) -> void:
set_arc4_string:
    // tests/artifacts/StateOps/contract.py:638-639
    // @arc4.abimethod()
    // def set_arc4_string(self, value: arc4.String) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:640
    // self.arc4_string.value = value
    bytec 11 // "explicit_key_arc4_string"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_byte(value: bytes) -> void:
set_arc4_byte:
    // tests/artifacts/StateOps/contract.py:642-643
    // @arc4.abimethod()
    // def set_arc4_byte(self, value: arc4.Byte) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:644
    // self.arc4_byte.value = value
    bytec 12 // "explicit_key_arc4_byte"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_bool(value: bytes) -> void:
set_arc4_bool:
    // tests/artifacts/StateOps/contract.py:646-647
    // @arc4.abimethod()
    // def set_arc4_bool(self, value: arc4.Bool) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:648
    // self.arc4_bool.value = value
    bytec 13 // "explicit_key_arc4_bool"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_address(value: bytes) -> void:
set_arc4_address:
    // tests/artifacts/StateOps/contract.py:650-651
    // @arc4.abimethod()
    // def set_arc4_address(self, value: arc4.Address) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:652
    // self.arc4_address.value = value
    bytec 14 // "explicit_key_arc4_address"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint128(value: bytes) -> void:
set_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:654-655
    // @arc4.abimethod()
    // def set_arc4_uint128(self, value: arc4.UInt128) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:656
    // self.arc4_uint128.value = value
    bytec 15 // "explicit_key_arc4_uint128"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_dynamic_bytes(value: bytes) -> void:
set_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:658-659
    // @arc4.abimethod()
    // def set_arc4_dynamic_bytes(self, value: arc4.DynamicBytes) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:660
    // self.arc4_dynamic_bytes.value = value.copy()
    bytec 16 // "explicit_key_arc4_dynamic_bytes"
    frame_dig -1
    app_global_put
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.GlobalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 "implicit_key_arc4_uint" "implicit_key_arc4_string" "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" "implicit_key_arc4_dynamic_bytes" "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" 0x0000000000000539 0x000548656c6c6f 0x00000010000000000000000000000000 0x000d64796e616d6963206279746573
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateOps/contract.py:515-516
    // # Implicit key state variables
    // self.implicit_key_arc4_uint = GlobalState(arc4.UInt64(1337))
    bytec_1 // "implicit_key_arc4_uint"
    bytec 16 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec_2 // "implicit_key_arc4_string"
    bytec 17 // 0x000548656c6c6f
    app_global_put
    // tests/artifacts/StateOps/contract.py:518
    // self.implicit_key_arc4_byte = GlobalState(arc4.Byte(0))
    bytec_3 // "implicit_key_arc4_byte"
    pushbytes 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    bytec 4 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_global_put
    // tests/artifacts/StateOps/contract.py:520
    // self.implicit_key_arc4_address = GlobalState(arc4.Address(Global.creator_address))
    bytec 5 // "implicit_key_arc4_address"
    global CreatorAddress
    app_global_put
    // tests/artifacts/StateOps/contract.py:521
    // self.implicit_key_arc4_uint128 = GlobalState(arc4.UInt128(2**100))
    bytec 6 // "implicit_key_arc4_uint128"
    bytec 18 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 7 // "implicit_key_arc4_dynamic_bytes"
    bytec 19 // 0x000d64796e616d6963206279746573
    app_global_put
    // tests/artifacts/StateOps/contract.py:523
    // self.implicit_key_tuple = GlobalState((UInt64(10), Bytes(b"test"), False))
    bytec 8 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_global_put
    // tests/artifacts/StateOps/contract.py:525-526
    // # Explicit key state variables
    // self.arc4_uint = GlobalState(arc4.UInt64(1337), key="explicit_key_arc4_uint")
    bytec 9 // "explicit_key_arc4_uint"
    bytec 16 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    bytec 10 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec 17 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    app_global_put
    // tests/artifacts/StateOps/contract.py:528
    // self.arc4_byte = GlobalState(arc4.Byte(0), key="explicit_key_arc4_byte")
    bytec 11 // "explicit_key_arc4_byte"
    pushbytes 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    bytec 12 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    app_global_put
    // tests/artifacts/StateOps/contract.py:531
    // arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    bytec 13 // "explicit_key_arc4_address"
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:530-532
    // self.arc4_address = GlobalState(
    //     arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    // )
    app_global_put
    // tests/artifacts/StateOps/contract.py:533
    // self.arc4_uint128 = GlobalState(arc4.UInt128(2**100), key="explicit_key_arc4_uint128")
    bytec 14 // "explicit_key_arc4_uint128"
    bytec 18 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:535
    // arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    bytec 15 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 19 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:534-536
    // self.arc4_dynamic_bytes = GlobalState(
    //     arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    // )
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@37
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x1cc966ee 0x2367cd4b 0x69128e90 0x68d590e2 0x44ef0681 0x1cd294ec 0xaac8ecb1 0x166c6afd 0x3cc3bb7b 0x9a6946ad 0xded75033 0x66279e93 0x096e927b 0x97531fbc 0x6ea3f996 0xa7f4f402 0xaaddcc4c 0x5ec3116d 0x20f56eee 0x1c149a43 0xa575ac7d 0x87f0869b 0x461afc6d 0x048116ea 0x30e34a93 0xd2e646ef 0xe674a270 0xa87e540d 0x720a3ca0 0x257708f7 // method "get_implicit_key_arc4_uint()uint64", method "get_implicit_key_arc4_string()string", method "get_implicit_key_arc4_byte()byte", method "get_implicit_key_arc4_bool()bool", method "get_implicit_key_arc4_address()address", method "get_implicit_key_arc4_uint128()uint128", method "get_implicit_key_arc4_dynamic_bytes()byte[]", method "get_implicit_key_tuple()(uint64,byte[],bool)", method "get_arc4_uint()uint64", method "get_arc4_string()string", method "get_arc4_byte()byte", method "get_arc4_bool()bool", method "get_arc4_address()address", method "get_arc4_uint128()uint128", method "get_arc4_dynamic_bytes()byte[]", method "set_implicit_key_arc4_uint(uint64)void", method "set_implicit_key_arc4_string(string)void", method "set_implicit_key_arc4_byte(byte)void", method "set_implicit_key_arc4_bool(bool)void", method "set_implicit_key_arc4_address(address)void", method "set_implicit_key_arc4_uint128(uint128)void", method "set_implicit_key_arc4_dynamic_bytes(byte[])void", method "set_implicit_key_tuple((uint64,byte[],bool))void", method "set_arc4_uint(uint64)void", method "set_arc4_string(string)void", method "set_arc4_byte(byte)void", method "set_arc4_bool(bool)void", method "set_arc4_address(address)void", method "set_arc4_uint128(uint128)void", method "set_arc4_dynamic_bytes(byte[])void"
    txna ApplicationArgs 0
    match get_implicit_key_arc4_uint get_implicit_key_arc4_string get_implicit_key_arc4_byte get_implicit_key_arc4_bool get_implicit_key_arc4_address get_implicit_key_arc4_uint128 get_implicit_key_arc4_dynamic_bytes get_implicit_key_tuple get_arc4_uint get_arc4_string get_arc4_byte get_arc4_bool get_arc4_address get_arc4_uint128 get_arc4_dynamic_bytes set_implicit_key_arc4_uint set_implicit_key_arc4_string set_implicit_key_arc4_byte set_implicit_key_arc4_bool set_implicit_key_arc4_address set_implicit_key_arc4_uint128 set_implicit_key_arc4_dynamic_bytes set_implicit_key_tuple set_arc4_uint set_arc4_string set_arc4_byte set_arc4_bool set_arc4_address set_arc4_uint128 set_arc4_dynamic_bytes
    err

main___algopy_default_create@37:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint[routing]() -> void:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:541
    // return self.implicit_key_arc4_uint.value
    intc_1 // 0
    bytec_1 // "implicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint exists
    // tests/artifacts/StateOps/contract.py:538-539
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_string[routing]() -> void:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:545
    // return self.implicit_key_arc4_string.value
    intc_1 // 0
    bytec_2 // "implicit_key_arc4_string"
    app_global_get_ex
    assert // check self.implicit_key_arc4_string exists
    // tests/artifacts/StateOps/contract.py:543
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_byte[routing]() -> void:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:549
    // return self.implicit_key_arc4_byte.value
    intc_1 // 0
    bytec_3 // "implicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.implicit_key_arc4_byte exists
    // tests/artifacts/StateOps/contract.py:547
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_bool[routing]() -> void:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:553
    // return self.implicit_key_arc4_bool.value
    intc_1 // 0
    bytec 4 // "implicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.implicit_key_arc4_bool exists
    // tests/artifacts/StateOps/contract.py:551
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_address[routing]() -> void:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:557
    // return self.implicit_key_arc4_address.value
    intc_1 // 0
    bytec 5 // "implicit_key_arc4_address"
    app_global_get_ex
    assert // check self.implicit_key_arc4_address exists
    // tests/artifacts/StateOps/contract.py:555
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint128[routing]() -> void:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:561
    // return self.implicit_key_arc4_uint128.value
    intc_1 // 0
    bytec 6 // "implicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint128 exists
    // tests/artifacts/StateOps/contract.py:559
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_dynamic_bytes[routing]() -> void:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:565
    // return self.implicit_key_arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 7 // "implicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists
    // tests/artifacts/StateOps/contract.py:563
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_tuple[routing]() -> void:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:569
    // return self.implicit_key_tuple.value
    intc_1 // 0
    bytec 8 // "implicit_key_tuple"
    app_global_get_ex
    assert // check self.implicit_key_tuple exists
    // tests/artifacts/StateOps/contract.py:567
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint[routing]() -> void:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:574
    // return self.arc4_uint.value
    intc_1 // 0
    bytec 9 // "explicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.arc4_uint exists
    // tests/artifacts/StateOps/contract.py:571-572
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_string[routing]() -> void:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:578
    // return self.arc4_string.value
    intc_1 // 0
    bytec 10 // "explicit_key_arc4_string"
    app_global_get_ex
    assert // check self.arc4_string exists
    // tests/artifacts/StateOps/contract.py:576
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_byte[routing]() -> void:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:582
    // return self.arc4_byte.value
    intc_1 // 0
    bytec 11 // "explicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.arc4_byte exists
    // tests/artifacts/StateOps/contract.py:580
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_bool[routing]() -> void:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:586
    // return self.arc4_bool.value
    intc_1 // 0
    bytec 12 // "explicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.arc4_bool exists
    // tests/artifacts/StateOps/contract.py:584
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_address[routing]() -> void:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:590
    // return self.arc4_address.value
    intc_1 // 0
    bytec 13 // "explicit_key_arc4_address"
    app_global_get_ex
    assert // check self.arc4_address exists
    // tests/artifacts/StateOps/contract.py:588
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint128[routing]() -> void:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:594
    // return self.arc4_uint128.value
    intc_1 // 0
    bytec 14 // "explicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.arc4_uint128 exists
    // tests/artifacts/StateOps/contract.py:592
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_dynamic_bytes[routing]() -> void:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:598
    // return self.arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 15 // "explicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.arc4_dynamic_bytes exists
    // tests/artifacts/StateOps/contract.py:596
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint[routing]() -> void:
set_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:603
    // self.implicit_key_arc4_uint.value = value
    bytec_1 // "implicit_key_arc4_uint"
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:603
    // self.implicit_key_arc4_uint.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_string[routing]() -> void:
set_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:607
    // self.implicit_key_arc4_string.value = value
    bytec_2 // "implicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:607
    // self.implicit_key_arc4_string.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_byte[routing]() -> void:
set_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:611
    // self.implicit_key_arc4_byte.value = value
    bytec_3 // "implicit_key_arc4_byte"
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:611
    // self.implicit_key_arc4_byte.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_bool[routing]() -> void:
set_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:615
    // self.implicit_key_arc4_bool.value = value
    bytec 4 // "implicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:615
    // self.implicit_key_arc4_bool.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_address[routing]() -> void:
set_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:619
    // self.implicit_key_arc4_address.value = value
    bytec 5 // "implicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:619
    // self.implicit_key_arc4_address.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint128[routing]() -> void:
set_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:623
    // self.implicit_key_arc4_uint128.value = value
    bytec 6 // "implicit_key_arc4_uint128"
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:623
    // self.implicit_key_arc4_uint128.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_dynamic_bytes[routing]() -> void:
set_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:627
    // self.implicit_key_arc4_dynamic_bytes.value = value.copy()
    bytec 7 // "implicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:627
    // self.implicit_key_arc4_dynamic_bytes.value = value.copy()
    app_global_put
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_tuple[routing]() -> void:
set_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:631
    // self.implicit_key_tuple.value = value
    bytec 8 // "implicit_key_tuple"
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:631
    // self.implicit_key_tuple.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint[routing]() -> void:
set_arc4_uint:
    // tests/artifacts/StateOps/contract.py:636
    // self.arc4_uint.value = value
    bytec 9 // "explicit_key_arc4_uint"
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:636
    // self.arc4_uint.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_string[routing]() -> void:
set_arc4_string:
    // tests/artifacts/StateOps/contract.py:640
    // self.arc4_string.value = value
    bytec 10 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:640
    // self.arc4_string.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_byte[routing]() -> void:
set_arc4_byte:
    // tests/artifacts/StateOps/contract.py:644
    // self.arc4_byte.value = value
    bytec 11 // "explicit_key_arc4_byte"
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:644
    // self.arc4_byte.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_bool[routing]() -> void:
set_arc4_bool:
    // tests/artifacts/StateOps/contract.py:648
    // self.arc4_bool.value = value
    bytec 12 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:648
    // self.arc4_bool.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_address[routing]() -> void:
set_arc4_address:
    // tests/artifacts/StateOps/contract.py:652
    // self.arc4_address.value = value
    bytec 13 // "explicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:652
    // self.arc4_address.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint128[routing]() -> void:
set_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:656
    // self.arc4_uint128.value = value
    bytec 14 // "explicit_key_arc4_uint128"
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:656
    // self.arc4_uint128.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_dynamic_bytes[routing]() -> void:
set_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:660
    // self.arc4_dynamic_bytes.value = value.copy()
    bytec 15 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:660
    // self.arc4_dynamic_bytes.value = value.copy()
    app_global_put
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/StateOps/data/GlobalStateContract.arc56.json b/tests/artifacts/StateOps/data/GlobalStateContract.arc56.json index 8704eb9..290e319 100644 --- a/tests/artifacts/StateOps/data/GlobalStateContract.arc56.json +++ b/tests/artifacts/StateOps/data/GlobalStateContract.arc56.json @@ -672,167 +672,103 @@ "sourceInfo": [ { "pc": [ - 766, - 781, - 796, - 811, - 826, - 841, - 856, - 871, - 908, - 923, - 938, - 953, - 968, - 983, - 998, - 1013, - 1029, - 1045, - 1061, - 1077, - 1093, - 1109, - 1125, - 1166, - 1182, - 1198, - 1214, - 1230, - 1246, - 1262 + 543 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 1283 + 772 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 769, - 784, - 799, - 814, - 829, - 844, - 859, - 874, - 911, - 926, - 941, - 956, - 971, - 986, - 1001, - 1016, - 1032, - 1048, - 1064, - 1080, - 1096, - 1112, - 1128, - 1169, - 1185, - 1201, - 1217, - 1233, - 1249, - 1265 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 1382 + 906 ], "errorMessage": "check self.arc4_address exists" }, { "pc": [ - 1376 + 895 ], "errorMessage": "check self.arc4_bool exists" }, { "pc": [ - 1370 + 884 ], "errorMessage": "check self.arc4_byte exists" }, { "pc": [ - 1394 + 928 ], "errorMessage": "check self.arc4_dynamic_bytes exists" }, { "pc": [ - 1364 + 873 ], "errorMessage": "check self.arc4_string exists" }, { "pc": [ - 1358 + 862 ], "errorMessage": "check self.arc4_uint exists" }, { "pc": [ - 1388 + 917 ], "errorMessage": "check self.arc4_uint128 exists" }, { "pc": [ - 1312 + 818 ], "errorMessage": "check self.implicit_key_arc4_address exists" }, { "pc": [ - 1306 + 807 ], "errorMessage": "check self.implicit_key_arc4_bool exists" }, { "pc": [ - 1300 + 796 ], "errorMessage": "check self.implicit_key_arc4_byte exists" }, { "pc": [ - 1324 + 840 ], "errorMessage": "check self.implicit_key_arc4_dynamic_bytes exists" }, { "pc": [ - 1294 + 786 ], "errorMessage": "check self.implicit_key_arc4_string exists" }, { "pc": [ - 1289 + 776 ], "errorMessage": "check self.implicit_key_arc4_uint exists" }, { "pc": [ - 1318 + 829 ], "errorMessage": "check self.implicit_key_arc4_uint128 exists" }, { "pc": [ - 1330 + 851 ], "errorMessage": "check self.implicit_key_tuple exists" } @@ -845,18 +781,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.GlobalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0 8 80
    bytecblock 0x151f7c75 0x00 "implicit_key_arc4_uint" "implicit_key_arc4_string" "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" "implicit_key_arc4_dynamic_bytes" "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" 0x0000000000000539 0x000548656c6c6f 0x00000010000000000000000000000000 0x000d64796e616d6963206279746573 0x000b
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateOps/contract.py:515-516
    // # Implicit key state variables
    // self.implicit_key_arc4_uint = GlobalState(arc4.UInt64(1337))
    bytec_2 // "implicit_key_arc4_uint"
    bytec 17 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec_3 // "implicit_key_arc4_string"
    bytec 18 // 0x000548656c6c6f
    app_global_put
    // tests/artifacts/StateOps/contract.py:518
    // self.implicit_key_arc4_byte = GlobalState(arc4.Byte(0))
    bytec 4 // "implicit_key_arc4_byte"
    bytec_1 // 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    bytec 5 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_global_put
    // tests/artifacts/StateOps/contract.py:520
    // self.implicit_key_arc4_address = GlobalState(arc4.Address(Global.creator_address))
    bytec 6 // "implicit_key_arc4_address"
    global CreatorAddress
    app_global_put
    // tests/artifacts/StateOps/contract.py:521
    // self.implicit_key_arc4_uint128 = GlobalState(arc4.UInt128(2**100))
    bytec 7 // "implicit_key_arc4_uint128"
    bytec 19 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 8 // "implicit_key_arc4_dynamic_bytes"
    bytec 20 // 0x000d64796e616d6963206279746573
    app_global_put
    // tests/artifacts/StateOps/contract.py:523
    // self.implicit_key_tuple = GlobalState((UInt64(10), Bytes(b"test"), False))
    bytec 9 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_global_put
    // tests/artifacts/StateOps/contract.py:525-526
    // # Explicit key state variables
    // self.arc4_uint = GlobalState(arc4.UInt64(1337), key="explicit_key_arc4_uint")
    bytec 10 // "explicit_key_arc4_uint"
    bytec 17 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    bytec 11 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec 18 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    app_global_put
    // tests/artifacts/StateOps/contract.py:528
    // self.arc4_byte = GlobalState(arc4.Byte(0), key="explicit_key_arc4_byte")
    bytec 12 // "explicit_key_arc4_byte"
    bytec_1 // 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    bytec 13 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    app_global_put
    // tests/artifacts/StateOps/contract.py:531
    // arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    bytec 14 // "explicit_key_arc4_address"
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:530-532
    // self.arc4_address = GlobalState(
    //     arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    // )
    app_global_put
    // tests/artifacts/StateOps/contract.py:533
    // self.arc4_uint128 = GlobalState(arc4.UInt128(2**100), key="explicit_key_arc4_uint128")
    bytec 15 // "explicit_key_arc4_uint128"
    bytec 19 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:535
    // arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    bytec 16 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 20 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:534-536
    // self.arc4_dynamic_bytes = GlobalState(
    //     arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    // )
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@35
    pushbytess 0x1cc966ee 0x2367cd4b 0x69128e90 0x68d590e2 0x44ef0681 0x1cd294ec 0xaac8ecb1 0x166c6afd 0x3cc3bb7b 0x9a6946ad 0xded75033 0x66279e93 0x096e927b 0x97531fbc 0x6ea3f996 0xa7f4f402 0xaaddcc4c 0x5ec3116d 0x20f56eee 0x1c149a43 0xa575ac7d 0x87f0869b 0x461afc6d 0x048116ea 0x30e34a93 0xd2e646ef 0xe674a270 0xa87e540d 0x720a3ca0 0x257708f7 // method "get_implicit_key_arc4_uint()uint64", method "get_implicit_key_arc4_string()string", method "get_implicit_key_arc4_byte()byte", method "get_implicit_key_arc4_bool()bool", method "get_implicit_key_arc4_address()address", method "get_implicit_key_arc4_uint128()uint128", method "get_implicit_key_arc4_dynamic_bytes()byte[]", method "get_implicit_key_tuple()(uint64,byte[],bool)", method "get_arc4_uint()uint64", method "get_arc4_string()string", method "get_arc4_byte()byte", method "get_arc4_bool()bool", method "get_arc4_address()address", method "get_arc4_uint128()uint128", method "get_arc4_dynamic_bytes()byte[]", method "set_implicit_key_arc4_uint(uint64)void", method "set_implicit_key_arc4_string(string)void", method "set_implicit_key_arc4_byte(byte)void", method "set_implicit_key_arc4_bool(bool)void", method "set_implicit_key_arc4_address(address)void", method "set_implicit_key_arc4_uint128(uint128)void", method "set_implicit_key_arc4_dynamic_bytes(byte[])void", method "set_implicit_key_tuple((uint64,byte[],bool))void", method "set_arc4_uint(uint64)void", method "set_arc4_string(string)void", method "set_arc4_byte(byte)void", method "set_arc4_bool(bool)void", method "set_arc4_address(address)void", method "set_arc4_uint128(uint128)void", method "set_arc4_dynamic_bytes(byte[])void"
    txna ApplicationArgs 0
    match main_get_implicit_key_arc4_uint_route@5 main_get_implicit_key_arc4_string_route@6 main_get_implicit_key_arc4_byte_route@7 main_get_implicit_key_arc4_bool_route@8 main_get_implicit_key_arc4_address_route@9 main_get_implicit_key_arc4_uint128_route@10 main_get_implicit_key_arc4_dynamic_bytes_route@11 main_get_implicit_key_tuple_route@12 main_get_arc4_uint_route@13 main_get_arc4_string_route@14 main_get_arc4_byte_route@15 main_get_arc4_bool_route@16 main_get_arc4_address_route@17 main_get_arc4_uint128_route@18 main_get_arc4_dynamic_bytes_route@19 main_set_implicit_key_arc4_uint_route@20 main_set_implicit_key_arc4_string_route@21 main_set_implicit_key_arc4_byte_route@22 main_set_implicit_key_arc4_bool_route@23 main_set_implicit_key_arc4_address_route@24 main_set_implicit_key_arc4_uint128_route@25 main_set_implicit_key_arc4_dynamic_bytes_route@26 main_set_implicit_key_tuple_route@27 main_set_arc4_uint_route@28 main_set_arc4_string_route@29 main_set_arc4_byte_route@30 main_set_arc4_bool_route@31 main_set_arc4_address_route@32 main_set_arc4_uint128_route@33 main_set_arc4_dynamic_bytes_route@34

main_after_if_else@37:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    intc_1 // 0
    return

main_set_arc4_dynamic_bytes_route@34:
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    callsub set_arc4_dynamic_bytes
    intc_0 // 1
    return

main_set_arc4_uint128_route@33:
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    callsub set_arc4_uint128
    intc_0 // 1
    return

main_set_arc4_address_route@32:
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    callsub set_arc4_address
    intc_0 // 1
    return

main_set_arc4_bool_route@31:
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    callsub set_arc4_bool
    intc_0 // 1
    return

main_set_arc4_byte_route@30:
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    callsub set_arc4_byte
    intc_0 // 1
    return

main_set_arc4_string_route@29:
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    callsub set_arc4_string
    intc_0 // 1
    return

main_set_arc4_uint_route@28:
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    callsub set_arc4_uint
    intc_0 // 1
    return

main_set_implicit_key_tuple_route@27:
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    dup
    intc_1 // 0
    extract_uint64
    dig 1
    intc_2 // 8
    extract_uint16
    dig 2
    len
    dig 3
    cover 2
    substring3
    extract 2 0
    uncover 2
    intc_3 // 80
    getbit
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    callsub set_implicit_key_tuple
    intc_0 // 1
    return

main_set_implicit_key_arc4_dynamic_bytes_route@26:
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_dynamic_bytes
    intc_0 // 1
    return

main_set_implicit_key_arc4_uint128_route@25:
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_uint128
    intc_0 // 1
    return

main_set_implicit_key_arc4_address_route@24:
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_address
    intc_0 // 1
    return

main_set_implicit_key_arc4_bool_route@23:
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_bool
    intc_0 // 1
    return

main_set_implicit_key_arc4_byte_route@22:
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_byte
    intc_0 // 1
    return

main_set_implicit_key_arc4_string_route@21:
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_string
    intc_0 // 1
    return

main_set_implicit_key_arc4_uint_route@20:
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    callsub set_implicit_key_arc4_uint
    intc_0 // 1
    return

main_get_arc4_dynamic_bytes_route@19:
    // tests/artifacts/StateOps/contract.py:596
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_uint128_route@18:
    // tests/artifacts/StateOps/contract.py:592
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_address_route@17:
    // tests/artifacts/StateOps/contract.py:588
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_bool_route@16:
    // tests/artifacts/StateOps/contract.py:584
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_byte_route@15:
    // tests/artifacts/StateOps/contract.py:580
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_string_route@14:
    // tests/artifacts/StateOps/contract.py:576
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_arc4_uint_route@13:
    // tests/artifacts/StateOps/contract.py:571-572
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_tuple_route@12:
    // tests/artifacts/StateOps/contract.py:567
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_tuple
    uncover 2
    itob
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    bytec 21 // 0x000b
    concat
    bytec_1 // 0x00
    intc_1 // 0
    uncover 4
    setbit
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_dynamic_bytes_route@11:
    // tests/artifacts/StateOps/contract.py:563
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_uint128_route@10:
    // tests/artifacts/StateOps/contract.py:559
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_address_route@9:
    // tests/artifacts/StateOps/contract.py:555
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_bool_route@8:
    // tests/artifacts/StateOps/contract.py:551
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_byte_route@7:
    // tests/artifacts/StateOps/contract.py:547
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_string_route@6:
    // tests/artifacts/StateOps/contract.py:543
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_get_implicit_key_arc4_uint_route@5:
    // tests/artifacts/StateOps/contract.py:538-539
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    callsub get_implicit_key_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@35:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@37
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint() -> bytes:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:541
    // return self.implicit_key_arc4_uint.value
    intc_1 // 0
    bytec_2 // "implicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_string() -> bytes:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:545
    // return self.implicit_key_arc4_string.value
    intc_1 // 0
    bytec_3 // "implicit_key_arc4_string"
    app_global_get_ex
    assert // check self.implicit_key_arc4_string exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_byte() -> bytes:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:549
    // return self.implicit_key_arc4_byte.value
    intc_1 // 0
    bytec 4 // "implicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.implicit_key_arc4_byte exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_bool() -> bytes:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:553
    // return self.implicit_key_arc4_bool.value
    intc_1 // 0
    bytec 5 // "implicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.implicit_key_arc4_bool exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_address() -> bytes:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:557
    // return self.implicit_key_arc4_address.value
    intc_1 // 0
    bytec 6 // "implicit_key_arc4_address"
    app_global_get_ex
    assert // check self.implicit_key_arc4_address exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint128() -> bytes:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:561
    // return self.implicit_key_arc4_uint128.value
    intc_1 // 0
    bytec 7 // "implicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint128 exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_dynamic_bytes() -> bytes:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:565
    // return self.implicit_key_arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 8 // "implicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_tuple() -> uint64, bytes, uint64:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:569
    // return self.implicit_key_tuple.value
    intc_1 // 0
    bytec 9 // "implicit_key_tuple"
    app_global_get_ex
    assert // check self.implicit_key_tuple exists
    dup
    intc_1 // 0
    extract_uint64
    dig 1
    intc_2 // 8
    extract_uint16
    dig 2
    len
    dig 3
    cover 2
    substring3
    extract 2 0
    uncover 2
    intc_3 // 80
    getbit
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint() -> bytes:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:574
    // return self.arc4_uint.value
    intc_1 // 0
    bytec 10 // "explicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.arc4_uint exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_string() -> bytes:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:578
    // return self.arc4_string.value
    intc_1 // 0
    bytec 11 // "explicit_key_arc4_string"
    app_global_get_ex
    assert // check self.arc4_string exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_byte() -> bytes:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:582
    // return self.arc4_byte.value
    intc_1 // 0
    bytec 12 // "explicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.arc4_byte exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_bool() -> bytes:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:586
    // return self.arc4_bool.value
    intc_1 // 0
    bytec 13 // "explicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.arc4_bool exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_address() -> bytes:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:590
    // return self.arc4_address.value
    intc_1 // 0
    bytec 14 // "explicit_key_arc4_address"
    app_global_get_ex
    assert // check self.arc4_address exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint128() -> bytes:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:594
    // return self.arc4_uint128.value
    intc_1 // 0
    bytec 15 // "explicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.arc4_uint128 exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_dynamic_bytes() -> bytes:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:598
    // return self.arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 16 // "explicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.arc4_dynamic_bytes exists
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint(value: bytes) -> void:
set_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:600-602
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    // def set_implicit_key_arc4_uint(self, value: arc4.UInt64) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:603
    // self.implicit_key_arc4_uint.value = value
    bytec_2 // "implicit_key_arc4_uint"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_string(value: bytes) -> void:
set_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:605-606
    // @arc4.abimethod()
    // def set_implicit_key_arc4_string(self, value: arc4.String) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:607
    // self.implicit_key_arc4_string.value = value
    bytec_3 // "implicit_key_arc4_string"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_byte(value: bytes) -> void:
set_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:609-610
    // @arc4.abimethod()
    // def set_implicit_key_arc4_byte(self, value: arc4.Byte) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:611
    // self.implicit_key_arc4_byte.value = value
    bytec 4 // "implicit_key_arc4_byte"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_bool(value: bytes) -> void:
set_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:613-614
    // @arc4.abimethod()
    // def set_implicit_key_arc4_bool(self, value: arc4.Bool) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:615
    // self.implicit_key_arc4_bool.value = value
    bytec 5 // "implicit_key_arc4_bool"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_address(value: bytes) -> void:
set_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:617-618
    // @arc4.abimethod()
    // def set_implicit_key_arc4_address(self, value: arc4.Address) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:619
    // self.implicit_key_arc4_address.value = value
    bytec 6 // "implicit_key_arc4_address"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint128(value: bytes) -> void:
set_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:621-622
    // @arc4.abimethod()
    // def set_implicit_key_arc4_uint128(self, value: arc4.UInt128) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:623
    // self.implicit_key_arc4_uint128.value = value
    bytec 7 // "implicit_key_arc4_uint128"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_dynamic_bytes(value: bytes) -> void:
set_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:625-626
    // @arc4.abimethod()
    // def set_implicit_key_arc4_dynamic_bytes(self, value: arc4.DynamicBytes) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:627
    // self.implicit_key_arc4_dynamic_bytes.value = value.copy()
    bytec 8 // "implicit_key_arc4_dynamic_bytes"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_tuple(value.0: uint64, value.1: bytes, value.2: uint64) -> void:
set_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:629-630
    // @arc4.abimethod()
    // def set_implicit_key_tuple(self, value: tuple[UInt64, Bytes, bool]) -> None:
    proto 3 0
    // tests/artifacts/StateOps/contract.py:631
    // self.implicit_key_tuple.value = value
    frame_dig -3
    itob
    frame_dig -2
    len
    itob
    extract 6 2
    frame_dig -2
    concat
    swap
    bytec 21 // 0x000b
    concat
    bytec_1 // 0x00
    intc_1 // 0
    frame_dig -1
    setbit
    concat
    swap
    concat
    bytec 9 // "implicit_key_tuple"
    swap
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint(value: bytes) -> void:
set_arc4_uint:
    // tests/artifacts/StateOps/contract.py:633-635
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    // def set_arc4_uint(self, value: arc4.UInt64) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:636
    // self.arc4_uint.value = value
    bytec 10 // "explicit_key_arc4_uint"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_string(value: bytes) -> void:
set_arc4_string:
    // tests/artifacts/StateOps/contract.py:638-639
    // @arc4.abimethod()
    // def set_arc4_string(self, value: arc4.String) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:640
    // self.arc4_string.value = value
    bytec 11 // "explicit_key_arc4_string"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_byte(value: bytes) -> void:
set_arc4_byte:
    // tests/artifacts/StateOps/contract.py:642-643
    // @arc4.abimethod()
    // def set_arc4_byte(self, value: arc4.Byte) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:644
    // self.arc4_byte.value = value
    bytec 12 // "explicit_key_arc4_byte"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_bool(value: bytes) -> void:
set_arc4_bool:
    // tests/artifacts/StateOps/contract.py:646-647
    // @arc4.abimethod()
    // def set_arc4_bool(self, value: arc4.Bool) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:648
    // self.arc4_bool.value = value
    bytec 13 // "explicit_key_arc4_bool"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_address(value: bytes) -> void:
set_arc4_address:
    // tests/artifacts/StateOps/contract.py:650-651
    // @arc4.abimethod()
    // def set_arc4_address(self, value: arc4.Address) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:652
    // self.arc4_address.value = value
    bytec 14 // "explicit_key_arc4_address"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint128(value: bytes) -> void:
set_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:654-655
    // @arc4.abimethod()
    // def set_arc4_uint128(self, value: arc4.UInt128) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:656
    // self.arc4_uint128.value = value
    bytec 15 // "explicit_key_arc4_uint128"
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_dynamic_bytes(value: bytes) -> void:
set_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:658-659
    // @arc4.abimethod()
    // def set_arc4_dynamic_bytes(self, value: arc4.DynamicBytes) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:660
    // self.arc4_dynamic_bytes.value = value.copy()
    bytec 16 // "explicit_key_arc4_dynamic_bytes"
    frame_dig -1
    app_global_put
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.GlobalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 "implicit_key_arc4_uint" "implicit_key_arc4_string" "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" "implicit_key_arc4_dynamic_bytes" "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" 0x0000000000000539 0x000548656c6c6f 0x00000010000000000000000000000000 0x000d64796e616d6963206279746573
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/StateOps/contract.py:515-516
    // # Implicit key state variables
    // self.implicit_key_arc4_uint = GlobalState(arc4.UInt64(1337))
    bytec_1 // "implicit_key_arc4_uint"
    bytec 16 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec_2 // "implicit_key_arc4_string"
    bytec 17 // 0x000548656c6c6f
    app_global_put
    // tests/artifacts/StateOps/contract.py:518
    // self.implicit_key_arc4_byte = GlobalState(arc4.Byte(0))
    bytec_3 // "implicit_key_arc4_byte"
    pushbytes 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    bytec 4 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_global_put
    // tests/artifacts/StateOps/contract.py:520
    // self.implicit_key_arc4_address = GlobalState(arc4.Address(Global.creator_address))
    bytec 5 // "implicit_key_arc4_address"
    global CreatorAddress
    app_global_put
    // tests/artifacts/StateOps/contract.py:521
    // self.implicit_key_arc4_uint128 = GlobalState(arc4.UInt128(2**100))
    bytec 6 // "implicit_key_arc4_uint128"
    bytec 18 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 7 // "implicit_key_arc4_dynamic_bytes"
    bytec 19 // 0x000d64796e616d6963206279746573
    app_global_put
    // tests/artifacts/StateOps/contract.py:523
    // self.implicit_key_tuple = GlobalState((UInt64(10), Bytes(b"test"), False))
    bytec 8 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_global_put
    // tests/artifacts/StateOps/contract.py:525-526
    // # Explicit key state variables
    // self.arc4_uint = GlobalState(arc4.UInt64(1337), key="explicit_key_arc4_uint")
    bytec 9 // "explicit_key_arc4_uint"
    bytec 16 // 0x0000000000000539
    app_global_put
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    bytec 10 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:517
    // self.implicit_key_arc4_string = GlobalState(arc4.String("Hello"))
    bytec 17 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:527
    // self.arc4_string = GlobalState(arc4.String("Hello"), key="explicit_key_arc4_string")
    app_global_put
    // tests/artifacts/StateOps/contract.py:528
    // self.arc4_byte = GlobalState(arc4.Byte(0), key="explicit_key_arc4_byte")
    bytec 11 // "explicit_key_arc4_byte"
    pushbytes 0x00
    app_global_put
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    bytec 12 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:519
    // self.implicit_key_arc4_bool = GlobalState(arc4.Bool(True))
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:529
    // self.arc4_bool = GlobalState(arc4.Bool(True), key="explicit_key_arc4_bool")
    app_global_put
    // tests/artifacts/StateOps/contract.py:531
    // arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    bytec 13 // "explicit_key_arc4_address"
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:530-532
    // self.arc4_address = GlobalState(
    //     arc4.Address(Global.creator_address), key="explicit_key_arc4_address"
    // )
    app_global_put
    // tests/artifacts/StateOps/contract.py:533
    // self.arc4_uint128 = GlobalState(arc4.UInt128(2**100), key="explicit_key_arc4_uint128")
    bytec 14 // "explicit_key_arc4_uint128"
    bytec 18 // 0x00000010000000000000000000000000
    app_global_put
    // tests/artifacts/StateOps/contract.py:535
    // arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    bytec 15 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:522
    // self.implicit_key_arc4_dynamic_bytes = GlobalState(arc4.DynamicBytes(b"dynamic bytes"))
    bytec 19 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:534-536
    // self.arc4_dynamic_bytes = GlobalState(
    //     arc4.DynamicBytes(b"dynamic bytes"), key="explicit_key_arc4_dynamic_bytes"
    // )
    app_global_put

main_after_if_else@2:
    // tests/artifacts/StateOps/contract.py:513
    // class GlobalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@37
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x1cc966ee 0x2367cd4b 0x69128e90 0x68d590e2 0x44ef0681 0x1cd294ec 0xaac8ecb1 0x166c6afd 0x3cc3bb7b 0x9a6946ad 0xded75033 0x66279e93 0x096e927b 0x97531fbc 0x6ea3f996 0xa7f4f402 0xaaddcc4c 0x5ec3116d 0x20f56eee 0x1c149a43 0xa575ac7d 0x87f0869b 0x461afc6d 0x048116ea 0x30e34a93 0xd2e646ef 0xe674a270 0xa87e540d 0x720a3ca0 0x257708f7 // method "get_implicit_key_arc4_uint()uint64", method "get_implicit_key_arc4_string()string", method "get_implicit_key_arc4_byte()byte", method "get_implicit_key_arc4_bool()bool", method "get_implicit_key_arc4_address()address", method "get_implicit_key_arc4_uint128()uint128", method "get_implicit_key_arc4_dynamic_bytes()byte[]", method "get_implicit_key_tuple()(uint64,byte[],bool)", method "get_arc4_uint()uint64", method "get_arc4_string()string", method "get_arc4_byte()byte", method "get_arc4_bool()bool", method "get_arc4_address()address", method "get_arc4_uint128()uint128", method "get_arc4_dynamic_bytes()byte[]", method "set_implicit_key_arc4_uint(uint64)void", method "set_implicit_key_arc4_string(string)void", method "set_implicit_key_arc4_byte(byte)void", method "set_implicit_key_arc4_bool(bool)void", method "set_implicit_key_arc4_address(address)void", method "set_implicit_key_arc4_uint128(uint128)void", method "set_implicit_key_arc4_dynamic_bytes(byte[])void", method "set_implicit_key_tuple((uint64,byte[],bool))void", method "set_arc4_uint(uint64)void", method "set_arc4_string(string)void", method "set_arc4_byte(byte)void", method "set_arc4_bool(bool)void", method "set_arc4_address(address)void", method "set_arc4_uint128(uint128)void", method "set_arc4_dynamic_bytes(byte[])void"
    txna ApplicationArgs 0
    match get_implicit_key_arc4_uint get_implicit_key_arc4_string get_implicit_key_arc4_byte get_implicit_key_arc4_bool get_implicit_key_arc4_address get_implicit_key_arc4_uint128 get_implicit_key_arc4_dynamic_bytes get_implicit_key_tuple get_arc4_uint get_arc4_string get_arc4_byte get_arc4_bool get_arc4_address get_arc4_uint128 get_arc4_dynamic_bytes set_implicit_key_arc4_uint set_implicit_key_arc4_string set_implicit_key_arc4_byte set_implicit_key_arc4_bool set_implicit_key_arc4_address set_implicit_key_arc4_uint128 set_implicit_key_arc4_dynamic_bytes set_implicit_key_tuple set_arc4_uint set_arc4_string set_arc4_byte set_arc4_bool set_arc4_address set_arc4_uint128 set_arc4_dynamic_bytes
    err

main___algopy_default_create@37:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint[routing]() -> void:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:541
    // return self.implicit_key_arc4_uint.value
    intc_1 // 0
    bytec_1 // "implicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint exists
    // tests/artifacts/StateOps/contract.py:538-539
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_string[routing]() -> void:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:545
    // return self.implicit_key_arc4_string.value
    intc_1 // 0
    bytec_2 // "implicit_key_arc4_string"
    app_global_get_ex
    assert // check self.implicit_key_arc4_string exists
    // tests/artifacts/StateOps/contract.py:543
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_byte[routing]() -> void:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:549
    // return self.implicit_key_arc4_byte.value
    intc_1 // 0
    bytec_3 // "implicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.implicit_key_arc4_byte exists
    // tests/artifacts/StateOps/contract.py:547
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_bool[routing]() -> void:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:553
    // return self.implicit_key_arc4_bool.value
    intc_1 // 0
    bytec 4 // "implicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.implicit_key_arc4_bool exists
    // tests/artifacts/StateOps/contract.py:551
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_address[routing]() -> void:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:557
    // return self.implicit_key_arc4_address.value
    intc_1 // 0
    bytec 5 // "implicit_key_arc4_address"
    app_global_get_ex
    assert // check self.implicit_key_arc4_address exists
    // tests/artifacts/StateOps/contract.py:555
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_uint128[routing]() -> void:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:561
    // return self.implicit_key_arc4_uint128.value
    intc_1 // 0
    bytec 6 // "implicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.implicit_key_arc4_uint128 exists
    // tests/artifacts/StateOps/contract.py:559
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_arc4_dynamic_bytes[routing]() -> void:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:565
    // return self.implicit_key_arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 7 // "implicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists
    // tests/artifacts/StateOps/contract.py:563
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_implicit_key_tuple[routing]() -> void:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:569
    // return self.implicit_key_tuple.value
    intc_1 // 0
    bytec 8 // "implicit_key_tuple"
    app_global_get_ex
    assert // check self.implicit_key_tuple exists
    // tests/artifacts/StateOps/contract.py:567
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint[routing]() -> void:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:574
    // return self.arc4_uint.value
    intc_1 // 0
    bytec 9 // "explicit_key_arc4_uint"
    app_global_get_ex
    assert // check self.arc4_uint exists
    // tests/artifacts/StateOps/contract.py:571-572
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_string[routing]() -> void:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:578
    // return self.arc4_string.value
    intc_1 // 0
    bytec 10 // "explicit_key_arc4_string"
    app_global_get_ex
    assert // check self.arc4_string exists
    // tests/artifacts/StateOps/contract.py:576
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_byte[routing]() -> void:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:582
    // return self.arc4_byte.value
    intc_1 // 0
    bytec 11 // "explicit_key_arc4_byte"
    app_global_get_ex
    assert // check self.arc4_byte exists
    // tests/artifacts/StateOps/contract.py:580
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_bool[routing]() -> void:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:586
    // return self.arc4_bool.value
    intc_1 // 0
    bytec 12 // "explicit_key_arc4_bool"
    app_global_get_ex
    assert // check self.arc4_bool exists
    // tests/artifacts/StateOps/contract.py:584
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_address[routing]() -> void:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:590
    // return self.arc4_address.value
    intc_1 // 0
    bytec 13 // "explicit_key_arc4_address"
    app_global_get_ex
    assert // check self.arc4_address exists
    // tests/artifacts/StateOps/contract.py:588
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_uint128[routing]() -> void:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:594
    // return self.arc4_uint128.value
    intc_1 // 0
    bytec 14 // "explicit_key_arc4_uint128"
    app_global_get_ex
    assert // check self.arc4_uint128 exists
    // tests/artifacts/StateOps/contract.py:592
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.get_arc4_dynamic_bytes[routing]() -> void:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:598
    // return self.arc4_dynamic_bytes.value
    intc_1 // 0
    bytec 15 // "explicit_key_arc4_dynamic_bytes"
    app_global_get_ex
    assert // check self.arc4_dynamic_bytes exists
    // tests/artifacts/StateOps/contract.py:596
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint[routing]() -> void:
set_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:603
    // self.implicit_key_arc4_uint.value = value
    bytec_1 // "implicit_key_arc4_uint"
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:603
    // self.implicit_key_arc4_uint.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:600-601
    // # Setter methods for implicit key state variables
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_string[routing]() -> void:
set_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:607
    // self.implicit_key_arc4_string.value = value
    bytec_2 // "implicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:607
    // self.implicit_key_arc4_string.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:605
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_byte[routing]() -> void:
set_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:611
    // self.implicit_key_arc4_byte.value = value
    bytec_3 // "implicit_key_arc4_byte"
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:611
    // self.implicit_key_arc4_byte.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:609
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_bool[routing]() -> void:
set_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:615
    // self.implicit_key_arc4_bool.value = value
    bytec 4 // "implicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:615
    // self.implicit_key_arc4_bool.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:613
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_address[routing]() -> void:
set_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:619
    // self.implicit_key_arc4_address.value = value
    bytec 5 // "implicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:619
    // self.implicit_key_arc4_address.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:617
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_uint128[routing]() -> void:
set_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:623
    // self.implicit_key_arc4_uint128.value = value
    bytec 6 // "implicit_key_arc4_uint128"
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:623
    // self.implicit_key_arc4_uint128.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:621
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_arc4_dynamic_bytes[routing]() -> void:
set_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:627
    // self.implicit_key_arc4_dynamic_bytes.value = value.copy()
    bytec 7 // "implicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:627
    // self.implicit_key_arc4_dynamic_bytes.value = value.copy()
    app_global_put
    // tests/artifacts/StateOps/contract.py:625
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_implicit_key_tuple[routing]() -> void:
set_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:631
    // self.implicit_key_tuple.value = value
    bytec 8 // "implicit_key_tuple"
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:631
    // self.implicit_key_tuple.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:629
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint[routing]() -> void:
set_arc4_uint:
    // tests/artifacts/StateOps/contract.py:636
    // self.arc4_uint.value = value
    bytec 9 // "explicit_key_arc4_uint"
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:636
    // self.arc4_uint.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:633-634
    // # Setter methods for explicit key state variables
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_string[routing]() -> void:
set_arc4_string:
    // tests/artifacts/StateOps/contract.py:640
    // self.arc4_string.value = value
    bytec 10 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:640
    // self.arc4_string.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:638
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_byte[routing]() -> void:
set_arc4_byte:
    // tests/artifacts/StateOps/contract.py:644
    // self.arc4_byte.value = value
    bytec 11 // "explicit_key_arc4_byte"
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:644
    // self.arc4_byte.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:642
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_bool[routing]() -> void:
set_arc4_bool:
    // tests/artifacts/StateOps/contract.py:648
    // self.arc4_bool.value = value
    bytec 12 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:648
    // self.arc4_bool.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:646
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_address[routing]() -> void:
set_arc4_address:
    // tests/artifacts/StateOps/contract.py:652
    // self.arc4_address.value = value
    bytec 13 // "explicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:652
    // self.arc4_address.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:650
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_uint128[routing]() -> void:
set_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:656
    // self.arc4_uint128.value = value
    bytec 14 // "explicit_key_arc4_uint128"
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:656
    // self.arc4_uint128.value = value
    app_global_put
    // tests/artifacts/StateOps/contract.py:654
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.GlobalStateContract.set_arc4_dynamic_bytes[routing]() -> void:
set_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:660
    // self.arc4_dynamic_bytes.value = value.copy()
    bytec 15 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:660
    // self.arc4_dynamic_bytes.value = value.copy()
    app_global_put
    // tests/artifacts/StateOps/contract.py:658
    // @arc4.abimethod()
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiAEAQAIUCYWBBUffHUBABZpbXBsaWNpdF9rZXlfYXJjNF91aW50GGltcGxpY2l0X2tleV9hcmM0X3N0cmluZxZpbXBsaWNpdF9rZXlfYXJjNF9ieXRlFmltcGxpY2l0X2tleV9hcmM0X2Jvb2wZaW1wbGljaXRfa2V5X2FyYzRfYWRkcmVzcxlpbXBsaWNpdF9rZXlfYXJjNF91aW50MTI4H2ltcGxpY2l0X2tleV9hcmM0X2R5bmFtaWNfYnl0ZXMSaW1wbGljaXRfa2V5X3R1cGxlFmV4cGxpY2l0X2tleV9hcmM0X3VpbnQYZXhwbGljaXRfa2V5X2FyYzRfc3RyaW5nFmV4cGxpY2l0X2tleV9hcmM0X2J5dGUWZXhwbGljaXRfa2V5X2FyYzRfYm9vbBlleHBsaWNpdF9rZXlfYXJjNF9hZGRyZXNzGWV4cGxpY2l0X2tleV9hcmM0X3VpbnQxMjgfZXhwbGljaXRfa2V5X2FyYzRfZHluYW1pY19ieXRlcwgAAAAAAAAFOQcABUhlbGxvEAAAABAAAAAAAAAAAAAAAAAPAA1keW5hbWljIGJ5dGVzAgALMRhAAFoqJxFnKycSZycEKWcnBYABgGcnBjIJZycHJxNnJwgnFGcnCYARAAAAAAAAAAoACwAABHRlc3RnJwonEWcnCycSZycMKWcnDYABgGcnDjIJZycPJxNnJxAnFGcxG0EC24IeBBzJZu4EI2fNSwRpEo6QBGjVkOIERO8GgQQc0pTsBKrI7LEEFmxq/QQ8w7t7BJppRq0E3tdQMwRmJ56TBAluknsEl1MfvARuo/mWBKf09AIEqt3MTARewxFtBCD1bu4EHBSaQwSldax9BIfwhpsERhr8bQQEgRbqBDDjSpME0uZG7wTmdKJwBKh+VA0Ecgo8oAQldwj3NhoAjh4B8gHiAdIBwgGyAaIBkgFpAVkBSQE5ASkBGQEJAPkA6gDbAMwAvQCuAJ8AkABrAFwATQA+AC8AIAARAAIjQzEZFEQxGEQ2GgGIAwAiQzEZFEQxGEQ2GgGIAugiQzEZFEQxGEQ2GgGIAtAiQzEZFEQxGEQ2GgGIArgiQzEZFEQxGEQ2GgGIAqAiQzEZFEQxGEQ2GgGIAogiQzEZFEQxGEQ2GgGIAnAiQzEZFEQxGEQ2GgFJI1tLASRZSwIVSwNOAlJXAgBPAiVTiAIqIkMxGRREMRhENhoBiAISIkMxGRREMRhENhoBiAH6IkMxGRREMRhENhoBiAHiIkMxGRREMRhENhoBiAHKIkMxGRREMRhENhoBiAGyIkMxGRREMRhENhoBiAGbIkMxGRREMRhENhoBiAGEIkMxGRREMRhEiAFyKExQsCJDMRkURDEYRIgBXChMULAiQzEZFEQxGESIAUYoTFCwIkMxGRREMRhEiAEwKExQsCJDMRkURDEYRIgBGihMULAiQzEZFEQxGESIAQQoTFCwIkMxGRREMRhEiADuKExQsCJDMRkURDEYRIgAwk8CFksCFRZXBgJPA1BMJxVQKSNPBFRQTFAoTFCwIkMxGRREMRhEiACTKExQsCJDMRkURDEYRIgAfShMULAiQzEZFEQxGESIAGcoTFCwIkMxGRREMRhEiABRKExQsCJDMRkURDEYRIgAOyhMULAiQzEZFEQxGESIACYoTFCwIkMxGRREMRhEiAARKExQsCJDMRlA/fkxGBREIkMjKmVEiSMrZUSJIycEZUSJIycFZUSJIycGZUSJIycHZUSJIycIZUSJIycJZURJI1tLASRZSwIVSwNOAlJXAgBPAiVTiSMnCmVEiSMnC2VEiSMnDGVEiSMnDWVEiSMnDmVEiSMnD2VEiSMnEGVEiYoBACqL/2eJigEAK4v/Z4mKAQAnBIv/Z4mKAQAnBYv/Z4mKAQAnBov/Z4mKAQAnB4v/Z4mKAQAnCIv/Z4mKAwCL/RaL/hUWVwYCi/5QTCcVUCkji/9UUExQJwlMZ4mKAQAnCov/Z4mKAQAnC4v/Z4mKAQAnDIv/Z4mKAQAnDYv/Z4mKAQAnDov/Z4mKAQAnD4v/Z4mKAQAnEIv/Z4k=", + "approval": "CiACAQAmFAQVH3x1FmltcGxpY2l0X2tleV9hcmM0X3VpbnQYaW1wbGljaXRfa2V5X2FyYzRfc3RyaW5nFmltcGxpY2l0X2tleV9hcmM0X2J5dGUWaW1wbGljaXRfa2V5X2FyYzRfYm9vbBlpbXBsaWNpdF9rZXlfYXJjNF9hZGRyZXNzGWltcGxpY2l0X2tleV9hcmM0X3VpbnQxMjgfaW1wbGljaXRfa2V5X2FyYzRfZHluYW1pY19ieXRlcxJpbXBsaWNpdF9rZXlfdHVwbGUWZXhwbGljaXRfa2V5X2FyYzRfdWludBhleHBsaWNpdF9rZXlfYXJjNF9zdHJpbmcWZXhwbGljaXRfa2V5X2FyYzRfYnl0ZRZleHBsaWNpdF9rZXlfYXJjNF9ib29sGWV4cGxpY2l0X2tleV9hcmM0X2FkZHJlc3MZZXhwbGljaXRfa2V5X2FyYzRfdWludDEyOB9leHBsaWNpdF9rZXlfYXJjNF9keW5hbWljX2J5dGVzCAAAAAAAAAU5BwAFSGVsbG8QAAAAEAAAAAAAAAAAAAAAAA8ADWR5bmFtaWMgYnl0ZXMxGEAAXSknEGcqJxFnK4ABAGcnBIABgGcnBTIJZycGJxJnJwcnE2cnCIARAAAAAAAAAAoACwAABHRlc3RnJwknEGcnCicRZycLgAEAZycMgAGAZycNMglnJw4nEmcnDycTZzEbQQDhMRkURDEYRIIeBBzJZu4EI2fNSwRpEo6QBGjVkOIERO8GgQQc0pTsBKrI7LEEFmxq/QQ8w7t7BJppRq0E3tdQMwRmJ56TBAluknsEl1MfvARuo/mWBKf09AIEqt3MTARewxFtBCD1bu4EHBSaQwSldax9BIfwhpsERhr8bQQEgRbqBDDjSpME0uZG7wTmdKJwBKh+VA0Ecgo8oAQldwj3NhoAjh4ACQATAB0AJwAyAD0ASABTAF4AaQB0AH8AigCVAKAAqwCyALkAwADIANAA2ADgAOgA8AD4AQABCAEQARgAMRkUMRgUEEMjKWVEKExQsCJDIyplRChMULAiQyMrZUQoTFCwIkMjJwRlRChMULAiQyMnBWVEKExQsCJDIycGZUQoTFCwIkMjJwdlRChMULAiQyMnCGVEKExQsCJDIycJZUQoTFCwIkMjJwplRChMULAiQyMnC2VEKExQsCJDIycMZUQoTFCwIkMjJw1lRChMULAiQyMnDmVEKExQsCJDIycPZUQoTFCwIkMpNhoBZyJDKjYaAWciQys2GgFnIkMnBDYaAWciQycFNhoBZyJDJwY2GgFnIkMnBzYaAWciQycINhoBZyJDJwk2GgFnIkMnCjYaAWciQycLNhoBZyJDJww2GgFnIkMnDTYaAWciQycONhoBZyJDJw82GgFnIkM=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/ITxnOpsContract.approval.teal b/tests/artifacts/StateOps/data/ITxnOpsContract.approval.teal index 297ea6d..ab40618 100644 --- a/tests/artifacts/StateOps/data/ITxnOpsContract.approval.teal +++ b/tests/artifacts/StateOps/data/ITxnOpsContract.approval.teal @@ -8,42 +8,32 @@ main: // tests/artifacts/StateOps/contract.py:488 // class ITxnOpsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@6 + bz main___algopy_default_create@5 pushbytes 0x4e7cd9cb // method "verify_itxn_ops()void" txna ApplicationArgs 0 match main_verify_itxn_ops_route@3 - -main_after_if_else@10: - // tests/artifacts/StateOps/contract.py:488 - // class ITxnOpsContract(ARC4Contract): - pushint 0 // 0 - return + err main_verify_itxn_ops_route@3: // tests/artifacts/StateOps/contract.py:489 // @arc4.abimethod() txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - callsub verify_itxn_ops - intc_0 // 1 - return + && + assert // OnCompletion must be NoOp && can only call when not creating + b verify_itxn_ops -main_bare_routing@6: - // tests/artifacts/StateOps/contract.py:488 - // class ITxnOpsContract(ARC4Contract): +main___algopy_default_create@5: txn OnCompletion - bnz main_after_if_else@10 + ! txn ApplicationID ! - assert // can only call when creating - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.StateOps.contract.ITxnOpsContract.verify_itxn_ops() -> void: +// tests.artifacts.StateOps.contract.ITxnOpsContract.verify_itxn_ops[routing]() -> void: verify_itxn_ops: // tests/artifacts/StateOps/contract.py:491 // algopy.op.ITxnCreate.begin() @@ -120,5 +110,6 @@ verify_itxn_ops: gitxn 1 TypeEnum intc_0 // pay == - assert - retsub + // tests/artifacts/StateOps/contract.py:489 + // @arc4.abimethod() + return diff --git a/tests/artifacts/StateOps/data/ITxnOpsContract.arc32.json b/tests/artifacts/StateOps/data/ITxnOpsContract.arc32.json index c482fcc..e616fb1 100644 --- a/tests/artifacts/StateOps/data/ITxnOpsContract.arc32.json +++ b/tests/artifacts/StateOps/data/ITxnOpsContract.arc32.json @@ -7,7 +7,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDYgMTAwMAogICAgYnl0ZWNibG9jayAweDA2ODEwMQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ4OAogICAgLy8gY2xhc3MgSVR4bk9wc0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9iYXJlX3JvdXRpbmdANgogICAgcHVzaGJ5dGVzIDB4NGU3Y2Q5Y2IgLy8gbWV0aG9kICJ2ZXJpZnlfaXR4bl9vcHMoKXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3ZlcmlmeV9pdHhuX29wc19yb3V0ZUAzCgptYWluX2FmdGVyX2lmX2Vsc2VAMTA6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDg4CiAgICAvLyBjbGFzcyBJVHhuT3BzQ29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHB1c2hpbnQgMCAvLyAwCiAgICByZXR1cm4KCm1haW5fdmVyaWZ5X2l0eG5fb3BzX3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDg5CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBpcyBub3QgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICBjYWxsc3ViIHZlcmlmeV9pdHhuX29wcwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKbWFpbl9iYXJlX3JvdXRpbmdANjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODgKICAgIC8vIGNsYXNzIElUeG5PcHNDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgYm56IG1haW5fYWZ0ZXJfaWZfZWxzZUAxMAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuSVR4bk9wc0NvbnRyYWN0LnZlcmlmeV9pdHhuX29wcygpIC0+IHZvaWQ6CnZlcmlmeV9pdHhuX29wczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLmJlZ2luKCkKICAgIGl0eG5fYmVnaW4KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTIKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF90eXBlX2VudW0oYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwpCiAgICBpbnRjXzEgLy8gYXBwbAogICAgaXR4bl9maWVsZCBUeXBlRW51bQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5MwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X29uX2NvbXBsZXRpb24oYWxnb3B5Lk9uQ29tcGxldGVBY3Rpb24uRGVsZXRlQXBwbGljYXRpb24pCiAgICBwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KICAgIGl0eG5fZmllbGQgT25Db21wbGV0aW9uCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDk0CiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfYXBwcm92YWxfcHJvZ3JhbShCeXRlcy5mcm9tX2hleCgiMDY4MTAxIikpCiAgICBieXRlY18wIC8vIDB4MDY4MTAxCiAgICBpdHhuX2ZpZWxkIEFwcHJvdmFsUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NS00OTYKICAgIC8vICMgcGFnZXMgZXNzZW50aWFsbHkgYXBwZW5kcwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2FwcHJvdmFsX3Byb2dyYW1fcGFnZXMoQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBBcHByb3ZhbFByb2dyYW1QYWdlcwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2NsZWFyX3N0YXRlX3Byb2dyYW0oQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBDbGVhclN0YXRlUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5OAogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2ZlZShhbGdvcHkub3AuR2xvYmFsLm1pbl90eG5fZmVlKQogICAgZ2xvYmFsIE1pblR4bkZlZQogICAgaXR4bl9maWVsZCBGZWUKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTkKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLm5leHQoKQogICAgaXR4bl9uZXh0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAwCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfdHlwZV9lbnVtKGFsZ29weS5UcmFuc2FjdGlvblR5cGUuUGF5bWVudCkKICAgIGludGNfMCAvLyBwYXkKICAgIGl0eG5fZmllbGQgVHlwZUVudW0KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF9yZWNlaXZlcihhbGdvcHkub3AuR2xvYmFsLmNyZWF0b3JfYWRkcmVzcykKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgaXR4bl9maWVsZCBSZWNlaXZlcgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUwMgogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2Ftb3VudChhbGdvcHkuVUludDY0KDEwMDApKQogICAgaW50Y18yIC8vIDEwMDAKICAgIGl0eG5fZmllbGQgQW1vdW50CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAzCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zdWJtaXQoKQogICAgaXR4bl9zdWJtaXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDUKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5yZWNlaXZlcigpID09IGFsZ29weS5vcC5HbG9iYWwuY3JlYXRvcl9hZGRyZXNzCiAgICBpdHhuIFJlY2VpdmVyCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDYKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5hbW91bnQoKSA9PSBhbGdvcHkuVUludDY0KDEwMDApCiAgICBpdHhuIEFtb3VudAogICAgaW50Y18yIC8vIDEwMDAKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDcKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi50eXBlX2VudW0oKSA9PSBhbGdvcHkuVHJhbnNhY3Rpb25UeXBlLlBheW1lbnQKICAgIGl0eG4gVHlwZUVudW0KICAgIGludGNfMCAvLyBwYXkKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDkKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuR0lUeG4udHlwZV9lbnVtKDApID09IGFsZ29weS5UcmFuc2FjdGlvblR5cGUuQXBwbGljYXRpb25DYWxsCiAgICBnaXR4biAwIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUxMAogICAgLy8gYXNzZXJ0IGFsZ29weS5vcC5HSVR4bi50eXBlX2VudW0oMSkgPT0gYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5QYXltZW50CiAgICBnaXR4biAxIFR5cGVFbnVtCiAgICBpbnRjXzAgLy8gcGF5CiAgICA9PQogICAgYXNzZXJ0CiAgICByZXRzdWIK", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDYgMTAwMAogICAgYnl0ZWNibG9jayAweDA2ODEwMQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ4OAogICAgLy8gY2xhc3MgSVR4bk9wc0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1CiAgICBwdXNoYnl0ZXMgMHg0ZTdjZDljYiAvLyBtZXRob2QgInZlcmlmeV9pdHhuX29wcygpdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIG1haW5fdmVyaWZ5X2l0eG5fb3BzX3JvdXRlQDMKICAgIGVycgoKbWFpbl92ZXJpZnlfaXR4bl9vcHNfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODkKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgJiYKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGIgdmVyaWZ5X2l0eG5fb3BzCgptYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDU6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgJiYKICAgIHJldHVybiAvLyBvbiBlcnJvcjogT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcCAmJiBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuSVR4bk9wc0NvbnRyYWN0LnZlcmlmeV9pdHhuX29wc1tyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9pdHhuX29wczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLmJlZ2luKCkKICAgIGl0eG5fYmVnaW4KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTIKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF90eXBlX2VudW0oYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwpCiAgICBpbnRjXzEgLy8gYXBwbAogICAgaXR4bl9maWVsZCBUeXBlRW51bQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5MwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X29uX2NvbXBsZXRpb24oYWxnb3B5Lk9uQ29tcGxldGVBY3Rpb24uRGVsZXRlQXBwbGljYXRpb24pCiAgICBwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KICAgIGl0eG5fZmllbGQgT25Db21wbGV0aW9uCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDk0CiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfYXBwcm92YWxfcHJvZ3JhbShCeXRlcy5mcm9tX2hleCgiMDY4MTAxIikpCiAgICBieXRlY18wIC8vIDB4MDY4MTAxCiAgICBpdHhuX2ZpZWxkIEFwcHJvdmFsUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NS00OTYKICAgIC8vICMgcGFnZXMgZXNzZW50aWFsbHkgYXBwZW5kcwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2FwcHJvdmFsX3Byb2dyYW1fcGFnZXMoQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBBcHByb3ZhbFByb2dyYW1QYWdlcwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2NsZWFyX3N0YXRlX3Byb2dyYW0oQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBDbGVhclN0YXRlUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5OAogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2ZlZShhbGdvcHkub3AuR2xvYmFsLm1pbl90eG5fZmVlKQogICAgZ2xvYmFsIE1pblR4bkZlZQogICAgaXR4bl9maWVsZCBGZWUKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTkKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLm5leHQoKQogICAgaXR4bl9uZXh0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAwCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfdHlwZV9lbnVtKGFsZ29weS5UcmFuc2FjdGlvblR5cGUuUGF5bWVudCkKICAgIGludGNfMCAvLyBwYXkKICAgIGl0eG5fZmllbGQgVHlwZUVudW0KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF9yZWNlaXZlcihhbGdvcHkub3AuR2xvYmFsLmNyZWF0b3JfYWRkcmVzcykKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgaXR4bl9maWVsZCBSZWNlaXZlcgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUwMgogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2Ftb3VudChhbGdvcHkuVUludDY0KDEwMDApKQogICAgaW50Y18yIC8vIDEwMDAKICAgIGl0eG5fZmllbGQgQW1vdW50CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAzCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zdWJtaXQoKQogICAgaXR4bl9zdWJtaXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDUKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5yZWNlaXZlcigpID09IGFsZ29weS5vcC5HbG9iYWwuY3JlYXRvcl9hZGRyZXNzCiAgICBpdHhuIFJlY2VpdmVyCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDYKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5hbW91bnQoKSA9PSBhbGdvcHkuVUludDY0KDEwMDApCiAgICBpdHhuIEFtb3VudAogICAgaW50Y18yIC8vIDEwMDAKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDcKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi50eXBlX2VudW0oKSA9PSBhbGdvcHkuVHJhbnNhY3Rpb25UeXBlLlBheW1lbnQKICAgIGl0eG4gVHlwZUVudW0KICAgIGludGNfMCAvLyBwYXkKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDkKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuR0lUeG4udHlwZV9lbnVtKDApID09IGFsZ29weS5UcmFuc2FjdGlvblR5cGUuQXBwbGljYXRpb25DYWxsCiAgICBnaXR4biAwIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUxMAogICAgLy8gYXNzZXJ0IGFsZ29weS5vcC5HSVR4bi50eXBlX2VudW0oMSkgPT0gYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5QYXltZW50CiAgICBnaXR4biAxIFR5cGVFbnVtCiAgICBpbnRjXzAgLy8gcGF5CiAgICA9PQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ4OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/StateOps/data/ITxnOpsContract.arc56.json b/tests/artifacts/StateOps/data/ITxnOpsContract.arc56.json index ce2294b..e9ec04d 100644 --- a/tests/artifacts/StateOps/data/ITxnOpsContract.arc56.json +++ b/tests/artifacts/StateOps/data/ITxnOpsContract.arc56.json @@ -57,21 +57,15 @@ "sourceInfo": [ { "pc": [ - 37 + 49 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 54 + 38 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 40 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when not creating" } ], "pcOffsetMethod": "none" @@ -82,18 +76,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDYgMTAwMAogICAgYnl0ZWNibG9jayAweDA2ODEwMQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ4OAogICAgLy8gY2xhc3MgSVR4bk9wc0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9iYXJlX3JvdXRpbmdANgogICAgcHVzaGJ5dGVzIDB4NGU3Y2Q5Y2IgLy8gbWV0aG9kICJ2ZXJpZnlfaXR4bl9vcHMoKXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3ZlcmlmeV9pdHhuX29wc19yb3V0ZUAzCgptYWluX2FmdGVyX2lmX2Vsc2VAMTA6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDg4CiAgICAvLyBjbGFzcyBJVHhuT3BzQ29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHB1c2hpbnQgMCAvLyAwCiAgICByZXR1cm4KCm1haW5fdmVyaWZ5X2l0eG5fb3BzX3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDg5CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBpcyBub3QgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICBjYWxsc3ViIHZlcmlmeV9pdHhuX29wcwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKbWFpbl9iYXJlX3JvdXRpbmdANjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODgKICAgIC8vIGNsYXNzIElUeG5PcHNDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgYm56IG1haW5fYWZ0ZXJfaWZfZWxzZUAxMAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuSVR4bk9wc0NvbnRyYWN0LnZlcmlmeV9pdHhuX29wcygpIC0+IHZvaWQ6CnZlcmlmeV9pdHhuX29wczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLmJlZ2luKCkKICAgIGl0eG5fYmVnaW4KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTIKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF90eXBlX2VudW0oYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwpCiAgICBpbnRjXzEgLy8gYXBwbAogICAgaXR4bl9maWVsZCBUeXBlRW51bQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5MwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X29uX2NvbXBsZXRpb24oYWxnb3B5Lk9uQ29tcGxldGVBY3Rpb24uRGVsZXRlQXBwbGljYXRpb24pCiAgICBwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KICAgIGl0eG5fZmllbGQgT25Db21wbGV0aW9uCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDk0CiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfYXBwcm92YWxfcHJvZ3JhbShCeXRlcy5mcm9tX2hleCgiMDY4MTAxIikpCiAgICBieXRlY18wIC8vIDB4MDY4MTAxCiAgICBpdHhuX2ZpZWxkIEFwcHJvdmFsUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NS00OTYKICAgIC8vICMgcGFnZXMgZXNzZW50aWFsbHkgYXBwZW5kcwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2FwcHJvdmFsX3Byb2dyYW1fcGFnZXMoQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBBcHByb3ZhbFByb2dyYW1QYWdlcwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2NsZWFyX3N0YXRlX3Byb2dyYW0oQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBDbGVhclN0YXRlUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5OAogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2ZlZShhbGdvcHkub3AuR2xvYmFsLm1pbl90eG5fZmVlKQogICAgZ2xvYmFsIE1pblR4bkZlZQogICAgaXR4bl9maWVsZCBGZWUKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTkKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLm5leHQoKQogICAgaXR4bl9uZXh0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAwCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfdHlwZV9lbnVtKGFsZ29weS5UcmFuc2FjdGlvblR5cGUuUGF5bWVudCkKICAgIGludGNfMCAvLyBwYXkKICAgIGl0eG5fZmllbGQgVHlwZUVudW0KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF9yZWNlaXZlcihhbGdvcHkub3AuR2xvYmFsLmNyZWF0b3JfYWRkcmVzcykKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgaXR4bl9maWVsZCBSZWNlaXZlcgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUwMgogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2Ftb3VudChhbGdvcHkuVUludDY0KDEwMDApKQogICAgaW50Y18yIC8vIDEwMDAKICAgIGl0eG5fZmllbGQgQW1vdW50CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAzCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zdWJtaXQoKQogICAgaXR4bl9zdWJtaXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDUKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5yZWNlaXZlcigpID09IGFsZ29weS5vcC5HbG9iYWwuY3JlYXRvcl9hZGRyZXNzCiAgICBpdHhuIFJlY2VpdmVyCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDYKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5hbW91bnQoKSA9PSBhbGdvcHkuVUludDY0KDEwMDApCiAgICBpdHhuIEFtb3VudAogICAgaW50Y18yIC8vIDEwMDAKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDcKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi50eXBlX2VudW0oKSA9PSBhbGdvcHkuVHJhbnNhY3Rpb25UeXBlLlBheW1lbnQKICAgIGl0eG4gVHlwZUVudW0KICAgIGludGNfMCAvLyBwYXkKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDkKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuR0lUeG4udHlwZV9lbnVtKDApID09IGFsZ29weS5UcmFuc2FjdGlvblR5cGUuQXBwbGljYXRpb25DYWxsCiAgICBnaXR4biAwIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUxMAogICAgLy8gYXNzZXJ0IGFsZ29weS5vcC5HSVR4bi50eXBlX2VudW0oMSkgPT0gYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5QYXltZW50CiAgICBnaXR4biAxIFR5cGVFbnVtCiAgICBpbnRjXzAgLy8gcGF5CiAgICA9PQogICAgYXNzZXJ0CiAgICByZXRzdWIK", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDYgMTAwMAogICAgYnl0ZWNibG9jayAweDA2ODEwMQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ4OAogICAgLy8gY2xhc3MgSVR4bk9wc0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1CiAgICBwdXNoYnl0ZXMgMHg0ZTdjZDljYiAvLyBtZXRob2QgInZlcmlmeV9pdHhuX29wcygpdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIG1haW5fdmVyaWZ5X2l0eG5fb3BzX3JvdXRlQDMKICAgIGVycgoKbWFpbl92ZXJpZnlfaXR4bl9vcHNfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODkKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgJiYKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGIgdmVyaWZ5X2l0eG5fb3BzCgptYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDU6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgJiYKICAgIHJldHVybiAvLyBvbiBlcnJvcjogT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcCAmJiBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuSVR4bk9wc0NvbnRyYWN0LnZlcmlmeV9pdHhuX29wc1tyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9pdHhuX29wczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLmJlZ2luKCkKICAgIGl0eG5fYmVnaW4KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTIKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF90eXBlX2VudW0oYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5BcHBsaWNhdGlvbkNhbGwpCiAgICBpbnRjXzEgLy8gYXBwbAogICAgaXR4bl9maWVsZCBUeXBlRW51bQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5MwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X29uX2NvbXBsZXRpb24oYWxnb3B5Lk9uQ29tcGxldGVBY3Rpb24uRGVsZXRlQXBwbGljYXRpb24pCiAgICBwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KICAgIGl0eG5fZmllbGQgT25Db21wbGV0aW9uCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDk0CiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfYXBwcm92YWxfcHJvZ3JhbShCeXRlcy5mcm9tX2hleCgiMDY4MTAxIikpCiAgICBieXRlY18wIC8vIDB4MDY4MTAxCiAgICBpdHhuX2ZpZWxkIEFwcHJvdmFsUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NS00OTYKICAgIC8vICMgcGFnZXMgZXNzZW50aWFsbHkgYXBwZW5kcwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2FwcHJvdmFsX3Byb2dyYW1fcGFnZXMoQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBBcHByb3ZhbFByb2dyYW1QYWdlcwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5NwogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2NsZWFyX3N0YXRlX3Byb2dyYW0oQnl0ZXMuZnJvbV9oZXgoIjA2ODEwMSIpKQogICAgYnl0ZWNfMCAvLyAweDA2ODEwMQogICAgaXR4bl9maWVsZCBDbGVhclN0YXRlUHJvZ3JhbQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ5OAogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2ZlZShhbGdvcHkub3AuR2xvYmFsLm1pbl90eG5fZmVlKQogICAgZ2xvYmFsIE1pblR4bkZlZQogICAgaXR4bl9maWVsZCBGZWUKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0OTkKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLm5leHQoKQogICAgaXR4bl9uZXh0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAwCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zZXRfdHlwZV9lbnVtKGFsZ29weS5UcmFuc2FjdGlvblR5cGUuUGF5bWVudCkKICAgIGludGNfMCAvLyBwYXkKICAgIGl0eG5fZmllbGQgVHlwZUVudW0KICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDEKICAgIC8vIGFsZ29weS5vcC5JVHhuQ3JlYXRlLnNldF9yZWNlaXZlcihhbGdvcHkub3AuR2xvYmFsLmNyZWF0b3JfYWRkcmVzcykKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgaXR4bl9maWVsZCBSZWNlaXZlcgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUwMgogICAgLy8gYWxnb3B5Lm9wLklUeG5DcmVhdGUuc2V0X2Ftb3VudChhbGdvcHkuVUludDY0KDEwMDApKQogICAgaW50Y18yIC8vIDEwMDAKICAgIGl0eG5fZmllbGQgQW1vdW50CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NTAzCiAgICAvLyBhbGdvcHkub3AuSVR4bkNyZWF0ZS5zdWJtaXQoKQogICAgaXR4bl9zdWJtaXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDUKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5yZWNlaXZlcigpID09IGFsZ29weS5vcC5HbG9iYWwuY3JlYXRvcl9hZGRyZXNzCiAgICBpdHhuIFJlY2VpdmVyCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDYKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi5hbW91bnQoKSA9PSBhbGdvcHkuVUludDY0KDEwMDApCiAgICBpdHhuIEFtb3VudAogICAgaW50Y18yIC8vIDEwMDAKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDcKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuSVR4bi50eXBlX2VudW0oKSA9PSBhbGdvcHkuVHJhbnNhY3Rpb25UeXBlLlBheW1lbnQKICAgIGl0eG4gVHlwZUVudW0KICAgIGludGNfMCAvLyBwYXkKICAgID09CiAgICBhc3NlcnQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo1MDkKICAgIC8vIGFzc2VydCBhbGdvcHkub3AuR0lUeG4udHlwZV9lbnVtKDApID09IGFsZ29weS5UcmFuc2FjdGlvblR5cGUuQXBwbGljYXRpb25DYWxsCiAgICBnaXR4biAwIFR5cGVFbnVtCiAgICBpbnRjXzEgLy8gYXBwbAogICAgPT0KICAgIGFzc2VydAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjUxMAogICAgLy8gYXNzZXJ0IGFsZ29weS5vcC5HSVR4bi50eXBlX2VudW0oMSkgPT0gYWxnb3B5LlRyYW5zYWN0aW9uVHlwZS5QYXltZW50CiAgICBnaXR4biAxIFR5cGVFbnVtCiAgICBpbnRjXzAgLy8gcGF5CiAgICA9PQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ4OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiADAQboByYBAwaBATEbQQAcgAROfNnLNhoAjgEAA4EAQzEZFEQxGESIAA0iQzEZQP/sMRgURCJDsSOyEIEFshkosh4oskAosh8yALIBtiKyEDIJsgcksgiztAcyCRJEtAgkEkS0ECISRLcAECMSRLcBECISRIk=", + "approval": "CiADAQboByYBAwaBATEbQQAYgAROfNnLNhoAjgEAAQAxGRQxGBBEQgAIMRkUMRgUEEOxI7IQgQWyGSiyHiiyQCiyHzIAsgG2IrIQMgmyBySyCLO0BzIJEkS0CCQSRLQQIhJEtwAQIxJEtwEQIhJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/LocalStateContract.approval.teal b/tests/artifacts/StateOps/data/LocalStateContract.approval.teal index 5389476..649fb16 100644 --- a/tests/artifacts/StateOps/data/LocalStateContract.approval.teal +++ b/tests/artifacts/StateOps/data/LocalStateContract.approval.teal @@ -3,444 +3,79 @@ // tests.artifacts.StateOps.contract.LocalStateContract.__algopy_entrypoint_with_init() -> uint64: main: - intcblock 0 1 - bytecblock 0x151f7c75 0x00 "implicit_key_arc4_uint" 0x0000000000000539 "implicit_key_arc4_string" 0x000548656c6c6f "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" 0x00000010000000000000000000000000 "implicit_key_arc4_dynamic_bytes" 0x000d64796e616d6963206279746573 "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" + intcblock 1 0 + bytecblock 0x151f7c75 "implicit_key_arc4_uint" 0x0000000000000539 "implicit_key_arc4_string" 0x000548656c6c6f "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" 0x00000010000000000000000000000000 "implicit_key_arc4_dynamic_bytes" 0x000d64796e616d6963206279746573 "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes" // tests/artifacts/StateOps/contract.py:663 // class LocalStateContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@21 - pushbytess 0x30c6d58a 0x2284b7af 0x26b45756 0xecf633b0 0x3e531223 0x3ed6799d 0x5296d5ca 0x676a87c2 0x25bd1059 0x999b7f2b 0x70666842 0x6521d49b 0xe07c56cd 0xaa19d2b5 0x971b071f 0xfc0feed9 // method "opt_in()void", method "get_implicit_key_arc4_uint(account)uint64", method "get_implicit_key_arc4_string(account)string", method "get_implicit_key_arc4_byte(account)byte", method "get_implicit_key_arc4_bool(account)bool", method "get_implicit_key_arc4_address(account)address", method "get_implicit_key_arc4_uint128(account)uint128", method "get_implicit_key_arc4_dynamic_bytes(account)byte[]", method "get_implicit_key_tuple(account)(uint64,byte[],bool)", method "get_arc4_uint(account)uint64", method "get_arc4_string(account)string", method "get_arc4_byte(account)byte", method "get_arc4_bool(account)bool", method "get_arc4_address(account)address", method "get_arc4_uint128(account)uint128", method "get_arc4_dynamic_bytes(account)byte[]" + bz main___algopy_default_create@24 + pushbytes 0x30c6d58a // method "opt_in()void" txna ApplicationArgs 0 - match main_opt_in_route@5 main_get_implicit_key_arc4_uint_route@6 main_get_implicit_key_arc4_string_route@7 main_get_implicit_key_arc4_byte_route@8 main_get_implicit_key_arc4_bool_route@9 main_get_implicit_key_arc4_address_route@10 main_get_implicit_key_arc4_uint128_route@11 main_get_implicit_key_arc4_dynamic_bytes_route@12 main_get_implicit_key_tuple_route@13 main_get_arc4_uint_route@14 main_get_arc4_string_route@15 main_get_arc4_byte_route@16 main_get_arc4_bool_route@17 main_get_arc4_address_route@18 main_get_arc4_uint128_route@19 main_get_arc4_dynamic_bytes_route@20 + match main_opt_in_route@5 -main_after_if_else@23: +main_switch_case_next@6: // tests/artifacts/StateOps/contract.py:663 // class LocalStateContract(ARC4Contract): - intc_0 // 0 - return - -main_get_arc4_dynamic_bytes_route@20: - // tests/artifacts/StateOps/contract.py:767 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:767 - // @arc4.abimethod() - callsub get_arc4_dynamic_bytes - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_arc4_uint128_route@19: - // tests/artifacts/StateOps/contract.py:763 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:763 - // @arc4.abimethod() - callsub get_arc4_uint128 - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_arc4_address_route@18: - // tests/artifacts/StateOps/contract.py:759 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:759 - // @arc4.abimethod() - callsub get_arc4_address - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_arc4_bool_route@17: - // tests/artifacts/StateOps/contract.py:755 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:755 - // @arc4.abimethod() - callsub get_arc4_bool - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_arc4_byte_route@16: - // tests/artifacts/StateOps/contract.py:751 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:751 - // @arc4.abimethod() - callsub get_arc4_byte - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_arc4_string_route@15: - // tests/artifacts/StateOps/contract.py:747 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:747 - // @arc4.abimethod() - callsub get_arc4_string - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_arc4_uint_route@14: - // tests/artifacts/StateOps/contract.py:742-743 - // # Getter methods for explicit key state variables - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:742-743 - // # Getter methods for explicit key state variables - // @arc4.abimethod() - callsub get_arc4_uint - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_tuple_route@13: - // tests/artifacts/StateOps/contract.py:738 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:738 - // @arc4.abimethod() - callsub get_implicit_key_tuple - uncover 2 - itob - dig 2 - len - itob - extract 6 2 - uncover 3 - concat - swap - pushbytes 0x000b - concat - bytec_1 // 0x00 - intc_0 // 0 - uncover 4 - setbit - concat - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_arc4_dynamic_bytes_route@12: - // tests/artifacts/StateOps/contract.py:734 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:734 - // @arc4.abimethod() - callsub get_implicit_key_arc4_dynamic_bytes - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_arc4_uint128_route@11: - // tests/artifacts/StateOps/contract.py:730 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:730 - // @arc4.abimethod() - callsub get_implicit_key_arc4_uint128 - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_arc4_address_route@10: - // tests/artifacts/StateOps/contract.py:726 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:726 - // @arc4.abimethod() - callsub get_implicit_key_arc4_address - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_arc4_bool_route@9: - // tests/artifacts/StateOps/contract.py:722 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:722 - // @arc4.abimethod() - callsub get_implicit_key_arc4_bool - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_arc4_byte_route@8: - // tests/artifacts/StateOps/contract.py:718 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:718 - // @arc4.abimethod() - callsub get_implicit_key_arc4_byte - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_arc4_string_route@7: - // tests/artifacts/StateOps/contract.py:714 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:714 - // @arc4.abimethod() - callsub get_implicit_key_arc4_string - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return - -main_get_implicit_key_arc4_uint_route@6: - // tests/artifacts/StateOps/contract.py:709-710 - // # Getter methods for implicit key state variables - // @arc4.abimethod() txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:709-710 - // # Getter methods for implicit key state variables - // @arc4.abimethod() - callsub get_implicit_key_arc4_uint - bytec_0 // 0x151f7c75 - swap - concat - log - intc_1 // 1 - return + assert + pushbytess 0xb3cfa389 0xdb858176 0x78267762 0x426351c8 0x075cae91 0x59c0b80b 0x0d6fa690 0x97e10d9c 0x2e4a8c49 0xb22cd21e 0xb3f44701 0xedd97297 0x671d353c 0xa3fd6fdc 0xcd2e5d66 // method "get_implicit_key_arc4_uint(address)uint64", method "get_implicit_key_arc4_string(address)string", method "get_implicit_key_arc4_byte(address)byte", method "get_implicit_key_arc4_bool(address)bool", method "get_implicit_key_arc4_address(address)address", method "get_implicit_key_arc4_uint128(address)uint128", method "get_implicit_key_arc4_dynamic_bytes(address)byte[]", method "get_implicit_key_tuple(address)(uint64,byte[],bool)", method "get_arc4_uint(address)uint64", method "get_arc4_string(address)string", method "get_arc4_byte(address)byte", method "get_arc4_bool(address)bool", method "get_arc4_address(address)address", method "get_arc4_uint128(address)uint128", method "get_arc4_dynamic_bytes(address)byte[]" + txna ApplicationArgs 0 + match get_implicit_key_arc4_uint get_implicit_key_arc4_string get_implicit_key_arc4_byte get_implicit_key_arc4_bool get_implicit_key_arc4_address get_implicit_key_arc4_uint128 get_implicit_key_arc4_dynamic_bytes get_implicit_key_tuple get_arc4_uint get_arc4_string get_arc4_byte get_arc4_bool get_arc4_address get_arc4_uint128 get_arc4_dynamic_bytes + err main_opt_in_route@5: // tests/artifacts/StateOps/contract.py:686 // @arc4.abimethod(allow_actions=["OptIn"]) txn OnCompletion - intc_1 // OptIn + intc_0 // OptIn == - assert // OnCompletion is not OptIn txn ApplicationID - assert // can only call when not creating - callsub opt_in - intc_1 // 1 - return + && + assert // OnCompletion must be OptIn && can only call when not creating + b opt_in -main_bare_routing@21: - // tests/artifacts/StateOps/contract.py:663 - // class LocalStateContract(ARC4Contract): +main___algopy_default_create@24: txn OnCompletion - bnz main_after_if_else@23 + ! txn ApplicationID ! - assert // can only call when creating - intc_1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.StateOps.contract.LocalStateContract.opt_in() -> void: +// tests.artifacts.StateOps.contract.LocalStateContract.opt_in[routing]() -> void: opt_in: // tests/artifacts/StateOps/contract.py:688 // self.implicit_key_arc4_uint[Global.creator_address] = arc4.UInt64(1337) global CreatorAddress - bytec_2 // "implicit_key_arc4_uint" - bytec_3 // 0x0000000000000539 + bytec_1 // "implicit_key_arc4_uint" + bytec_2 // 0x0000000000000539 app_local_put // tests/artifacts/StateOps/contract.py:689 // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello") global CreatorAddress - bytec 4 // "implicit_key_arc4_string" - bytec 5 // 0x000548656c6c6f + bytec_3 // "implicit_key_arc4_string" + bytec 4 // 0x000548656c6c6f app_local_put // tests/artifacts/StateOps/contract.py:690 // self.implicit_key_arc4_byte[Global.creator_address] = arc4.Byte(0) global CreatorAddress - bytec 6 // "implicit_key_arc4_byte" - bytec_1 // 0x00 + bytec 5 // "implicit_key_arc4_byte" + pushbytes 0x00 app_local_put // tests/artifacts/StateOps/contract.py:691 // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True) global CreatorAddress - bytec 7 // "implicit_key_arc4_bool" + bytec 6 // "implicit_key_arc4_bool" pushbytes 0x80 app_local_put // tests/artifacts/StateOps/contract.py:692 // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address( global CreatorAddress - bytec 8 // "implicit_key_arc4_address" + bytec 7 // "implicit_key_arc4_address" // tests/artifacts/StateOps/contract.py:693 // Global.creator_address global CreatorAddress @@ -452,51 +87,51 @@ opt_in: // tests/artifacts/StateOps/contract.py:695 // self.implicit_key_arc4_uint128[Global.creator_address] = arc4.UInt128(2**100) global CreatorAddress - bytec 9 // "implicit_key_arc4_uint128" - bytec 10 // 0x00000010000000000000000000000000 + bytec 8 // "implicit_key_arc4_uint128" + bytec 9 // 0x00000010000000000000000000000000 app_local_put // tests/artifacts/StateOps/contract.py:696 // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes( global CreatorAddress - bytec 11 // "implicit_key_arc4_dynamic_bytes" + bytec 10 // "implicit_key_arc4_dynamic_bytes" // tests/artifacts/StateOps/contract.py:696-698 // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes( // b"dynamic bytes" // ) - bytec 12 // 0x000d64796e616d6963206279746573 + bytec 11 // 0x000d64796e616d6963206279746573 app_local_put // tests/artifacts/StateOps/contract.py:699 // self.implicit_key_tuple[Global.creator_address] = (UInt64(10), Bytes(b"test"), False) global CreatorAddress - bytec 13 // "implicit_key_tuple" + bytec 12 // "implicit_key_tuple" pushbytes 0x000000000000000a000b00000474657374 app_local_put // tests/artifacts/StateOps/contract.py:701 // self.arc4_uint[Global.creator_address] = arc4.UInt64(1337) global CreatorAddress - bytec 14 // "explicit_key_arc4_uint" - bytec_3 // 0x0000000000000539 + bytec 13 // "explicit_key_arc4_uint" + bytec_2 // 0x0000000000000539 app_local_put // tests/artifacts/StateOps/contract.py:702 // self.arc4_string[Global.creator_address] = arc4.String("Hello") global CreatorAddress - bytec 15 // "explicit_key_arc4_string" + bytec 14 // "explicit_key_arc4_string" // tests/artifacts/StateOps/contract.py:689 // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello") - bytec 5 // 0x000548656c6c6f + bytec 4 // 0x000548656c6c6f // tests/artifacts/StateOps/contract.py:702 // self.arc4_string[Global.creator_address] = arc4.String("Hello") app_local_put // tests/artifacts/StateOps/contract.py:703 // self.arc4_byte[Global.creator_address] = arc4.Byte(0) global CreatorAddress - bytec 16 // "explicit_key_arc4_byte" - bytec_1 // 0x00 + bytec 15 // "explicit_key_arc4_byte" + pushbytes 0x00 app_local_put // tests/artifacts/StateOps/contract.py:704 // self.arc4_bool[Global.creator_address] = arc4.Bool(True) global CreatorAddress - bytec 17 // "explicit_key_arc4_bool" + bytec 16 // "explicit_key_arc4_bool" // tests/artifacts/StateOps/contract.py:691 // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True) pushbytes 0x80 @@ -506,282 +141,347 @@ opt_in: // tests/artifacts/StateOps/contract.py:705 // self.arc4_address[Global.creator_address] = arc4.Address(Global.creator_address) global CreatorAddress - bytec 18 // "explicit_key_arc4_address" + bytec 17 // "explicit_key_arc4_address" global CreatorAddress app_local_put // tests/artifacts/StateOps/contract.py:706 // self.arc4_uint128[Global.creator_address] = arc4.UInt128(2**100) global CreatorAddress - bytec 19 // "explicit_key_arc4_uint128" - bytec 10 // 0x00000010000000000000000000000000 + bytec 18 // "explicit_key_arc4_uint128" + bytec 9 // 0x00000010000000000000000000000000 app_local_put // tests/artifacts/StateOps/contract.py:707 // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes") global CreatorAddress - bytec 20 // "explicit_key_arc4_dynamic_bytes" + bytec 19 // "explicit_key_arc4_dynamic_bytes" // tests/artifacts/StateOps/contract.py:696-698 // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes( // b"dynamic bytes" // ) - bytec 12 // 0x000d64796e616d6963206279746573 + bytec 11 // 0x000d64796e616d6963206279746573 // tests/artifacts/StateOps/contract.py:707 // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes") app_local_put - retsub + // tests/artifacts/StateOps/contract.py:686 + // @arc4.abimethod(allow_actions=["OptIn"]) + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint[routing]() -> void: get_implicit_key_arc4_uint: - // tests/artifacts/StateOps/contract.py:709-711 + // tests/artifacts/StateOps/contract.py:709-710 // # Getter methods for implicit key state variables // @arc4.abimethod() - // def get_implicit_key_arc4_uint(self, a: Account) -> arc4.UInt64: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:712 // return self.implicit_key_arc4_uint[a] - frame_dig -1 - intc_0 // 0 - bytec_2 // "implicit_key_arc4_uint" + intc_1 // 0 + bytec_1 // "implicit_key_arc4_uint" app_local_get_ex assert // check self.implicit_key_arc4_uint exists for account - retsub + // tests/artifacts/StateOps/contract.py:709-710 + // # Getter methods for implicit key state variables + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_string(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_string[routing]() -> void: get_implicit_key_arc4_string: - // tests/artifacts/StateOps/contract.py:714-715 + // tests/artifacts/StateOps/contract.py:714 // @arc4.abimethod() - // def get_implicit_key_arc4_string(self, a: Account) -> arc4.String: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:716 // return self.implicit_key_arc4_string[a] - frame_dig -1 - intc_0 // 0 - bytec 4 // "implicit_key_arc4_string" + intc_1 // 0 + bytec_3 // "implicit_key_arc4_string" app_local_get_ex assert // check self.implicit_key_arc4_string exists for account - retsub + // tests/artifacts/StateOps/contract.py:714 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_byte(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_byte[routing]() -> void: get_implicit_key_arc4_byte: - // tests/artifacts/StateOps/contract.py:718-719 + // tests/artifacts/StateOps/contract.py:718 // @arc4.abimethod() - // def get_implicit_key_arc4_byte(self, a: Account) -> arc4.Byte: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:720 // return self.implicit_key_arc4_byte[a] - frame_dig -1 - intc_0 // 0 - bytec 6 // "implicit_key_arc4_byte" + intc_1 // 0 + bytec 5 // "implicit_key_arc4_byte" app_local_get_ex assert // check self.implicit_key_arc4_byte exists for account - retsub + // tests/artifacts/StateOps/contract.py:718 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_bool(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_bool[routing]() -> void: get_implicit_key_arc4_bool: - // tests/artifacts/StateOps/contract.py:722-723 + // tests/artifacts/StateOps/contract.py:722 // @arc4.abimethod() - // def get_implicit_key_arc4_bool(self, a: Account) -> arc4.Bool: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:724 // return self.implicit_key_arc4_bool[a] - frame_dig -1 - intc_0 // 0 - bytec 7 // "implicit_key_arc4_bool" + intc_1 // 0 + bytec 6 // "implicit_key_arc4_bool" app_local_get_ex assert // check self.implicit_key_arc4_bool exists for account - retsub + // tests/artifacts/StateOps/contract.py:722 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_address(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_address[routing]() -> void: get_implicit_key_arc4_address: - // tests/artifacts/StateOps/contract.py:726-727 + // tests/artifacts/StateOps/contract.py:726 // @arc4.abimethod() - // def get_implicit_key_arc4_address(self, a: Account) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:728 // return self.implicit_key_arc4_address[a] - frame_dig -1 - intc_0 // 0 - bytec 8 // "implicit_key_arc4_address" + intc_1 // 0 + bytec 7 // "implicit_key_arc4_address" app_local_get_ex assert // check self.implicit_key_arc4_address exists for account - retsub + // tests/artifacts/StateOps/contract.py:726 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint128(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint128[routing]() -> void: get_implicit_key_arc4_uint128: - // tests/artifacts/StateOps/contract.py:730-731 + // tests/artifacts/StateOps/contract.py:730 // @arc4.abimethod() - // def get_implicit_key_arc4_uint128(self, a: Account) -> arc4.UInt128: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:732 // return self.implicit_key_arc4_uint128[a] - frame_dig -1 - intc_0 // 0 - bytec 9 // "implicit_key_arc4_uint128" + intc_1 // 0 + bytec 8 // "implicit_key_arc4_uint128" app_local_get_ex assert // check self.implicit_key_arc4_uint128 exists for account - retsub + // tests/artifacts/StateOps/contract.py:730 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_dynamic_bytes(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_dynamic_bytes[routing]() -> void: get_implicit_key_arc4_dynamic_bytes: - // tests/artifacts/StateOps/contract.py:734-735 + // tests/artifacts/StateOps/contract.py:734 // @arc4.abimethod() - // def get_implicit_key_arc4_dynamic_bytes(self, a: Account) -> arc4.DynamicBytes: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:736 // return self.implicit_key_arc4_dynamic_bytes[a] - frame_dig -1 - intc_0 // 0 - bytec 11 // "implicit_key_arc4_dynamic_bytes" + intc_1 // 0 + bytec 10 // "implicit_key_arc4_dynamic_bytes" app_local_get_ex assert // check self.implicit_key_arc4_dynamic_bytes exists for account - retsub + // tests/artifacts/StateOps/contract.py:734 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_tuple(a: bytes) -> uint64, bytes, uint64: +// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_tuple[routing]() -> void: get_implicit_key_tuple: - // tests/artifacts/StateOps/contract.py:738-739 + // tests/artifacts/StateOps/contract.py:738 // @arc4.abimethod() - // def get_implicit_key_tuple(self, a: Account) -> tuple[UInt64, Bytes, bool]: - proto 1 3 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:740 // return self.implicit_key_tuple[a] - frame_dig -1 - intc_0 // 0 - bytec 13 // "implicit_key_tuple" + intc_1 // 0 + bytec 12 // "implicit_key_tuple" app_local_get_ex assert // check self.implicit_key_tuple exists for account - dup - intc_0 // 0 - extract_uint64 - dig 1 - pushint 8 // 8 - extract_uint16 - dig 2 - len - dig 3 - cover 2 - substring3 - extract 2 0 - uncover 2 - pushint 80 // 80 - getbit - retsub - - -// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint(a: bytes) -> bytes: + // tests/artifacts/StateOps/contract.py:738 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return + + +// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint[routing]() -> void: get_arc4_uint: - // tests/artifacts/StateOps/contract.py:742-744 + // tests/artifacts/StateOps/contract.py:742-743 // # Getter methods for explicit key state variables // @arc4.abimethod() - // def get_arc4_uint(self, a: Account) -> arc4.UInt64: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:745 // return self.arc4_uint[a] - frame_dig -1 - intc_0 // 0 - bytec 14 // "explicit_key_arc4_uint" + intc_1 // 0 + bytec 13 // "explicit_key_arc4_uint" app_local_get_ex assert // check self.arc4_uint exists for account - retsub + // tests/artifacts/StateOps/contract.py:742-743 + // # Getter methods for explicit key state variables + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_string(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_string[routing]() -> void: get_arc4_string: - // tests/artifacts/StateOps/contract.py:747-748 + // tests/artifacts/StateOps/contract.py:747 // @arc4.abimethod() - // def get_arc4_string(self, a: Account) -> arc4.String: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:749 // return self.arc4_string[a] - frame_dig -1 - intc_0 // 0 - bytec 15 // "explicit_key_arc4_string" + intc_1 // 0 + bytec 14 // "explicit_key_arc4_string" app_local_get_ex assert // check self.arc4_string exists for account - retsub + // tests/artifacts/StateOps/contract.py:747 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_byte(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_byte[routing]() -> void: get_arc4_byte: - // tests/artifacts/StateOps/contract.py:751-752 + // tests/artifacts/StateOps/contract.py:751 // @arc4.abimethod() - // def get_arc4_byte(self, a: Account) -> arc4.Byte: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:753 // return self.arc4_byte[a] - frame_dig -1 - intc_0 // 0 - bytec 16 // "explicit_key_arc4_byte" + intc_1 // 0 + bytec 15 // "explicit_key_arc4_byte" app_local_get_ex assert // check self.arc4_byte exists for account - retsub + // tests/artifacts/StateOps/contract.py:751 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_bool(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_bool[routing]() -> void: get_arc4_bool: - // tests/artifacts/StateOps/contract.py:755-756 + // tests/artifacts/StateOps/contract.py:755 // @arc4.abimethod() - // def get_arc4_bool(self, a: Account) -> arc4.Bool: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:757 // return self.arc4_bool[a] - frame_dig -1 - intc_0 // 0 - bytec 17 // "explicit_key_arc4_bool" + intc_1 // 0 + bytec 16 // "explicit_key_arc4_bool" app_local_get_ex assert // check self.arc4_bool exists for account - retsub + // tests/artifacts/StateOps/contract.py:755 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_address(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_address[routing]() -> void: get_arc4_address: - // tests/artifacts/StateOps/contract.py:759-760 + // tests/artifacts/StateOps/contract.py:759 // @arc4.abimethod() - // def get_arc4_address(self, a: Account) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:761 // return self.arc4_address[a] - frame_dig -1 - intc_0 // 0 - bytec 18 // "explicit_key_arc4_address" + intc_1 // 0 + bytec 17 // "explicit_key_arc4_address" app_local_get_ex assert // check self.arc4_address exists for account - retsub + // tests/artifacts/StateOps/contract.py:759 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint128(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint128[routing]() -> void: get_arc4_uint128: - // tests/artifacts/StateOps/contract.py:763-764 + // tests/artifacts/StateOps/contract.py:763 // @arc4.abimethod() - // def get_arc4_uint128(self, a: Account) -> arc4.UInt128: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:765 // return self.arc4_uint128[a] - frame_dig -1 - intc_0 // 0 - bytec 19 // "explicit_key_arc4_uint128" + intc_1 // 0 + bytec 18 // "explicit_key_arc4_uint128" app_local_get_ex assert // check self.arc4_uint128 exists for account - retsub + // tests/artifacts/StateOps/contract.py:763 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_dynamic_bytes(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_dynamic_bytes[routing]() -> void: get_arc4_dynamic_bytes: - // tests/artifacts/StateOps/contract.py:767-768 + // tests/artifacts/StateOps/contract.py:767 // @arc4.abimethod() - // def get_arc4_dynamic_bytes(self, a: Account) -> arc4.DynamicBytes: - proto 1 1 + txna ApplicationArgs 1 // tests/artifacts/StateOps/contract.py:769 // return self.arc4_dynamic_bytes[a] - frame_dig -1 - intc_0 // 0 - bytec 20 // "explicit_key_arc4_dynamic_bytes" + intc_1 // 0 + bytec 19 // "explicit_key_arc4_dynamic_bytes" app_local_get_ex assert // check self.arc4_dynamic_bytes exists for account - retsub + // tests/artifacts/StateOps/contract.py:767 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return diff --git a/tests/artifacts/StateOps/data/LocalStateContract.arc32.json b/tests/artifacts/StateOps/data/LocalStateContract.arc32.json index 0e5eb4c..75bcd82 100644 --- a/tests/artifacts/StateOps/data/LocalStateContract.arc32.json +++ b/tests/artifacts/StateOps/data/LocalStateContract.arc32.json @@ -5,84 +5,84 @@ "opt_in": "CALL" } }, - "get_implicit_key_arc4_uint(account)uint64": { + "get_implicit_key_arc4_uint(address)uint64": { "call_config": { "no_op": "CALL" } }, - "get_implicit_key_arc4_string(account)string": { + "get_implicit_key_arc4_string(address)string": { "call_config": { "no_op": "CALL" } }, - "get_implicit_key_arc4_byte(account)byte": { + "get_implicit_key_arc4_byte(address)byte": { "call_config": { "no_op": "CALL" } }, - "get_implicit_key_arc4_bool(account)bool": { + "get_implicit_key_arc4_bool(address)bool": { "call_config": { "no_op": "CALL" } }, - "get_implicit_key_arc4_address(account)address": { + "get_implicit_key_arc4_address(address)address": { "call_config": { "no_op": "CALL" } }, - "get_implicit_key_arc4_uint128(account)uint128": { + "get_implicit_key_arc4_uint128(address)uint128": { "call_config": { "no_op": "CALL" } }, - "get_implicit_key_arc4_dynamic_bytes(account)byte[]": { + "get_implicit_key_arc4_dynamic_bytes(address)byte[]": { "call_config": { "no_op": "CALL" } }, - "get_implicit_key_tuple(account)(uint64,byte[],bool)": { + "get_implicit_key_tuple(address)(uint64,byte[],bool)": { "call_config": { "no_op": "CALL" } }, - "get_arc4_uint(account)uint64": { + "get_arc4_uint(address)uint64": { "call_config": { "no_op": "CALL" } }, - "get_arc4_string(account)string": { + "get_arc4_string(address)string": { "call_config": { "no_op": "CALL" } }, - "get_arc4_byte(account)byte": { + "get_arc4_byte(address)byte": { "call_config": { "no_op": "CALL" } }, - "get_arc4_bool(account)bool": { + "get_arc4_bool(address)bool": { "call_config": { "no_op": "CALL" } }, - "get_arc4_address(account)address": { + "get_arc4_address(address)address": { "call_config": { "no_op": "CALL" } }, - "get_arc4_uint128(account)uint128": { + "get_arc4_uint128(address)uint128": { "call_config": { "no_op": "CALL" } }, - "get_arc4_dynamic_bytes(account)byte[]": { + "get_arc4_dynamic_bytes(address)byte[]": { "call_config": { "no_op": "CALL" } } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.LocalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1
    bytecblock 0x151f7c75 0x00 "implicit_key_arc4_uint" 0x0000000000000539 "implicit_key_arc4_string" 0x000548656c6c6f "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" 0x00000010000000000000000000000000 "implicit_key_arc4_dynamic_bytes" 0x000d64796e616d6963206279746573 "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@21
    pushbytess 0x30c6d58a 0x2284b7af 0x26b45756 0xecf633b0 0x3e531223 0x3ed6799d 0x5296d5ca 0x676a87c2 0x25bd1059 0x999b7f2b 0x70666842 0x6521d49b 0xe07c56cd 0xaa19d2b5 0x971b071f 0xfc0feed9 // method "opt_in()void", method "get_implicit_key_arc4_uint(account)uint64", method "get_implicit_key_arc4_string(account)string", method "get_implicit_key_arc4_byte(account)byte", method "get_implicit_key_arc4_bool(account)bool", method "get_implicit_key_arc4_address(account)address", method "get_implicit_key_arc4_uint128(account)uint128", method "get_implicit_key_arc4_dynamic_bytes(account)byte[]", method "get_implicit_key_tuple(account)(uint64,byte[],bool)", method "get_arc4_uint(account)uint64", method "get_arc4_string(account)string", method "get_arc4_byte(account)byte", method "get_arc4_bool(account)bool", method "get_arc4_address(account)address", method "get_arc4_uint128(account)uint128", method "get_arc4_dynamic_bytes(account)byte[]"
    txna ApplicationArgs 0
    match main_opt_in_route@5 main_get_implicit_key_arc4_uint_route@6 main_get_implicit_key_arc4_string_route@7 main_get_implicit_key_arc4_byte_route@8 main_get_implicit_key_arc4_bool_route@9 main_get_implicit_key_arc4_address_route@10 main_get_implicit_key_arc4_uint128_route@11 main_get_implicit_key_arc4_dynamic_bytes_route@12 main_get_implicit_key_tuple_route@13 main_get_arc4_uint_route@14 main_get_arc4_string_route@15 main_get_arc4_byte_route@16 main_get_arc4_bool_route@17 main_get_arc4_address_route@18 main_get_arc4_uint128_route@19 main_get_arc4_dynamic_bytes_route@20

main_after_if_else@23:
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    intc_0 // 0
    return

main_get_arc4_dynamic_bytes_route@20:
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    callsub get_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_uint128_route@19:
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    callsub get_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_address_route@18:
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    callsub get_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_bool_route@17:
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    callsub get_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_byte_route@16:
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    callsub get_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_string_route@15:
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    callsub get_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_uint_route@14:
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    callsub get_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_tuple_route@13:
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    callsub get_implicit_key_tuple
    uncover 2
    itob
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    pushbytes 0x000b
    concat
    bytec_1 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_dynamic_bytes_route@12:
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_uint128_route@11:
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_address_route@10:
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_bool_route@9:
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_byte_route@8:
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_string_route@7:
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_uint_route@6:
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:686
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_1 // OptIn
    ==
    assert // OnCompletion is not OptIn
    txn ApplicationID
    assert // can only call when not creating
    callsub opt_in
    intc_1 // 1
    return

main_bare_routing@21:
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@23
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.opt_in() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:688
    // self.implicit_key_arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec_2 // "implicit_key_arc4_uint"
    bytec_3 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec 4 // "implicit_key_arc4_string"
    bytec 5 // 0x000548656c6c6f
    app_local_put
    // tests/artifacts/StateOps/contract.py:690
    // self.implicit_key_arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 6 // "implicit_key_arc4_byte"
    bytec_1 // 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 7 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_local_put
    // tests/artifacts/StateOps/contract.py:692
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    global CreatorAddress
    bytec 8 // "implicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:693
    // Global.creator_address
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:692-694
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    //     Global.creator_address
    // )
    app_local_put
    // tests/artifacts/StateOps/contract.py:695
    // self.implicit_key_arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 9 // "implicit_key_arc4_uint128"
    bytec 10 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:696
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    global CreatorAddress
    bytec 11 // "implicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 12 // 0x000d64796e616d6963206279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:699
    // self.implicit_key_tuple[Global.creator_address] = (UInt64(10), Bytes(b"test"), False)
    global CreatorAddress
    bytec 13 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_local_put
    // tests/artifacts/StateOps/contract.py:701
    // self.arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec 14 // "explicit_key_arc4_uint"
    bytec_3 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec 15 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    bytec 5 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    app_local_put
    // tests/artifacts/StateOps/contract.py:703
    // self.arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 16 // "explicit_key_arc4_byte"
    bytec_1 // 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 17 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    app_local_put
    // tests/artifacts/StateOps/contract.py:705
    // self.arc4_address[Global.creator_address] = arc4.Address(Global.creator_address)
    global CreatorAddress
    bytec 18 // "explicit_key_arc4_address"
    global CreatorAddress
    app_local_put
    // tests/artifacts/StateOps/contract.py:706
    // self.arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 19 // "explicit_key_arc4_uint128"
    bytec 10 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    global CreatorAddress
    bytec 20 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 12 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    app_local_put
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint(a: bytes) -> bytes:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:709-711
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    // def get_implicit_key_arc4_uint(self, a: Account) -> arc4.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:712
    // return self.implicit_key_arc4_uint[a]
    frame_dig -1
    intc_0 // 0
    bytec_2 // "implicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_string(a: bytes) -> bytes:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:714-715
    // @arc4.abimethod()
    // def get_implicit_key_arc4_string(self, a: Account) -> arc4.String:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:716
    // return self.implicit_key_arc4_string[a]
    frame_dig -1
    intc_0 // 0
    bytec 4 // "implicit_key_arc4_string"
    app_local_get_ex
    assert // check self.implicit_key_arc4_string exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_byte(a: bytes) -> bytes:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:718-719
    // @arc4.abimethod()
    // def get_implicit_key_arc4_byte(self, a: Account) -> arc4.Byte:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:720
    // return self.implicit_key_arc4_byte[a]
    frame_dig -1
    intc_0 // 0
    bytec 6 // "implicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.implicit_key_arc4_byte exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_bool(a: bytes) -> bytes:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:722-723
    // @arc4.abimethod()
    // def get_implicit_key_arc4_bool(self, a: Account) -> arc4.Bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:724
    // return self.implicit_key_arc4_bool[a]
    frame_dig -1
    intc_0 // 0
    bytec 7 // "implicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.implicit_key_arc4_bool exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_address(a: bytes) -> bytes:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:726-727
    // @arc4.abimethod()
    // def get_implicit_key_arc4_address(self, a: Account) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:728
    // return self.implicit_key_arc4_address[a]
    frame_dig -1
    intc_0 // 0
    bytec 8 // "implicit_key_arc4_address"
    app_local_get_ex
    assert // check self.implicit_key_arc4_address exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint128(a: bytes) -> bytes:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:730-731
    // @arc4.abimethod()
    // def get_implicit_key_arc4_uint128(self, a: Account) -> arc4.UInt128:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:732
    // return self.implicit_key_arc4_uint128[a]
    frame_dig -1
    intc_0 // 0
    bytec 9 // "implicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint128 exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_dynamic_bytes(a: bytes) -> bytes:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:734-735
    // @arc4.abimethod()
    // def get_implicit_key_arc4_dynamic_bytes(self, a: Account) -> arc4.DynamicBytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:736
    // return self.implicit_key_arc4_dynamic_bytes[a]
    frame_dig -1
    intc_0 // 0
    bytec 11 // "implicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_tuple(a: bytes) -> uint64, bytes, uint64:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:738-739
    // @arc4.abimethod()
    // def get_implicit_key_tuple(self, a: Account) -> tuple[UInt64, Bytes, bool]:
    proto 1 3
    // tests/artifacts/StateOps/contract.py:740
    // return self.implicit_key_tuple[a]
    frame_dig -1
    intc_0 // 0
    bytec 13 // "implicit_key_tuple"
    app_local_get_ex
    assert // check self.implicit_key_tuple exists for account
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 8 // 8
    extract_uint16
    dig 2
    len
    dig 3
    cover 2
    substring3
    extract 2 0
    uncover 2
    pushint 80 // 80
    getbit
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint(a: bytes) -> bytes:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:742-744
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    // def get_arc4_uint(self, a: Account) -> arc4.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:745
    // return self.arc4_uint[a]
    frame_dig -1
    intc_0 // 0
    bytec 14 // "explicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.arc4_uint exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_string(a: bytes) -> bytes:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:747-748
    // @arc4.abimethod()
    // def get_arc4_string(self, a: Account) -> arc4.String:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:749
    // return self.arc4_string[a]
    frame_dig -1
    intc_0 // 0
    bytec 15 // "explicit_key_arc4_string"
    app_local_get_ex
    assert // check self.arc4_string exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_byte(a: bytes) -> bytes:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:751-752
    // @arc4.abimethod()
    // def get_arc4_byte(self, a: Account) -> arc4.Byte:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:753
    // return self.arc4_byte[a]
    frame_dig -1
    intc_0 // 0
    bytec 16 // "explicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.arc4_byte exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_bool(a: bytes) -> bytes:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:755-756
    // @arc4.abimethod()
    // def get_arc4_bool(self, a: Account) -> arc4.Bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:757
    // return self.arc4_bool[a]
    frame_dig -1
    intc_0 // 0
    bytec 17 // "explicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.arc4_bool exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_address(a: bytes) -> bytes:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:759-760
    // @arc4.abimethod()
    // def get_arc4_address(self, a: Account) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:761
    // return self.arc4_address[a]
    frame_dig -1
    intc_0 // 0
    bytec 18 // "explicit_key_arc4_address"
    app_local_get_ex
    assert // check self.arc4_address exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint128(a: bytes) -> bytes:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:763-764
    // @arc4.abimethod()
    // def get_arc4_uint128(self, a: Account) -> arc4.UInt128:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:765
    // return self.arc4_uint128[a]
    frame_dig -1
    intc_0 // 0
    bytec 19 // "explicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.arc4_uint128 exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_dynamic_bytes(a: bytes) -> bytes:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:767-768
    // @arc4.abimethod()
    // def get_arc4_dynamic_bytes(self, a: Account) -> arc4.DynamicBytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:769
    // return self.arc4_dynamic_bytes[a]
    frame_dig -1
    intc_0 // 0
    bytec 20 // "explicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.arc4_dynamic_bytes exists for account
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.LocalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 "implicit_key_arc4_uint" 0x0000000000000539 "implicit_key_arc4_string" 0x000548656c6c6f "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" 0x00000010000000000000000000000000 "implicit_key_arc4_dynamic_bytes" 0x000d64796e616d6963206279746573 "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@24
    pushbytes 0x30c6d58a // method "opt_in()void"
    txna ApplicationArgs 0
    match main_opt_in_route@5

main_switch_case_next@6:
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xb3cfa389 0xdb858176 0x78267762 0x426351c8 0x075cae91 0x59c0b80b 0x0d6fa690 0x97e10d9c 0x2e4a8c49 0xb22cd21e 0xb3f44701 0xedd97297 0x671d353c 0xa3fd6fdc 0xcd2e5d66 // method "get_implicit_key_arc4_uint(address)uint64", method "get_implicit_key_arc4_string(address)string", method "get_implicit_key_arc4_byte(address)byte", method "get_implicit_key_arc4_bool(address)bool", method "get_implicit_key_arc4_address(address)address", method "get_implicit_key_arc4_uint128(address)uint128", method "get_implicit_key_arc4_dynamic_bytes(address)byte[]", method "get_implicit_key_tuple(address)(uint64,byte[],bool)", method "get_arc4_uint(address)uint64", method "get_arc4_string(address)string", method "get_arc4_byte(address)byte", method "get_arc4_bool(address)bool", method "get_arc4_address(address)address", method "get_arc4_uint128(address)uint128", method "get_arc4_dynamic_bytes(address)byte[]"
    txna ApplicationArgs 0
    match get_implicit_key_arc4_uint get_implicit_key_arc4_string get_implicit_key_arc4_byte get_implicit_key_arc4_bool get_implicit_key_arc4_address get_implicit_key_arc4_uint128 get_implicit_key_arc4_dynamic_bytes get_implicit_key_tuple get_arc4_uint get_arc4_string get_arc4_byte get_arc4_bool get_arc4_address get_arc4_uint128 get_arc4_dynamic_bytes
    err

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:686
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_0 // OptIn
    ==
    txn ApplicationID
    &&
    assert // OnCompletion must be OptIn && can only call when not creating
    b opt_in

main___algopy_default_create@24:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.LocalStateContract.opt_in[routing]() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:688
    // self.implicit_key_arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec_1 // "implicit_key_arc4_uint"
    bytec_2 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec_3 // "implicit_key_arc4_string"
    bytec 4 // 0x000548656c6c6f
    app_local_put
    // tests/artifacts/StateOps/contract.py:690
    // self.implicit_key_arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 5 // "implicit_key_arc4_byte"
    pushbytes 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 6 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_local_put
    // tests/artifacts/StateOps/contract.py:692
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    global CreatorAddress
    bytec 7 // "implicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:693
    // Global.creator_address
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:692-694
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    //     Global.creator_address
    // )
    app_local_put
    // tests/artifacts/StateOps/contract.py:695
    // self.implicit_key_arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 8 // "implicit_key_arc4_uint128"
    bytec 9 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:696
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    global CreatorAddress
    bytec 10 // "implicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 11 // 0x000d64796e616d6963206279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:699
    // self.implicit_key_tuple[Global.creator_address] = (UInt64(10), Bytes(b"test"), False)
    global CreatorAddress
    bytec 12 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_local_put
    // tests/artifacts/StateOps/contract.py:701
    // self.arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec 13 // "explicit_key_arc4_uint"
    bytec_2 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec 14 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    bytec 4 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    app_local_put
    // tests/artifacts/StateOps/contract.py:703
    // self.arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 15 // "explicit_key_arc4_byte"
    pushbytes 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 16 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    app_local_put
    // tests/artifacts/StateOps/contract.py:705
    // self.arc4_address[Global.creator_address] = arc4.Address(Global.creator_address)
    global CreatorAddress
    bytec 17 // "explicit_key_arc4_address"
    global CreatorAddress
    app_local_put
    // tests/artifacts/StateOps/contract.py:706
    // self.arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 18 // "explicit_key_arc4_uint128"
    bytec 9 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    global CreatorAddress
    bytec 19 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 11 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    app_local_put
    // tests/artifacts/StateOps/contract.py:686
    // @arc4.abimethod(allow_actions=["OptIn"])
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint[routing]() -> void:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:712
    // return self.implicit_key_arc4_uint[a]
    intc_1 // 0
    bytec_1 // "implicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint exists for account
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_string[routing]() -> void:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:716
    // return self.implicit_key_arc4_string[a]
    intc_1 // 0
    bytec_3 // "implicit_key_arc4_string"
    app_local_get_ex
    assert // check self.implicit_key_arc4_string exists for account
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_byte[routing]() -> void:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:720
    // return self.implicit_key_arc4_byte[a]
    intc_1 // 0
    bytec 5 // "implicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.implicit_key_arc4_byte exists for account
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_bool[routing]() -> void:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:724
    // return self.implicit_key_arc4_bool[a]
    intc_1 // 0
    bytec 6 // "implicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.implicit_key_arc4_bool exists for account
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_address[routing]() -> void:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:728
    // return self.implicit_key_arc4_address[a]
    intc_1 // 0
    bytec 7 // "implicit_key_arc4_address"
    app_local_get_ex
    assert // check self.implicit_key_arc4_address exists for account
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint128[routing]() -> void:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:732
    // return self.implicit_key_arc4_uint128[a]
    intc_1 // 0
    bytec 8 // "implicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint128 exists for account
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_dynamic_bytes[routing]() -> void:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:736
    // return self.implicit_key_arc4_dynamic_bytes[a]
    intc_1 // 0
    bytec 10 // "implicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists for account
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_tuple[routing]() -> void:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:740
    // return self.implicit_key_tuple[a]
    intc_1 // 0
    bytec 12 // "implicit_key_tuple"
    app_local_get_ex
    assert // check self.implicit_key_tuple exists for account
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint[routing]() -> void:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:745
    // return self.arc4_uint[a]
    intc_1 // 0
    bytec 13 // "explicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.arc4_uint exists for account
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_string[routing]() -> void:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:749
    // return self.arc4_string[a]
    intc_1 // 0
    bytec 14 // "explicit_key_arc4_string"
    app_local_get_ex
    assert // check self.arc4_string exists for account
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_byte[routing]() -> void:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:753
    // return self.arc4_byte[a]
    intc_1 // 0
    bytec 15 // "explicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.arc4_byte exists for account
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_bool[routing]() -> void:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:757
    // return self.arc4_bool[a]
    intc_1 // 0
    bytec 16 // "explicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.arc4_bool exists for account
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_address[routing]() -> void:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:761
    // return self.arc4_address[a]
    intc_1 // 0
    bytec 17 // "explicit_key_arc4_address"
    app_local_get_ex
    assert // check self.arc4_address exists for account
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint128[routing]() -> void:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:765
    // return self.arc4_uint128[a]
    intc_1 // 0
    bytec 18 // "explicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.arc4_uint128 exists for account
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_dynamic_bytes[routing]() -> void:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:769
    // return self.arc4_dynamic_bytes[a]
    intc_1 // 0
    bytec 19 // "explicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.arc4_dynamic_bytes exists for account
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -181,7 +181,7 @@ "name": "get_implicit_key_arc4_uint", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -194,7 +194,7 @@ "name": "get_implicit_key_arc4_string", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -207,7 +207,7 @@ "name": "get_implicit_key_arc4_byte", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -220,7 +220,7 @@ "name": "get_implicit_key_arc4_bool", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -233,7 +233,7 @@ "name": "get_implicit_key_arc4_address", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -246,7 +246,7 @@ "name": "get_implicit_key_arc4_uint128", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -259,7 +259,7 @@ "name": "get_implicit_key_arc4_dynamic_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -272,7 +272,7 @@ "name": "get_implicit_key_tuple", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -285,7 +285,7 @@ "name": "get_arc4_uint", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -298,7 +298,7 @@ "name": "get_arc4_string", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -311,7 +311,7 @@ "name": "get_arc4_byte", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -324,7 +324,7 @@ "name": "get_arc4_bool", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -337,7 +337,7 @@ "name": "get_arc4_address", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -350,7 +350,7 @@ "name": "get_arc4_uint128", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -363,7 +363,7 @@ "name": "get_arc4_dynamic_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], diff --git a/tests/artifacts/StateOps/data/LocalStateContract.arc56.json b/tests/artifacts/StateOps/data/LocalStateContract.arc56.json index b18b128..1c4355d 100644 --- a/tests/artifacts/StateOps/data/LocalStateContract.arc56.json +++ b/tests/artifacts/StateOps/data/LocalStateContract.arc56.json @@ -22,7 +22,7 @@ "name": "get_implicit_key_arc4_uint", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -43,7 +43,7 @@ "name": "get_implicit_key_arc4_string", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -64,7 +64,7 @@ "name": "get_implicit_key_arc4_byte", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -85,7 +85,7 @@ "name": "get_implicit_key_arc4_bool", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -106,7 +106,7 @@ "name": "get_implicit_key_arc4_address", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -127,7 +127,7 @@ "name": "get_implicit_key_arc4_uint128", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -148,7 +148,7 @@ "name": "get_implicit_key_arc4_dynamic_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -169,7 +169,7 @@ "name": "get_implicit_key_tuple", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -190,7 +190,7 @@ "name": "get_arc4_uint", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -211,7 +211,7 @@ "name": "get_arc4_string", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -232,7 +232,7 @@ "name": "get_arc4_byte", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -253,7 +253,7 @@ "name": "get_arc4_bool", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -274,7 +274,7 @@ "name": "get_arc4_address", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -295,7 +295,7 @@ "name": "get_arc4_uint128", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -316,7 +316,7 @@ "name": "get_arc4_dynamic_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" } ], @@ -448,144 +448,109 @@ "sourceInfo": [ { "pc": [ - 568, - 590, - 612, - 634, - 656, - 678, - 700, - 722, - 771, - 793, - 815, - 837, - 859, - 881, - 903 + 458 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 926 + 593 ], - "errorMessage": "OnCompletion is not OptIn" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 943 + 582 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be OptIn && can only call when not creating" }, { "pc": [ - 571, - 593, - 615, - 637, - 659, - 681, - 703, - 725, - 774, - 796, - 818, - 840, - 862, - 884, - 906, - 929 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 1230 + 891 ], "errorMessage": "check self.arc4_address exists for account" }, { "pc": [ - 1219 + 877 ], "errorMessage": "check self.arc4_bool exists for account" }, { "pc": [ - 1208 + 863 ], "errorMessage": "check self.arc4_byte exists for account" }, { "pc": [ - 1252 + 919 ], "errorMessage": "check self.arc4_dynamic_bytes exists for account" }, { "pc": [ - 1197 + 849 ], "errorMessage": "check self.arc4_string exists for account" }, { "pc": [ - 1186 + 835 ], "errorMessage": "check self.arc4_uint exists for account" }, { "pc": [ - 1241 + 905 ], "errorMessage": "check self.arc4_uint128 exists for account" }, { "pc": [ - 1118 + 779 ], "errorMessage": "check self.implicit_key_arc4_address exists for account" }, { "pc": [ - 1107 + 765 ], "errorMessage": "check self.implicit_key_arc4_bool exists for account" }, { "pc": [ - 1096 + 751 ], "errorMessage": "check self.implicit_key_arc4_byte exists for account" }, { "pc": [ - 1140 + 807 ], "errorMessage": "check self.implicit_key_arc4_dynamic_bytes exists for account" }, { "pc": [ - 1085 + 737 ], "errorMessage": "check self.implicit_key_arc4_string exists for account" }, { "pc": [ - 1074 + 724 ], "errorMessage": "check self.implicit_key_arc4_uint exists for account" }, { "pc": [ - 1129 + 793 ], "errorMessage": "check self.implicit_key_arc4_uint128 exists for account" }, { "pc": [ - 1151 + 821 ], "errorMessage": "check self.implicit_key_tuple exists for account" } @@ -598,18 +563,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.LocalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 0 1
    bytecblock 0x151f7c75 0x00 "implicit_key_arc4_uint" 0x0000000000000539 "implicit_key_arc4_string" 0x000548656c6c6f "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" 0x00000010000000000000000000000000 "implicit_key_arc4_dynamic_bytes" 0x000d64796e616d6963206279746573 "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@21
    pushbytess 0x30c6d58a 0x2284b7af 0x26b45756 0xecf633b0 0x3e531223 0x3ed6799d 0x5296d5ca 0x676a87c2 0x25bd1059 0x999b7f2b 0x70666842 0x6521d49b 0xe07c56cd 0xaa19d2b5 0x971b071f 0xfc0feed9 // method "opt_in()void", method "get_implicit_key_arc4_uint(account)uint64", method "get_implicit_key_arc4_string(account)string", method "get_implicit_key_arc4_byte(account)byte", method "get_implicit_key_arc4_bool(account)bool", method "get_implicit_key_arc4_address(account)address", method "get_implicit_key_arc4_uint128(account)uint128", method "get_implicit_key_arc4_dynamic_bytes(account)byte[]", method "get_implicit_key_tuple(account)(uint64,byte[],bool)", method "get_arc4_uint(account)uint64", method "get_arc4_string(account)string", method "get_arc4_byte(account)byte", method "get_arc4_bool(account)bool", method "get_arc4_address(account)address", method "get_arc4_uint128(account)uint128", method "get_arc4_dynamic_bytes(account)byte[]"
    txna ApplicationArgs 0
    match main_opt_in_route@5 main_get_implicit_key_arc4_uint_route@6 main_get_implicit_key_arc4_string_route@7 main_get_implicit_key_arc4_byte_route@8 main_get_implicit_key_arc4_bool_route@9 main_get_implicit_key_arc4_address_route@10 main_get_implicit_key_arc4_uint128_route@11 main_get_implicit_key_arc4_dynamic_bytes_route@12 main_get_implicit_key_tuple_route@13 main_get_arc4_uint_route@14 main_get_arc4_string_route@15 main_get_arc4_byte_route@16 main_get_arc4_bool_route@17 main_get_arc4_address_route@18 main_get_arc4_uint128_route@19 main_get_arc4_dynamic_bytes_route@20

main_after_if_else@23:
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    intc_0 // 0
    return

main_get_arc4_dynamic_bytes_route@20:
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    callsub get_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_uint128_route@19:
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    callsub get_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_address_route@18:
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    callsub get_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_bool_route@17:
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    callsub get_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_byte_route@16:
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    callsub get_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_string_route@15:
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    callsub get_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_arc4_uint_route@14:
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    callsub get_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_tuple_route@13:
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    callsub get_implicit_key_tuple
    uncover 2
    itob
    dig 2
    len
    itob
    extract 6 2
    uncover 3
    concat
    swap
    pushbytes 0x000b
    concat
    bytec_1 // 0x00
    intc_0 // 0
    uncover 4
    setbit
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_dynamic_bytes_route@12:
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_dynamic_bytes
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_uint128_route@11:
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_uint128
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_address_route@10:
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_bool_route@9:
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_bool
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_byte_route@8:
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_byte
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_string_route@7:
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_string
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_get_implicit_key_arc4_uint_route@6:
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    callsub get_implicit_key_arc4_uint
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:686
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_1 // OptIn
    ==
    assert // OnCompletion is not OptIn
    txn ApplicationID
    assert // can only call when not creating
    callsub opt_in
    intc_1 // 1
    return

main_bare_routing@21:
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@23
    txn ApplicationID
    !
    assert // can only call when creating
    intc_1 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.opt_in() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:688
    // self.implicit_key_arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec_2 // "implicit_key_arc4_uint"
    bytec_3 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec 4 // "implicit_key_arc4_string"
    bytec 5 // 0x000548656c6c6f
    app_local_put
    // tests/artifacts/StateOps/contract.py:690
    // self.implicit_key_arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 6 // "implicit_key_arc4_byte"
    bytec_1 // 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 7 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_local_put
    // tests/artifacts/StateOps/contract.py:692
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    global CreatorAddress
    bytec 8 // "implicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:693
    // Global.creator_address
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:692-694
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    //     Global.creator_address
    // )
    app_local_put
    // tests/artifacts/StateOps/contract.py:695
    // self.implicit_key_arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 9 // "implicit_key_arc4_uint128"
    bytec 10 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:696
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    global CreatorAddress
    bytec 11 // "implicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 12 // 0x000d64796e616d6963206279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:699
    // self.implicit_key_tuple[Global.creator_address] = (UInt64(10), Bytes(b"test"), False)
    global CreatorAddress
    bytec 13 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_local_put
    // tests/artifacts/StateOps/contract.py:701
    // self.arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec 14 // "explicit_key_arc4_uint"
    bytec_3 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec 15 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    bytec 5 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    app_local_put
    // tests/artifacts/StateOps/contract.py:703
    // self.arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 16 // "explicit_key_arc4_byte"
    bytec_1 // 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 17 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    app_local_put
    // tests/artifacts/StateOps/contract.py:705
    // self.arc4_address[Global.creator_address] = arc4.Address(Global.creator_address)
    global CreatorAddress
    bytec 18 // "explicit_key_arc4_address"
    global CreatorAddress
    app_local_put
    // tests/artifacts/StateOps/contract.py:706
    // self.arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 19 // "explicit_key_arc4_uint128"
    bytec 10 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    global CreatorAddress
    bytec 20 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 12 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    app_local_put
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint(a: bytes) -> bytes:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:709-711
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    // def get_implicit_key_arc4_uint(self, a: Account) -> arc4.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:712
    // return self.implicit_key_arc4_uint[a]
    frame_dig -1
    intc_0 // 0
    bytec_2 // "implicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_string(a: bytes) -> bytes:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:714-715
    // @arc4.abimethod()
    // def get_implicit_key_arc4_string(self, a: Account) -> arc4.String:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:716
    // return self.implicit_key_arc4_string[a]
    frame_dig -1
    intc_0 // 0
    bytec 4 // "implicit_key_arc4_string"
    app_local_get_ex
    assert // check self.implicit_key_arc4_string exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_byte(a: bytes) -> bytes:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:718-719
    // @arc4.abimethod()
    // def get_implicit_key_arc4_byte(self, a: Account) -> arc4.Byte:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:720
    // return self.implicit_key_arc4_byte[a]
    frame_dig -1
    intc_0 // 0
    bytec 6 // "implicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.implicit_key_arc4_byte exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_bool(a: bytes) -> bytes:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:722-723
    // @arc4.abimethod()
    // def get_implicit_key_arc4_bool(self, a: Account) -> arc4.Bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:724
    // return self.implicit_key_arc4_bool[a]
    frame_dig -1
    intc_0 // 0
    bytec 7 // "implicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.implicit_key_arc4_bool exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_address(a: bytes) -> bytes:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:726-727
    // @arc4.abimethod()
    // def get_implicit_key_arc4_address(self, a: Account) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:728
    // return self.implicit_key_arc4_address[a]
    frame_dig -1
    intc_0 // 0
    bytec 8 // "implicit_key_arc4_address"
    app_local_get_ex
    assert // check self.implicit_key_arc4_address exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint128(a: bytes) -> bytes:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:730-731
    // @arc4.abimethod()
    // def get_implicit_key_arc4_uint128(self, a: Account) -> arc4.UInt128:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:732
    // return self.implicit_key_arc4_uint128[a]
    frame_dig -1
    intc_0 // 0
    bytec 9 // "implicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint128 exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_dynamic_bytes(a: bytes) -> bytes:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:734-735
    // @arc4.abimethod()
    // def get_implicit_key_arc4_dynamic_bytes(self, a: Account) -> arc4.DynamicBytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:736
    // return self.implicit_key_arc4_dynamic_bytes[a]
    frame_dig -1
    intc_0 // 0
    bytec 11 // "implicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_tuple(a: bytes) -> uint64, bytes, uint64:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:738-739
    // @arc4.abimethod()
    // def get_implicit_key_tuple(self, a: Account) -> tuple[UInt64, Bytes, bool]:
    proto 1 3
    // tests/artifacts/StateOps/contract.py:740
    // return self.implicit_key_tuple[a]
    frame_dig -1
    intc_0 // 0
    bytec 13 // "implicit_key_tuple"
    app_local_get_ex
    assert // check self.implicit_key_tuple exists for account
    dup
    intc_0 // 0
    extract_uint64
    dig 1
    pushint 8 // 8
    extract_uint16
    dig 2
    len
    dig 3
    cover 2
    substring3
    extract 2 0
    uncover 2
    pushint 80 // 80
    getbit
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint(a: bytes) -> bytes:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:742-744
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    // def get_arc4_uint(self, a: Account) -> arc4.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:745
    // return self.arc4_uint[a]
    frame_dig -1
    intc_0 // 0
    bytec 14 // "explicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.arc4_uint exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_string(a: bytes) -> bytes:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:747-748
    // @arc4.abimethod()
    // def get_arc4_string(self, a: Account) -> arc4.String:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:749
    // return self.arc4_string[a]
    frame_dig -1
    intc_0 // 0
    bytec 15 // "explicit_key_arc4_string"
    app_local_get_ex
    assert // check self.arc4_string exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_byte(a: bytes) -> bytes:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:751-752
    // @arc4.abimethod()
    // def get_arc4_byte(self, a: Account) -> arc4.Byte:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:753
    // return self.arc4_byte[a]
    frame_dig -1
    intc_0 // 0
    bytec 16 // "explicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.arc4_byte exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_bool(a: bytes) -> bytes:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:755-756
    // @arc4.abimethod()
    // def get_arc4_bool(self, a: Account) -> arc4.Bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:757
    // return self.arc4_bool[a]
    frame_dig -1
    intc_0 // 0
    bytec 17 // "explicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.arc4_bool exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_address(a: bytes) -> bytes:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:759-760
    // @arc4.abimethod()
    // def get_arc4_address(self, a: Account) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:761
    // return self.arc4_address[a]
    frame_dig -1
    intc_0 // 0
    bytec 18 // "explicit_key_arc4_address"
    app_local_get_ex
    assert // check self.arc4_address exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint128(a: bytes) -> bytes:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:763-764
    // @arc4.abimethod()
    // def get_arc4_uint128(self, a: Account) -> arc4.UInt128:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:765
    // return self.arc4_uint128[a]
    frame_dig -1
    intc_0 // 0
    bytec 19 // "explicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.arc4_uint128 exists for account
    retsub


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_dynamic_bytes(a: bytes) -> bytes:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:767-768
    // @arc4.abimethod()
    // def get_arc4_dynamic_bytes(self, a: Account) -> arc4.DynamicBytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:769
    // return self.arc4_dynamic_bytes[a]
    frame_dig -1
    intc_0 // 0
    bytec 20 // "explicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.arc4_dynamic_bytes exists for account
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.LocalStateContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 "implicit_key_arc4_uint" 0x0000000000000539 "implicit_key_arc4_string" 0x000548656c6c6f "implicit_key_arc4_byte" "implicit_key_arc4_bool" "implicit_key_arc4_address" "implicit_key_arc4_uint128" 0x00000010000000000000000000000000 "implicit_key_arc4_dynamic_bytes" 0x000d64796e616d6963206279746573 "implicit_key_tuple" "explicit_key_arc4_uint" "explicit_key_arc4_string" "explicit_key_arc4_byte" "explicit_key_arc4_bool" "explicit_key_arc4_address" "explicit_key_arc4_uint128" "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@24
    pushbytes 0x30c6d58a // method "opt_in()void"
    txna ApplicationArgs 0
    match main_opt_in_route@5

main_switch_case_next@6:
    // tests/artifacts/StateOps/contract.py:663
    // class LocalStateContract(ARC4Contract):
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xb3cfa389 0xdb858176 0x78267762 0x426351c8 0x075cae91 0x59c0b80b 0x0d6fa690 0x97e10d9c 0x2e4a8c49 0xb22cd21e 0xb3f44701 0xedd97297 0x671d353c 0xa3fd6fdc 0xcd2e5d66 // method "get_implicit_key_arc4_uint(address)uint64", method "get_implicit_key_arc4_string(address)string", method "get_implicit_key_arc4_byte(address)byte", method "get_implicit_key_arc4_bool(address)bool", method "get_implicit_key_arc4_address(address)address", method "get_implicit_key_arc4_uint128(address)uint128", method "get_implicit_key_arc4_dynamic_bytes(address)byte[]", method "get_implicit_key_tuple(address)(uint64,byte[],bool)", method "get_arc4_uint(address)uint64", method "get_arc4_string(address)string", method "get_arc4_byte(address)byte", method "get_arc4_bool(address)bool", method "get_arc4_address(address)address", method "get_arc4_uint128(address)uint128", method "get_arc4_dynamic_bytes(address)byte[]"
    txna ApplicationArgs 0
    match get_implicit_key_arc4_uint get_implicit_key_arc4_string get_implicit_key_arc4_byte get_implicit_key_arc4_bool get_implicit_key_arc4_address get_implicit_key_arc4_uint128 get_implicit_key_arc4_dynamic_bytes get_implicit_key_tuple get_arc4_uint get_arc4_string get_arc4_byte get_arc4_bool get_arc4_address get_arc4_uint128 get_arc4_dynamic_bytes
    err

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:686
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_0 // OptIn
    ==
    txn ApplicationID
    &&
    assert // OnCompletion must be OptIn && can only call when not creating
    b opt_in

main___algopy_default_create@24:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.LocalStateContract.opt_in[routing]() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:688
    // self.implicit_key_arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec_1 // "implicit_key_arc4_uint"
    bytec_2 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec_3 // "implicit_key_arc4_string"
    bytec 4 // 0x000548656c6c6f
    app_local_put
    // tests/artifacts/StateOps/contract.py:690
    // self.implicit_key_arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 5 // "implicit_key_arc4_byte"
    pushbytes 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 6 // "implicit_key_arc4_bool"
    pushbytes 0x80
    app_local_put
    // tests/artifacts/StateOps/contract.py:692
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    global CreatorAddress
    bytec 7 // "implicit_key_arc4_address"
    // tests/artifacts/StateOps/contract.py:693
    // Global.creator_address
    global CreatorAddress
    // tests/artifacts/StateOps/contract.py:692-694
    // self.implicit_key_arc4_address[Global.creator_address] = arc4.Address(
    //     Global.creator_address
    // )
    app_local_put
    // tests/artifacts/StateOps/contract.py:695
    // self.implicit_key_arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 8 // "implicit_key_arc4_uint128"
    bytec 9 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:696
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    global CreatorAddress
    bytec 10 // "implicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 11 // 0x000d64796e616d6963206279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:699
    // self.implicit_key_tuple[Global.creator_address] = (UInt64(10), Bytes(b"test"), False)
    global CreatorAddress
    bytec 12 // "implicit_key_tuple"
    pushbytes 0x000000000000000a000b00000474657374
    app_local_put
    // tests/artifacts/StateOps/contract.py:701
    // self.arc4_uint[Global.creator_address] = arc4.UInt64(1337)
    global CreatorAddress
    bytec 13 // "explicit_key_arc4_uint"
    bytec_2 // 0x0000000000000539
    app_local_put
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    global CreatorAddress
    bytec 14 // "explicit_key_arc4_string"
    // tests/artifacts/StateOps/contract.py:689
    // self.implicit_key_arc4_string[Global.creator_address] = arc4.String("Hello")
    bytec 4 // 0x000548656c6c6f
    // tests/artifacts/StateOps/contract.py:702
    // self.arc4_string[Global.creator_address] = arc4.String("Hello")
    app_local_put
    // tests/artifacts/StateOps/contract.py:703
    // self.arc4_byte[Global.creator_address] = arc4.Byte(0)
    global CreatorAddress
    bytec 15 // "explicit_key_arc4_byte"
    pushbytes 0x00
    app_local_put
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    global CreatorAddress
    bytec 16 // "explicit_key_arc4_bool"
    // tests/artifacts/StateOps/contract.py:691
    // self.implicit_key_arc4_bool[Global.creator_address] = arc4.Bool(True)
    pushbytes 0x80
    // tests/artifacts/StateOps/contract.py:704
    // self.arc4_bool[Global.creator_address] = arc4.Bool(True)
    app_local_put
    // tests/artifacts/StateOps/contract.py:705
    // self.arc4_address[Global.creator_address] = arc4.Address(Global.creator_address)
    global CreatorAddress
    bytec 17 // "explicit_key_arc4_address"
    global CreatorAddress
    app_local_put
    // tests/artifacts/StateOps/contract.py:706
    // self.arc4_uint128[Global.creator_address] = arc4.UInt128(2**100)
    global CreatorAddress
    bytec 18 // "explicit_key_arc4_uint128"
    bytec 9 // 0x00000010000000000000000000000000
    app_local_put
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    global CreatorAddress
    bytec 19 // "explicit_key_arc4_dynamic_bytes"
    // tests/artifacts/StateOps/contract.py:696-698
    // self.implicit_key_arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(
    //     b"dynamic bytes"
    // )
    bytec 11 // 0x000d64796e616d6963206279746573
    // tests/artifacts/StateOps/contract.py:707
    // self.arc4_dynamic_bytes[Global.creator_address] = arc4.DynamicBytes(b"dynamic bytes")
    app_local_put
    // tests/artifacts/StateOps/contract.py:686
    // @arc4.abimethod(allow_actions=["OptIn"])
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint[routing]() -> void:
get_implicit_key_arc4_uint:
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:712
    // return self.implicit_key_arc4_uint[a]
    intc_1 // 0
    bytec_1 // "implicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint exists for account
    // tests/artifacts/StateOps/contract.py:709-710
    // # Getter methods for implicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_string[routing]() -> void:
get_implicit_key_arc4_string:
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:716
    // return self.implicit_key_arc4_string[a]
    intc_1 // 0
    bytec_3 // "implicit_key_arc4_string"
    app_local_get_ex
    assert // check self.implicit_key_arc4_string exists for account
    // tests/artifacts/StateOps/contract.py:714
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_byte[routing]() -> void:
get_implicit_key_arc4_byte:
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:720
    // return self.implicit_key_arc4_byte[a]
    intc_1 // 0
    bytec 5 // "implicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.implicit_key_arc4_byte exists for account
    // tests/artifacts/StateOps/contract.py:718
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_bool[routing]() -> void:
get_implicit_key_arc4_bool:
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:724
    // return self.implicit_key_arc4_bool[a]
    intc_1 // 0
    bytec 6 // "implicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.implicit_key_arc4_bool exists for account
    // tests/artifacts/StateOps/contract.py:722
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_address[routing]() -> void:
get_implicit_key_arc4_address:
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:728
    // return self.implicit_key_arc4_address[a]
    intc_1 // 0
    bytec 7 // "implicit_key_arc4_address"
    app_local_get_ex
    assert // check self.implicit_key_arc4_address exists for account
    // tests/artifacts/StateOps/contract.py:726
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_uint128[routing]() -> void:
get_implicit_key_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:732
    // return self.implicit_key_arc4_uint128[a]
    intc_1 // 0
    bytec 8 // "implicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.implicit_key_arc4_uint128 exists for account
    // tests/artifacts/StateOps/contract.py:730
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_arc4_dynamic_bytes[routing]() -> void:
get_implicit_key_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:736
    // return self.implicit_key_arc4_dynamic_bytes[a]
    intc_1 // 0
    bytec 10 // "implicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.implicit_key_arc4_dynamic_bytes exists for account
    // tests/artifacts/StateOps/contract.py:734
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_implicit_key_tuple[routing]() -> void:
get_implicit_key_tuple:
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:740
    // return self.implicit_key_tuple[a]
    intc_1 // 0
    bytec 12 // "implicit_key_tuple"
    app_local_get_ex
    assert // check self.implicit_key_tuple exists for account
    // tests/artifacts/StateOps/contract.py:738
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint[routing]() -> void:
get_arc4_uint:
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:745
    // return self.arc4_uint[a]
    intc_1 // 0
    bytec 13 // "explicit_key_arc4_uint"
    app_local_get_ex
    assert // check self.arc4_uint exists for account
    // tests/artifacts/StateOps/contract.py:742-743
    // # Getter methods for explicit key state variables
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_string[routing]() -> void:
get_arc4_string:
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:749
    // return self.arc4_string[a]
    intc_1 // 0
    bytec 14 // "explicit_key_arc4_string"
    app_local_get_ex
    assert // check self.arc4_string exists for account
    // tests/artifacts/StateOps/contract.py:747
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_byte[routing]() -> void:
get_arc4_byte:
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:753
    // return self.arc4_byte[a]
    intc_1 // 0
    bytec 15 // "explicit_key_arc4_byte"
    app_local_get_ex
    assert // check self.arc4_byte exists for account
    // tests/artifacts/StateOps/contract.py:751
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_bool[routing]() -> void:
get_arc4_bool:
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:757
    // return self.arc4_bool[a]
    intc_1 // 0
    bytec 16 // "explicit_key_arc4_bool"
    app_local_get_ex
    assert // check self.arc4_bool exists for account
    // tests/artifacts/StateOps/contract.py:755
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_address[routing]() -> void:
get_arc4_address:
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:761
    // return self.arc4_address[a]
    intc_1 // 0
    bytec 17 // "explicit_key_arc4_address"
    app_local_get_ex
    assert // check self.arc4_address exists for account
    // tests/artifacts/StateOps/contract.py:759
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_uint128[routing]() -> void:
get_arc4_uint128:
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:765
    // return self.arc4_uint128[a]
    intc_1 // 0
    bytec 18 // "explicit_key_arc4_uint128"
    app_local_get_ex
    assert // check self.arc4_uint128 exists for account
    // tests/artifacts/StateOps/contract.py:763
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.LocalStateContract.get_arc4_dynamic_bytes[routing]() -> void:
get_arc4_dynamic_bytes:
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/StateOps/contract.py:769
    // return self.arc4_dynamic_bytes[a]
    intc_1 // 0
    bytec 19 // "explicit_key_arc4_dynamic_bytes"
    app_local_get_ex
    assert // check self.arc4_dynamic_bytes exists for account
    // tests/artifacts/StateOps/contract.py:767
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiACAAEmFQQVH3x1AQAWaW1wbGljaXRfa2V5X2FyYzRfdWludAgAAAAAAAAFORhpbXBsaWNpdF9rZXlfYXJjNF9zdHJpbmcHAAVIZWxsbxZpbXBsaWNpdF9rZXlfYXJjNF9ieXRlFmltcGxpY2l0X2tleV9hcmM0X2Jvb2wZaW1wbGljaXRfa2V5X2FyYzRfYWRkcmVzcxlpbXBsaWNpdF9rZXlfYXJjNF91aW50MTI4EAAAABAAAAAAAAAAAAAAAAAfaW1wbGljaXRfa2V5X2FyYzRfZHluYW1pY19ieXRlcw8ADWR5bmFtaWMgYnl0ZXMSaW1wbGljaXRfa2V5X3R1cGxlFmV4cGxpY2l0X2tleV9hcmM0X3VpbnQYZXhwbGljaXRfa2V5X2FyYzRfc3RyaW5nFmV4cGxpY2l0X2tleV9hcmM0X2J5dGUWZXhwbGljaXRfa2V5X2FyYzRfYm9vbBlleHBsaWNpdF9rZXlfYXJjNF9hZGRyZXNzGWV4cGxpY2l0X2tleV9hcmM0X3VpbnQxMjgfZXhwbGljaXRfa2V5X2FyYzRfZHluYW1pY19ieXRlczEbQQHrghAEMMbVigQihLevBCa0V1YE7PYzsAQ+UxIjBD7WeZ0EUpbVygRnaofCBCW9EFkEmZt/KwRwZmhCBGUh1JsE4HxWzQSqGdK1BJcbBx8E/A/u2TYaAI4QAWcBUQE7ASUBDwD5AOMAzQCcAIYAcABaAEQALgAYAAIiQzEZFEQxGEQ2GgEXwByIApYoTFCwI0MxGRREMRhENhoBF8AciAJ1KExQsCNDMRkURDEYRDYaARfAHIgCVChMULAjQzEZFEQxGEQ2GgEXwByIAjMoTFCwI0MxGRREMRhENhoBF8AciAISKExQsCNDMRkURDEYRDYaARfAHIgB8ShMULAjQzEZFEQxGEQ2GgEXwByIAdAoTFCwI0MxGRREMRhENhoBF8AciAGXTwIWSwIVFlcGAk8DUEyAAgALUCkiTwRUUExQKExQsCNDMRkURDEYRDYaARfAHIgBWyhMULAjQzEZFEQxGEQ2GgEXwByIATooTFCwI0MxGRREMRhENhoBF8AciAEZKExQsCNDMRkURDEYRDYaARfAHIgA+ChMULAjQzEZFEQxGEQ2GgEXwByIANcoTFCwI0MxGRREMRhENhoBF8AciAC2KExQsCNDMRkURDEYRDYaARfAHIgAlihMULAjQzEZIxJEMRhEiAANI0MxGUD+hzEYFEQjQzIJKitmMgknBCcFZjIJJwYpZjIJJweAAYBmMgknCDIJZjIJJwknCmYyCScLJwxmMgknDYARAAAAAAAAAAoACwAABHRlc3RmMgknDitmMgknDycFZjIJJxApZjIJJxGAAYBmMgknEjIJZjIJJxMnCmYyCScUJwxmiYoBAYv/IipjRImKAQGL/yInBGNEiYoBAYv/IicGY0SJigEBi/8iJwdjRImKAQGL/yInCGNEiYoBAYv/IicJY0SJigEBi/8iJwtjRImKAQOL/yInDWNESSJbSwGBCFlLAhVLA04CUlcCAE8CgVBTiYoBAYv/IicOY0SJigEBi/8iJw9jRImKAQGL/yInEGNEiYoBAYv/IicRY0SJigEBi/8iJxJjRImKAQGL/yInE2NEiYoBAYv/IicUY0SJ", + "approval": "CiACAQAmFAQVH3x1FmltcGxpY2l0X2tleV9hcmM0X3VpbnQIAAAAAAAABTkYaW1wbGljaXRfa2V5X2FyYzRfc3RyaW5nBwAFSGVsbG8WaW1wbGljaXRfa2V5X2FyYzRfYnl0ZRZpbXBsaWNpdF9rZXlfYXJjNF9ib29sGWltcGxpY2l0X2tleV9hcmM0X2FkZHJlc3MZaW1wbGljaXRfa2V5X2FyYzRfdWludDEyOBAAAAAQAAAAAAAAAAAAAAAAH2ltcGxpY2l0X2tleV9hcmM0X2R5bmFtaWNfYnl0ZXMPAA1keW5hbWljIGJ5dGVzEmltcGxpY2l0X2tleV90dXBsZRZleHBsaWNpdF9rZXlfYXJjNF91aW50GGV4cGxpY2l0X2tleV9hcmM0X3N0cmluZxZleHBsaWNpdF9rZXlfYXJjNF9ieXRlFmV4cGxpY2l0X2tleV9hcmM0X2Jvb2wZZXhwbGljaXRfa2V5X2FyYzRfYWRkcmVzcxlleHBsaWNpdF9rZXlfYXJjNF91aW50MTI4H2V4cGxpY2l0X2tleV9hcmM0X2R5bmFtaWNfYnl0ZXMxG0EAkIAEMMbVijYaAI4BAHgxGRREMRhEgg8Es8+jiQTbhYF2BHgmd2IEQmNRyAQHXK6RBFnAuAsEDW+mkASX4Q2cBC5KjEkEsizSHgSz9EcBBO3ZcpcEZx01PASj/W/cBM0uXWY2GgCODwCQAJ0AqgC4AMYA1ADiAPAA/gEMARoBKAE2AUQBUgAxGSISMRgQREIACDEZFDEYFBBDMgkpKmYyCSsnBGYyCScFgAEAZjIJJwaAAYBmMgknBzIJZjIJJwgnCWYyCScKJwtmMgknDIARAAAAAAAAAAoACwAABHRlc3RmMgknDSpmMgknDicEZjIJJw+AAQBmMgknEIABgGYyCScRMglmMgknEicJZjIJJxMnC2YiQzYaASMpY0QoTFCwIkM2GgEjK2NEKExQsCJDNhoBIycFY0QoTFCwIkM2GgEjJwZjRChMULAiQzYaASMnB2NEKExQsCJDNhoBIycIY0QoTFCwIkM2GgEjJwpjRChMULAiQzYaASMnDGNEKExQsCJDNhoBIycNY0QoTFCwIkM2GgEjJw5jRChMULAiQzYaASMnD2NEKExQsCJDNhoBIycQY0QoTFCwIkM2GgEjJxFjRChMULAiQzYaASMnEmNEKExQsCJDNhoBIycTY0QoTFCwIkM=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAcctParamsGetContract.approval.teal b/tests/artifacts/StateOps/data/StateAcctParamsGetContract.approval.teal index b2b5d81..fa425d3 100644 --- a/tests/artifacts/StateOps/data/StateAcctParamsGetContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAcctParamsGetContract.approval.teal @@ -3,405 +3,41 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 0 + intcblock 1 bytecblock 0x151f7c75 // tests/artifacts/StateOps/contract.py:24 // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): txn NumAppArgs - bz main_bare_routing@20 - pushbytess 0x5f5b43e4 0x73dc93c7 0x5626dfeb 0xdc8a25bf 0x198ebd8c 0x2301ab26 0x9f68fca6 0xa975c2d1 0xd1e04801 0xb6966be5 0x195d5418 0x6adae3f1 0xdf8cfee5 0x6ad70d21 0x1735fd22 // method "verify_acct_balance(account)uint64", method "verify_acct_min_balance(account)uint64", method "verify_acct_auth_addr(account)address", method "verify_acct_total_num_uint(account)uint64", method "verify_acct_total_num_byte_slice(account)uint64", method "verify_acct_total_extra_app_pages(account)uint64", method "verify_acct_total_apps_created(account)uint64", method "verify_acct_total_apps_opted_in(account)uint64", method "verify_acct_total_assets_created(account)uint64", method "verify_acct_total_assets(account)uint64", method "verify_acct_total_boxes(account)uint64", method "verify_acct_total_box_bytes(account)uint64", method "verify_acct_incentive_eligible(account)bool", method "verify_acct_last_heartbeat(account)uint64", method "verify_acct_last_proposed(account)uint64" - txna ApplicationArgs 0 - match main_verify_acct_balance_route@3 main_verify_acct_min_balance_route@4 main_verify_acct_auth_addr_route@5 main_verify_acct_total_num_uint_route@6 main_verify_acct_total_num_byte_slice_route@7 main_verify_acct_total_extra_app_pages_route@8 main_verify_acct_total_apps_created_route@9 main_verify_acct_total_apps_opted_in_route@10 main_verify_acct_total_assets_created_route@11 main_verify_acct_total_assets_route@12 main_verify_acct_total_boxes_route@13 main_verify_acct_total_box_bytes_route@14 main_verify_acct_incentive_eligible_route@15 main_verify_acct_last_heartbeat_route@16 main_verify_acct_last_proposed_route@17 - -main_after_if_else@24: - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - intc_1 // 0 - return - -main_verify_acct_last_proposed_route@17: - // tests/artifacts/StateOps/contract.py:153 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:153 - // @arc4.abimethod() - callsub verify_acct_last_proposed - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_last_heartbeat_route@16: - // tests/artifacts/StateOps/contract.py:145 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:145 - // @arc4.abimethod() - callsub verify_acct_last_heartbeat - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_incentive_eligible_route@15: - // tests/artifacts/StateOps/contract.py:137 - // @arc4.abimethod() + bz main___algopy_default_create@22 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:137 - // @arc4.abimethod() - callsub verify_acct_incentive_eligible - pushbytes 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_box_bytes_route@14: - // tests/artifacts/StateOps/contract.py:129 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:129 - // @arc4.abimethod() - callsub verify_acct_total_box_bytes - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_boxes_route@13: - // tests/artifacts/StateOps/contract.py:121 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:121 - // @arc4.abimethod() - callsub verify_acct_total_boxes - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_assets_route@12: - // tests/artifacts/StateOps/contract.py:113 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:113 - // @arc4.abimethod() - callsub verify_acct_total_assets - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_assets_created_route@11: - // tests/artifacts/StateOps/contract.py:103 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:103 - // @arc4.abimethod() - callsub verify_acct_total_assets_created - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_apps_opted_in_route@10: - // tests/artifacts/StateOps/contract.py:95 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:95 - // @arc4.abimethod() - callsub verify_acct_total_apps_opted_in - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_apps_created_route@9: - // tests/artifacts/StateOps/contract.py:87 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:87 - // @arc4.abimethod() - callsub verify_acct_total_apps_created - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_extra_app_pages_route@8: - // tests/artifacts/StateOps/contract.py:77 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:77 - // @arc4.abimethod() - callsub verify_acct_total_extra_app_pages - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_total_num_byte_slice_route@7: - // tests/artifacts/StateOps/contract.py:67 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:67 - // @arc4.abimethod() - callsub verify_acct_total_num_byte_slice - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + assert + pushbytess 0x5f5b43e4 0x73dc93c7 0x5626dfeb 0xdc8a25bf 0x198ebd8c 0x2301ab26 0x9f68fca6 0xa975c2d1 0xd1e04801 0xb6966be5 0x195d5418 0x6adae3f1 0xdf8cfee5 0x6ad70d21 0x1735fd22 // method "verify_acct_balance(account)uint64", method "verify_acct_min_balance(account)uint64", method "verify_acct_auth_addr(account)address", method "verify_acct_total_num_uint(account)uint64", method "verify_acct_total_num_byte_slice(account)uint64", method "verify_acct_total_extra_app_pages(account)uint64", method "verify_acct_total_apps_created(account)uint64", method "verify_acct_total_apps_opted_in(account)uint64", method "verify_acct_total_assets_created(account)uint64", method "verify_acct_total_assets(account)uint64", method "verify_acct_total_boxes(account)uint64", method "verify_acct_total_box_bytes(account)uint64", method "verify_acct_incentive_eligible(account)bool", method "verify_acct_last_heartbeat(account)uint64", method "verify_acct_last_proposed(account)uint64" + txna ApplicationArgs 0 + match verify_acct_balance verify_acct_min_balance verify_acct_auth_addr verify_acct_total_num_uint verify_acct_total_num_byte_slice verify_acct_total_extra_app_pages verify_acct_total_apps_created verify_acct_total_apps_opted_in verify_acct_total_assets_created verify_acct_total_assets verify_acct_total_boxes verify_acct_total_box_bytes verify_acct_incentive_eligible verify_acct_last_heartbeat verify_acct_last_proposed + err -main_verify_acct_total_num_uint_route@6: - // tests/artifacts/StateOps/contract.py:59 - // @arc4.abimethod() +main___algopy_default_create@22: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:59 - // @arc4.abimethod() - callsub verify_acct_total_num_uint - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_acct_auth_addr_route@5: - // tests/artifacts/StateOps/contract.py:51 - // @arc4.abimethod() - txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:51 - // @arc4.abimethod() - callsub verify_acct_auth_addr - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_acct_min_balance_route@4: - // tests/artifacts/StateOps/contract.py:38 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txna ApplicationArgs 1 - btoi - txnas Accounts - // tests/artifacts/StateOps/contract.py:38 - // @arc4.abimethod() - callsub verify_acct_min_balance - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_acct_balance_route@3: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_balance[routing]() -> void: +verify_acct_balance: // tests/artifacts/StateOps/contract.py:25 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): + // @arc4.abimethod(resource_encoding="index") txna ApplicationArgs 1 btoi txnas Accounts - // tests/artifacts/StateOps/contract.py:25 - // @arc4.abimethod() - callsub verify_acct_balance - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_bare_routing@20: - // tests/artifacts/StateOps/contract.py:24 - // class StateAcctParamsGetContract(ARC4Contract, avm_version=11): - txn OnCompletion - bnz main_after_if_else@24 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_balance(a: bytes) -> uint64: -verify_acct_balance: - // tests/artifacts/StateOps/contract.py:25-26 - // @arc4.abimethod() - // def verify_acct_balance(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 // tests/artifacts/StateOps/contract.py:27 // value, funded = op.AcctParamsGet.acct_balance(a) - frame_dig -1 + dup acct_params_get AcctBalance // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -422,7 +58,7 @@ verify_acct_balance: assert // expected funded by index to match // tests/artifacts/StateOps/contract.py:31 // assert value == a.balance, "expected Account balance to match" - frame_dig -1 + dig 1 acct_params_get AcctBalance assert // account funded dig 1 @@ -430,7 +66,7 @@ verify_acct_balance: assert // expected Account balance to match // tests/artifacts/StateOps/contract.py:32 // assert value == algopy.op.balance(a), "expected op.balance to match" - frame_dig -1 + swap balance dig 1 == @@ -447,20 +83,27 @@ verify_acct_balance: dig 1 == assert // expected op.balance by index to match - // tests/artifacts/StateOps/contract.py:36 - // return value - retsub + // tests/artifacts/StateOps/contract.py:25 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_min_balance(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_min_balance[routing]() -> void: verify_acct_min_balance: - // tests/artifacts/StateOps/contract.py:38-39 - // @arc4.abimethod() - // def verify_acct_min_balance(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:38 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:40 // value, funded = op.AcctParamsGet.acct_min_balance(a) - frame_dig -1 + dup acct_params_get AcctMinBalance // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -481,7 +124,7 @@ verify_acct_min_balance: assert // expected funded by index to match // tests/artifacts/StateOps/contract.py:44 // assert value == a.min_balance, "expected Account min_balance to match" - frame_dig -1 + dig 1 acct_params_get AcctMinBalance assert // account funded dig 1 @@ -489,7 +132,7 @@ verify_acct_min_balance: assert // expected Account min_balance to match // tests/artifacts/StateOps/contract.py:45 // assert value == algopy.op.min_balance(a), "expected op.min_balance to match" - frame_dig -1 + swap min_balance dig 1 == @@ -506,20 +149,26 @@ verify_acct_min_balance: dig 1 == assert // expected op.min_balance by index to match - // tests/artifacts/StateOps/contract.py:49 - // return value - retsub + // tests/artifacts/StateOps/contract.py:38 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_auth_addr(a: bytes) -> bytes: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_auth_addr[routing]() -> void: verify_acct_auth_addr: - // tests/artifacts/StateOps/contract.py:51-52 - // @arc4.abimethod() - // def verify_acct_auth_addr(self, a: algopy.Account) -> arc4.Address: - proto 1 1 + // tests/artifacts/StateOps/contract.py:51 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:53 // value, funded = op.AcctParamsGet.acct_auth_addr(a) - frame_dig -1 acct_params_get AcctAuthAddr // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -538,20 +187,25 @@ verify_acct_auth_addr: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:57 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:51 + // @arc4.abimethod(resource_encoding="index") + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_uint(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_uint[routing]() -> void: verify_acct_total_num_uint: - // tests/artifacts/StateOps/contract.py:59-60 - // @arc4.abimethod() - // def verify_acct_total_num_uint(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:59 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:61 // value, funded = op.AcctParamsGet.acct_total_num_uint(a) - frame_dig -1 acct_params_get AcctTotalNumUint // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -570,20 +224,26 @@ verify_acct_total_num_uint: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:65 - // return value - retsub + // tests/artifacts/StateOps/contract.py:59 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_byte_slice(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_byte_slice[routing]() -> void: verify_acct_total_num_byte_slice: - // tests/artifacts/StateOps/contract.py:67-68 - // @arc4.abimethod() - // def verify_acct_total_num_byte_slice(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:67 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:69 // value, funded = op.AcctParamsGet.acct_total_num_byte_slice(a) - frame_dig -1 acct_params_get AcctTotalNumByteSlice // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -604,20 +264,26 @@ verify_acct_total_num_byte_slice: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:75 - // return value - retsub + // tests/artifacts/StateOps/contract.py:67 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_extra_app_pages(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_extra_app_pages[routing]() -> void: verify_acct_total_extra_app_pages: - // tests/artifacts/StateOps/contract.py:77-78 - // @arc4.abimethod() - // def verify_acct_total_extra_app_pages(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:77 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:79 // value, funded = op.AcctParamsGet.acct_total_extra_app_pages(a) - frame_dig -1 acct_params_get AcctTotalExtraAppPages // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -638,20 +304,26 @@ verify_acct_total_extra_app_pages: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:85 - // return value - retsub + // tests/artifacts/StateOps/contract.py:77 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_created(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_created[routing]() -> void: verify_acct_total_apps_created: - // tests/artifacts/StateOps/contract.py:87-88 - // @arc4.abimethod() - // def verify_acct_total_apps_created(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:87 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:89 // value, funded = op.AcctParamsGet.acct_total_apps_created(a) - frame_dig -1 acct_params_get AcctTotalAppsCreated // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -670,20 +342,26 @@ verify_acct_total_apps_created: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:93 - // return value - retsub + // tests/artifacts/StateOps/contract.py:87 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_opted_in(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_opted_in[routing]() -> void: verify_acct_total_apps_opted_in: - // tests/artifacts/StateOps/contract.py:95-96 - // @arc4.abimethod() - // def verify_acct_total_apps_opted_in(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:95 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:97 // value, funded = op.AcctParamsGet.acct_total_apps_opted_in(a) - frame_dig -1 acct_params_get AcctTotalAppsOptedIn // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -702,20 +380,26 @@ verify_acct_total_apps_opted_in: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:101 - // return value - retsub + // tests/artifacts/StateOps/contract.py:95 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets_created(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets_created[routing]() -> void: verify_acct_total_assets_created: - // tests/artifacts/StateOps/contract.py:103-104 - // @arc4.abimethod() - // def verify_acct_total_assets_created(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:103 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:105 // value, funded = op.AcctParamsGet.acct_total_assets_created(a) - frame_dig -1 acct_params_get AcctTotalAssetsCreated // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -736,20 +420,26 @@ verify_acct_total_assets_created: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:111 - // return value - retsub + // tests/artifacts/StateOps/contract.py:103 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets[routing]() -> void: verify_acct_total_assets: - // tests/artifacts/StateOps/contract.py:113-114 - // @arc4.abimethod() - // def verify_acct_total_assets(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:113 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:115 // value, funded = op.AcctParamsGet.acct_total_assets(a) - frame_dig -1 acct_params_get AcctTotalAssets // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -768,20 +458,26 @@ verify_acct_total_assets: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:119 - // return value - retsub + // tests/artifacts/StateOps/contract.py:113 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_boxes(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_boxes[routing]() -> void: verify_acct_total_boxes: - // tests/artifacts/StateOps/contract.py:121-122 - // @arc4.abimethod() - // def verify_acct_total_boxes(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:121 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:123 // value, funded = op.AcctParamsGet.acct_total_boxes(a) - frame_dig -1 acct_params_get AcctTotalBoxes // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -800,20 +496,26 @@ verify_acct_total_boxes: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:127 - // return value - retsub + // tests/artifacts/StateOps/contract.py:121 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_box_bytes(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_box_bytes[routing]() -> void: verify_acct_total_box_bytes: - // tests/artifacts/StateOps/contract.py:129-130 - // @arc4.abimethod() - // def verify_acct_total_box_bytes(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:129 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:131 // value, funded = op.AcctParamsGet.acct_total_box_bytes(a) - frame_dig -1 acct_params_get AcctTotalBoxBytes // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -832,20 +534,26 @@ verify_acct_total_box_bytes: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:135 - // return value - retsub + // tests/artifacts/StateOps/contract.py:129 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_incentive_eligible(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_incentive_eligible[routing]() -> void: verify_acct_incentive_eligible: - // tests/artifacts/StateOps/contract.py:137-138 - // @arc4.abimethod() - // def verify_acct_incentive_eligible(self, a: algopy.Account) -> bool: - proto 1 1 + // tests/artifacts/StateOps/contract.py:137 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:139 // value, funded = op.AcctParamsGet.acct_incentive_eligible(a) - frame_dig -1 acct_params_get AcctIncentiveEligible // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -864,20 +572,29 @@ verify_acct_incentive_eligible: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:143 - // return value - retsub + // tests/artifacts/StateOps/contract.py:137 + // @arc4.abimethod(resource_encoding="index") + pushbytes 0x00 + pushint 0 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_heartbeat(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_heartbeat[routing]() -> void: verify_acct_last_heartbeat: - // tests/artifacts/StateOps/contract.py:145-146 - // @arc4.abimethod() - // def verify_acct_last_heartbeat(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:145 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:147 // value, funded = op.AcctParamsGet.acct_last_heartbeat(a) - frame_dig -1 acct_params_get AcctLastHeartbeat // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -896,20 +613,26 @@ verify_acct_last_heartbeat: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:151 - // return value - retsub + // tests/artifacts/StateOps/contract.py:145 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_proposed(a: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_proposed[routing]() -> void: verify_acct_last_proposed: - // tests/artifacts/StateOps/contract.py:153-154 - // @arc4.abimethod() - // def verify_acct_last_proposed(self, a: algopy.Account) -> algopy.UInt64: - proto 1 1 + // tests/artifacts/StateOps/contract.py:153 + // @arc4.abimethod(resource_encoding="index") + txna ApplicationArgs 1 + btoi + txnas Accounts // tests/artifacts/StateOps/contract.py:155 // value, funded = op.AcctParamsGet.acct_last_proposed(a) - frame_dig -1 acct_params_get AcctLastProposed // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -928,6 +651,12 @@ verify_acct_last_proposed: // assert funded == funded_index, "expected funded by index to match" == assert // expected funded by index to match - // tests/artifacts/StateOps/contract.py:159 - // return value - retsub + // tests/artifacts/StateOps/contract.py:153 + // @arc4.abimethod(resource_encoding="index") + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return diff --git a/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc32.json b/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc32.json index 628dde3..be01c9e 100644 --- a/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc32.json @@ -77,7 +77,7 @@ } }, "source": { - "approval": "#pragma version 11
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txn NumAppArgs
    bz main_bare_routing@20
    pushbytess 0x5f5b43e4 0x73dc93c7 0x5626dfeb 0xdc8a25bf 0x198ebd8c 0x2301ab26 0x9f68fca6 0xa975c2d1 0xd1e04801 0xb6966be5 0x195d5418 0x6adae3f1 0xdf8cfee5 0x6ad70d21 0x1735fd22 // method "verify_acct_balance(account)uint64", method "verify_acct_min_balance(account)uint64", method "verify_acct_auth_addr(account)address", method "verify_acct_total_num_uint(account)uint64", method "verify_acct_total_num_byte_slice(account)uint64", method "verify_acct_total_extra_app_pages(account)uint64", method "verify_acct_total_apps_created(account)uint64", method "verify_acct_total_apps_opted_in(account)uint64", method "verify_acct_total_assets_created(account)uint64", method "verify_acct_total_assets(account)uint64", method "verify_acct_total_boxes(account)uint64", method "verify_acct_total_box_bytes(account)uint64", method "verify_acct_incentive_eligible(account)bool", method "verify_acct_last_heartbeat(account)uint64", method "verify_acct_last_proposed(account)uint64"
    txna ApplicationArgs 0
    match main_verify_acct_balance_route@3 main_verify_acct_min_balance_route@4 main_verify_acct_auth_addr_route@5 main_verify_acct_total_num_uint_route@6 main_verify_acct_total_num_byte_slice_route@7 main_verify_acct_total_extra_app_pages_route@8 main_verify_acct_total_apps_created_route@9 main_verify_acct_total_apps_opted_in_route@10 main_verify_acct_total_assets_created_route@11 main_verify_acct_total_assets_route@12 main_verify_acct_total_boxes_route@13 main_verify_acct_total_box_bytes_route@14 main_verify_acct_incentive_eligible_route@15 main_verify_acct_last_heartbeat_route@16 main_verify_acct_last_proposed_route@17

main_after_if_else@24:
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    intc_1 // 0
    return

main_verify_acct_last_proposed_route@17:
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod()
    callsub verify_acct_last_proposed
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_last_heartbeat_route@16:
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod()
    callsub verify_acct_last_heartbeat
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_incentive_eligible_route@15:
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod()
    callsub verify_acct_incentive_eligible
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_box_bytes_route@14:
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod()
    callsub verify_acct_total_box_bytes
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_boxes_route@13:
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod()
    callsub verify_acct_total_boxes
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_assets_route@12:
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod()
    callsub verify_acct_total_assets
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_assets_created_route@11:
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod()
    callsub verify_acct_total_assets_created
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_apps_opted_in_route@10:
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod()
    callsub verify_acct_total_apps_opted_in
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_apps_created_route@9:
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod()
    callsub verify_acct_total_apps_created
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_extra_app_pages_route@8:
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod()
    callsub verify_acct_total_extra_app_pages
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_num_byte_slice_route@7:
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod()
    callsub verify_acct_total_num_byte_slice
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_num_uint_route@6:
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod()
    callsub verify_acct_total_num_uint
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_auth_addr_route@5:
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod()
    callsub verify_acct_auth_addr
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_min_balance_route@4:
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod()
    callsub verify_acct_min_balance
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_balance_route@3:
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod()
    callsub verify_acct_balance
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@20:
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txn OnCompletion
    bnz main_after_if_else@24
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_balance(a: bytes) -> uint64:
verify_acct_balance:
    // tests/artifacts/StateOps/contract.py:25-26
    // @arc4.abimethod()
    // def verify_acct_balance(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:27
    // value, funded = op.AcctParamsGet.acct_balance(a)
    frame_dig -1
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:28
    // value_index, funded_index = op.AcctParamsGet.acct_balance(_get_1st_ref_index())
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:29
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:30
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:31
    // assert value == a.balance, "expected Account balance to match"
    frame_dig -1
    acct_params_get AcctBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account balance to match
    // tests/artifacts/StateOps/contract.py:32
    // assert value == algopy.op.balance(a), "expected op.balance to match"
    frame_dig -1
    balance
    dig 1
    ==
    assert // expected op.balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:33-35
    // assert value == algopy.op.balance(
    //     _get_1st_ref_index()
    // ), "expected op.balance by index to match"
    balance
    dig 1
    ==
    assert // expected op.balance by index to match
    // tests/artifacts/StateOps/contract.py:36
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_min_balance(a: bytes) -> uint64:
verify_acct_min_balance:
    // tests/artifacts/StateOps/contract.py:38-39
    // @arc4.abimethod()
    // def verify_acct_min_balance(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:40
    // value, funded = op.AcctParamsGet.acct_min_balance(a)
    frame_dig -1
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:41
    // value_index, funded_index = op.AcctParamsGet.acct_min_balance(_get_1st_ref_index())
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:42
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:43
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:44
    // assert value == a.min_balance, "expected Account min_balance to match"
    frame_dig -1
    acct_params_get AcctMinBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account min_balance to match
    // tests/artifacts/StateOps/contract.py:45
    // assert value == algopy.op.min_balance(a), "expected op.min_balance to match"
    frame_dig -1
    min_balance
    dig 1
    ==
    assert // expected op.min_balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:46-48
    // assert value == algopy.op.min_balance(
    //     _get_1st_ref_index()
    // ), "expected op.min_balance by index to match"
    min_balance
    dig 1
    ==
    assert // expected op.min_balance by index to match
    // tests/artifacts/StateOps/contract.py:49
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_auth_addr(a: bytes) -> bytes:
verify_acct_auth_addr:
    // tests/artifacts/StateOps/contract.py:51-52
    // @arc4.abimethod()
    // def verify_acct_auth_addr(self, a: algopy.Account) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:53
    // value, funded = op.AcctParamsGet.acct_auth_addr(a)
    frame_dig -1
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:54
    // value_index, funded_index = op.AcctParamsGet.acct_auth_addr(_get_1st_ref_index())
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:55
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:56
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:57
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_uint(a: bytes) -> uint64:
verify_acct_total_num_uint:
    // tests/artifacts/StateOps/contract.py:59-60
    // @arc4.abimethod()
    // def verify_acct_total_num_uint(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:61
    // value, funded = op.AcctParamsGet.acct_total_num_uint(a)
    frame_dig -1
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:62
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_uint(_get_1st_ref_index())
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:63
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:64
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:65
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_byte_slice(a: bytes) -> uint64:
verify_acct_total_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:67-68
    // @arc4.abimethod()
    // def verify_acct_total_num_byte_slice(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:69
    // value, funded = op.AcctParamsGet.acct_total_num_byte_slice(a)
    frame_dig -1
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:70-72
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_byte_slice(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:73
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:74
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:75
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_extra_app_pages(a: bytes) -> uint64:
verify_acct_total_extra_app_pages:
    // tests/artifacts/StateOps/contract.py:77-78
    // @arc4.abimethod()
    // def verify_acct_total_extra_app_pages(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:79
    // value, funded = op.AcctParamsGet.acct_total_extra_app_pages(a)
    frame_dig -1
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:80-82
    // value_index, funded_index = op.AcctParamsGet.acct_total_extra_app_pages(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:83
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:84
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:85
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_created(a: bytes) -> uint64:
verify_acct_total_apps_created:
    // tests/artifacts/StateOps/contract.py:87-88
    // @arc4.abimethod()
    // def verify_acct_total_apps_created(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:89
    // value, funded = op.AcctParamsGet.acct_total_apps_created(a)
    frame_dig -1
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:90
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_created(_get_1st_ref_index())
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:91
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:92
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:93
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_opted_in(a: bytes) -> uint64:
verify_acct_total_apps_opted_in:
    // tests/artifacts/StateOps/contract.py:95-96
    // @arc4.abimethod()
    // def verify_acct_total_apps_opted_in(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:97
    // value, funded = op.AcctParamsGet.acct_total_apps_opted_in(a)
    frame_dig -1
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:98
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_opted_in(_get_1st_ref_index())
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:99
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:100
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:101
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets_created(a: bytes) -> uint64:
verify_acct_total_assets_created:
    // tests/artifacts/StateOps/contract.py:103-104
    // @arc4.abimethod()
    // def verify_acct_total_assets_created(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:105
    // value, funded = op.AcctParamsGet.acct_total_assets_created(a)
    frame_dig -1
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:106-108
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets_created(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:109
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:110
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:111
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets(a: bytes) -> uint64:
verify_acct_total_assets:
    // tests/artifacts/StateOps/contract.py:113-114
    // @arc4.abimethod()
    // def verify_acct_total_assets(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:115
    // value, funded = op.AcctParamsGet.acct_total_assets(a)
    frame_dig -1
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:116
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets(_get_1st_ref_index())
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:117
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:118
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:119
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_boxes(a: bytes) -> uint64:
verify_acct_total_boxes:
    // tests/artifacts/StateOps/contract.py:121-122
    // @arc4.abimethod()
    // def verify_acct_total_boxes(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:123
    // value, funded = op.AcctParamsGet.acct_total_boxes(a)
    frame_dig -1
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:124
    // value_index, funded_index = op.AcctParamsGet.acct_total_boxes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:125
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:126
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:127
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_box_bytes(a: bytes) -> uint64:
verify_acct_total_box_bytes:
    // tests/artifacts/StateOps/contract.py:129-130
    // @arc4.abimethod()
    // def verify_acct_total_box_bytes(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:131
    // value, funded = op.AcctParamsGet.acct_total_box_bytes(a)
    frame_dig -1
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:132
    // value_index, funded_index = op.AcctParamsGet.acct_total_box_bytes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:133
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:134
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:135
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_incentive_eligible(a: bytes) -> uint64:
verify_acct_incentive_eligible:
    // tests/artifacts/StateOps/contract.py:137-138
    // @arc4.abimethod()
    // def verify_acct_incentive_eligible(self, a: algopy.Account) -> bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:139
    // value, funded = op.AcctParamsGet.acct_incentive_eligible(a)
    frame_dig -1
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:140
    // value_index, funded_index = op.AcctParamsGet.acct_incentive_eligible(_get_1st_ref_index())
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:141
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:142
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:143
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_heartbeat(a: bytes) -> uint64:
verify_acct_last_heartbeat:
    // tests/artifacts/StateOps/contract.py:145-146
    // @arc4.abimethod()
    // def verify_acct_last_heartbeat(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:147
    // value, funded = op.AcctParamsGet.acct_last_heartbeat(a)
    frame_dig -1
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:148
    // value_index, funded_index = op.AcctParamsGet.acct_last_heartbeat(_get_1st_ref_index())
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:149
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:150
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:151
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_proposed(a: bytes) -> uint64:
verify_acct_last_proposed:
    // tests/artifacts/StateOps/contract.py:153-154
    // @arc4.abimethod()
    // def verify_acct_last_proposed(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:155
    // value, funded = op.AcctParamsGet.acct_last_proposed(a)
    frame_dig -1
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:156
    // value_index, funded_index = op.AcctParamsGet.acct_last_proposed(_get_1st_ref_index())
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:157
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:158
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:159
    // return value
    retsub
", + "approval": "#pragma version 11
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txn NumAppArgs
    bz main___algopy_default_create@22
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x5f5b43e4 0x73dc93c7 0x5626dfeb 0xdc8a25bf 0x198ebd8c 0x2301ab26 0x9f68fca6 0xa975c2d1 0xd1e04801 0xb6966be5 0x195d5418 0x6adae3f1 0xdf8cfee5 0x6ad70d21 0x1735fd22 // method "verify_acct_balance(account)uint64", method "verify_acct_min_balance(account)uint64", method "verify_acct_auth_addr(account)address", method "verify_acct_total_num_uint(account)uint64", method "verify_acct_total_num_byte_slice(account)uint64", method "verify_acct_total_extra_app_pages(account)uint64", method "verify_acct_total_apps_created(account)uint64", method "verify_acct_total_apps_opted_in(account)uint64", method "verify_acct_total_assets_created(account)uint64", method "verify_acct_total_assets(account)uint64", method "verify_acct_total_boxes(account)uint64", method "verify_acct_total_box_bytes(account)uint64", method "verify_acct_incentive_eligible(account)bool", method "verify_acct_last_heartbeat(account)uint64", method "verify_acct_last_proposed(account)uint64"
    txna ApplicationArgs 0
    match verify_acct_balance verify_acct_min_balance verify_acct_auth_addr verify_acct_total_num_uint verify_acct_total_num_byte_slice verify_acct_total_extra_app_pages verify_acct_total_apps_created verify_acct_total_apps_opted_in verify_acct_total_assets_created verify_acct_total_assets verify_acct_total_boxes verify_acct_total_box_bytes verify_acct_incentive_eligible verify_acct_last_heartbeat verify_acct_last_proposed
    err

main___algopy_default_create@22:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_balance[routing]() -> void:
verify_acct_balance:
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:27
    // value, funded = op.AcctParamsGet.acct_balance(a)
    dup
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:28
    // value_index, funded_index = op.AcctParamsGet.acct_balance(_get_1st_ref_index())
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:29
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:30
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:31
    // assert value == a.balance, "expected Account balance to match"
    dig 1
    acct_params_get AcctBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account balance to match
    // tests/artifacts/StateOps/contract.py:32
    // assert value == algopy.op.balance(a), "expected op.balance to match"
    swap
    balance
    dig 1
    ==
    assert // expected op.balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:33-35
    // assert value == algopy.op.balance(
    //     _get_1st_ref_index()
    // ), "expected op.balance by index to match"
    balance
    dig 1
    ==
    assert // expected op.balance by index to match
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_min_balance[routing]() -> void:
verify_acct_min_balance:
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:40
    // value, funded = op.AcctParamsGet.acct_min_balance(a)
    dup
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:41
    // value_index, funded_index = op.AcctParamsGet.acct_min_balance(_get_1st_ref_index())
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:42
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:43
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:44
    // assert value == a.min_balance, "expected Account min_balance to match"
    dig 1
    acct_params_get AcctMinBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account min_balance to match
    // tests/artifacts/StateOps/contract.py:45
    // assert value == algopy.op.min_balance(a), "expected op.min_balance to match"
    swap
    min_balance
    dig 1
    ==
    assert // expected op.min_balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:46-48
    // assert value == algopy.op.min_balance(
    //     _get_1st_ref_index()
    // ), "expected op.min_balance by index to match"
    min_balance
    dig 1
    ==
    assert // expected op.min_balance by index to match
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_auth_addr[routing]() -> void:
verify_acct_auth_addr:
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:53
    // value, funded = op.AcctParamsGet.acct_auth_addr(a)
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:54
    // value_index, funded_index = op.AcctParamsGet.acct_auth_addr(_get_1st_ref_index())
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:55
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:56
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod(resource_encoding="index")
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_uint[routing]() -> void:
verify_acct_total_num_uint:
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:61
    // value, funded = op.AcctParamsGet.acct_total_num_uint(a)
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:62
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_uint(_get_1st_ref_index())
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:63
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:64
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_byte_slice[routing]() -> void:
verify_acct_total_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:69
    // value, funded = op.AcctParamsGet.acct_total_num_byte_slice(a)
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:70-72
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_byte_slice(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:73
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:74
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_extra_app_pages[routing]() -> void:
verify_acct_total_extra_app_pages:
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:79
    // value, funded = op.AcctParamsGet.acct_total_extra_app_pages(a)
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:80-82
    // value_index, funded_index = op.AcctParamsGet.acct_total_extra_app_pages(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:83
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:84
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_created[routing]() -> void:
verify_acct_total_apps_created:
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:89
    // value, funded = op.AcctParamsGet.acct_total_apps_created(a)
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:90
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_created(_get_1st_ref_index())
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:91
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:92
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_opted_in[routing]() -> void:
verify_acct_total_apps_opted_in:
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:97
    // value, funded = op.AcctParamsGet.acct_total_apps_opted_in(a)
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:98
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_opted_in(_get_1st_ref_index())
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:99
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:100
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets_created[routing]() -> void:
verify_acct_total_assets_created:
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:105
    // value, funded = op.AcctParamsGet.acct_total_assets_created(a)
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:106-108
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets_created(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:109
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:110
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets[routing]() -> void:
verify_acct_total_assets:
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:115
    // value, funded = op.AcctParamsGet.acct_total_assets(a)
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:116
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets(_get_1st_ref_index())
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:117
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:118
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_boxes[routing]() -> void:
verify_acct_total_boxes:
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:123
    // value, funded = op.AcctParamsGet.acct_total_boxes(a)
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:124
    // value_index, funded_index = op.AcctParamsGet.acct_total_boxes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:125
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:126
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_box_bytes[routing]() -> void:
verify_acct_total_box_bytes:
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:131
    // value, funded = op.AcctParamsGet.acct_total_box_bytes(a)
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:132
    // value_index, funded_index = op.AcctParamsGet.acct_total_box_bytes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:133
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:134
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_incentive_eligible[routing]() -> void:
verify_acct_incentive_eligible:
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:139
    // value, funded = op.AcctParamsGet.acct_incentive_eligible(a)
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:140
    // value_index, funded_index = op.AcctParamsGet.acct_incentive_eligible(_get_1st_ref_index())
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:141
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:142
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod(resource_encoding="index")
    pushbytes 0x00
    pushint 0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_heartbeat[routing]() -> void:
verify_acct_last_heartbeat:
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:147
    // value, funded = op.AcctParamsGet.acct_last_heartbeat(a)
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:148
    // value_index, funded_index = op.AcctParamsGet.acct_last_heartbeat(_get_1st_ref_index())
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:149
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:150
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_proposed[routing]() -> void:
verify_acct_last_proposed:
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:155
    // value, funded = op.AcctParamsGet.acct_last_proposed(a)
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:156
    // value_index, funded_index = op.AcctParamsGet.acct_last_proposed(_get_1st_ref_index())
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:157
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:158
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc56.json b/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc56.json index 4b6388b..8a244de 100644 --- a/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAcctParamsGetContract.arc56.json @@ -356,130 +356,96 @@ "sourceInfo": [ { "pc": [ - 134, - 157, - 180, - 209, - 232, - 255, - 278, - 301, - 324, - 347, - 370, - 393, - 416, - 438, - 461 - ], - "errorMessage": "OnCompletion is not NoOp" - }, - { - "pc": [ - 517, - 564 + 19 ], - "errorMessage": "account funded" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 489 + 143 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 137, - 160, - 183, - 212, - 235, - 258, - 281, - 304, - 327, - 350, - 373, - 396, - 419, - 441, - 464 + 171, + 225 ], - "errorMessage": "can only call when not creating" + "errorMessage": "account funded" }, { "pc": [ - 521 + 175 ], "errorMessage": "expected Account balance to match" }, { "pc": [ - 568 + 229 ], "errorMessage": "expected Account min_balance to match" }, { "pc": [ - 512, - 559, - 606, - 628, - 650, - 672, - 694, - 716, - 738, - 760, - 782, - 804, - 826, - 848, - 870 + 166, + 220, + 273, + 301, + 330, + 359, + 388, + 417, + 446, + 475, + 504, + 533, + 562, + 598, + 627 ], "errorMessage": "expected funded by index to match" }, { "pc": [ - 537 + 190 ], "errorMessage": "expected op.balance by index to match" }, { "pc": [ - 528 + 181 ], "errorMessage": "expected op.balance to match" }, { "pc": [ - 584 + 244 ], "errorMessage": "expected op.min_balance by index to match" }, { "pc": [ - 575 + 235 ], "errorMessage": "expected op.min_balance to match" }, { "pc": [ - 510, - 557, - 604, - 626, - 648, - 670, - 692, - 714, - 736, - 758, - 780, - 802, - 824, - 846, - 868 + 164, + 218, + 271, + 299, + 328, + 357, + 386, + 415, + 444, + 473, + 502, + 531, + 560, + 596, + 625 ], "errorMessage": "expected value by index to match" } @@ -492,18 +458,18 @@ } }, "source": { - "approval": "#pragma version 11
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txn NumAppArgs
    bz main_bare_routing@20
    pushbytess 0x5f5b43e4 0x73dc93c7 0x5626dfeb 0xdc8a25bf 0x198ebd8c 0x2301ab26 0x9f68fca6 0xa975c2d1 0xd1e04801 0xb6966be5 0x195d5418 0x6adae3f1 0xdf8cfee5 0x6ad70d21 0x1735fd22 // method "verify_acct_balance(account)uint64", method "verify_acct_min_balance(account)uint64", method "verify_acct_auth_addr(account)address", method "verify_acct_total_num_uint(account)uint64", method "verify_acct_total_num_byte_slice(account)uint64", method "verify_acct_total_extra_app_pages(account)uint64", method "verify_acct_total_apps_created(account)uint64", method "verify_acct_total_apps_opted_in(account)uint64", method "verify_acct_total_assets_created(account)uint64", method "verify_acct_total_assets(account)uint64", method "verify_acct_total_boxes(account)uint64", method "verify_acct_total_box_bytes(account)uint64", method "verify_acct_incentive_eligible(account)bool", method "verify_acct_last_heartbeat(account)uint64", method "verify_acct_last_proposed(account)uint64"
    txna ApplicationArgs 0
    match main_verify_acct_balance_route@3 main_verify_acct_min_balance_route@4 main_verify_acct_auth_addr_route@5 main_verify_acct_total_num_uint_route@6 main_verify_acct_total_num_byte_slice_route@7 main_verify_acct_total_extra_app_pages_route@8 main_verify_acct_total_apps_created_route@9 main_verify_acct_total_apps_opted_in_route@10 main_verify_acct_total_assets_created_route@11 main_verify_acct_total_assets_route@12 main_verify_acct_total_boxes_route@13 main_verify_acct_total_box_bytes_route@14 main_verify_acct_incentive_eligible_route@15 main_verify_acct_last_heartbeat_route@16 main_verify_acct_last_proposed_route@17

main_after_if_else@24:
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    intc_1 // 0
    return

main_verify_acct_last_proposed_route@17:
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod()
    callsub verify_acct_last_proposed
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_last_heartbeat_route@16:
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod()
    callsub verify_acct_last_heartbeat
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_incentive_eligible_route@15:
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod()
    callsub verify_acct_incentive_eligible
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_box_bytes_route@14:
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod()
    callsub verify_acct_total_box_bytes
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_boxes_route@13:
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod()
    callsub verify_acct_total_boxes
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_assets_route@12:
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod()
    callsub verify_acct_total_assets
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_assets_created_route@11:
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod()
    callsub verify_acct_total_assets_created
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_apps_opted_in_route@10:
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod()
    callsub verify_acct_total_apps_opted_in
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_apps_created_route@9:
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod()
    callsub verify_acct_total_apps_created
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_extra_app_pages_route@8:
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod()
    callsub verify_acct_total_extra_app_pages
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_num_byte_slice_route@7:
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod()
    callsub verify_acct_total_num_byte_slice
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_total_num_uint_route@6:
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod()
    callsub verify_acct_total_num_uint
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_auth_addr_route@5:
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod()
    callsub verify_acct_auth_addr
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_min_balance_route@4:
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod()
    callsub verify_acct_min_balance
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_acct_balance_route@3:
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod()
    callsub verify_acct_balance
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@20:
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txn OnCompletion
    bnz main_after_if_else@24
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_balance(a: bytes) -> uint64:
verify_acct_balance:
    // tests/artifacts/StateOps/contract.py:25-26
    // @arc4.abimethod()
    // def verify_acct_balance(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:27
    // value, funded = op.AcctParamsGet.acct_balance(a)
    frame_dig -1
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:28
    // value_index, funded_index = op.AcctParamsGet.acct_balance(_get_1st_ref_index())
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:29
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:30
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:31
    // assert value == a.balance, "expected Account balance to match"
    frame_dig -1
    acct_params_get AcctBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account balance to match
    // tests/artifacts/StateOps/contract.py:32
    // assert value == algopy.op.balance(a), "expected op.balance to match"
    frame_dig -1
    balance
    dig 1
    ==
    assert // expected op.balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:33-35
    // assert value == algopy.op.balance(
    //     _get_1st_ref_index()
    // ), "expected op.balance by index to match"
    balance
    dig 1
    ==
    assert // expected op.balance by index to match
    // tests/artifacts/StateOps/contract.py:36
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_min_balance(a: bytes) -> uint64:
verify_acct_min_balance:
    // tests/artifacts/StateOps/contract.py:38-39
    // @arc4.abimethod()
    // def verify_acct_min_balance(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:40
    // value, funded = op.AcctParamsGet.acct_min_balance(a)
    frame_dig -1
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:41
    // value_index, funded_index = op.AcctParamsGet.acct_min_balance(_get_1st_ref_index())
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:42
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:43
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:44
    // assert value == a.min_balance, "expected Account min_balance to match"
    frame_dig -1
    acct_params_get AcctMinBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account min_balance to match
    // tests/artifacts/StateOps/contract.py:45
    // assert value == algopy.op.min_balance(a), "expected op.min_balance to match"
    frame_dig -1
    min_balance
    dig 1
    ==
    assert // expected op.min_balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:46-48
    // assert value == algopy.op.min_balance(
    //     _get_1st_ref_index()
    // ), "expected op.min_balance by index to match"
    min_balance
    dig 1
    ==
    assert // expected op.min_balance by index to match
    // tests/artifacts/StateOps/contract.py:49
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_auth_addr(a: bytes) -> bytes:
verify_acct_auth_addr:
    // tests/artifacts/StateOps/contract.py:51-52
    // @arc4.abimethod()
    // def verify_acct_auth_addr(self, a: algopy.Account) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:53
    // value, funded = op.AcctParamsGet.acct_auth_addr(a)
    frame_dig -1
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:54
    // value_index, funded_index = op.AcctParamsGet.acct_auth_addr(_get_1st_ref_index())
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:55
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:56
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:57
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_uint(a: bytes) -> uint64:
verify_acct_total_num_uint:
    // tests/artifacts/StateOps/contract.py:59-60
    // @arc4.abimethod()
    // def verify_acct_total_num_uint(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:61
    // value, funded = op.AcctParamsGet.acct_total_num_uint(a)
    frame_dig -1
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:62
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_uint(_get_1st_ref_index())
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:63
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:64
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:65
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_byte_slice(a: bytes) -> uint64:
verify_acct_total_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:67-68
    // @arc4.abimethod()
    // def verify_acct_total_num_byte_slice(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:69
    // value, funded = op.AcctParamsGet.acct_total_num_byte_slice(a)
    frame_dig -1
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:70-72
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_byte_slice(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:73
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:74
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:75
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_extra_app_pages(a: bytes) -> uint64:
verify_acct_total_extra_app_pages:
    // tests/artifacts/StateOps/contract.py:77-78
    // @arc4.abimethod()
    // def verify_acct_total_extra_app_pages(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:79
    // value, funded = op.AcctParamsGet.acct_total_extra_app_pages(a)
    frame_dig -1
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:80-82
    // value_index, funded_index = op.AcctParamsGet.acct_total_extra_app_pages(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:83
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:84
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:85
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_created(a: bytes) -> uint64:
verify_acct_total_apps_created:
    // tests/artifacts/StateOps/contract.py:87-88
    // @arc4.abimethod()
    // def verify_acct_total_apps_created(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:89
    // value, funded = op.AcctParamsGet.acct_total_apps_created(a)
    frame_dig -1
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:90
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_created(_get_1st_ref_index())
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:91
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:92
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:93
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_opted_in(a: bytes) -> uint64:
verify_acct_total_apps_opted_in:
    // tests/artifacts/StateOps/contract.py:95-96
    // @arc4.abimethod()
    // def verify_acct_total_apps_opted_in(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:97
    // value, funded = op.AcctParamsGet.acct_total_apps_opted_in(a)
    frame_dig -1
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:98
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_opted_in(_get_1st_ref_index())
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:99
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:100
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:101
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets_created(a: bytes) -> uint64:
verify_acct_total_assets_created:
    // tests/artifacts/StateOps/contract.py:103-104
    // @arc4.abimethod()
    // def verify_acct_total_assets_created(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:105
    // value, funded = op.AcctParamsGet.acct_total_assets_created(a)
    frame_dig -1
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:106-108
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets_created(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:109
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:110
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:111
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets(a: bytes) -> uint64:
verify_acct_total_assets:
    // tests/artifacts/StateOps/contract.py:113-114
    // @arc4.abimethod()
    // def verify_acct_total_assets(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:115
    // value, funded = op.AcctParamsGet.acct_total_assets(a)
    frame_dig -1
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:116
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets(_get_1st_ref_index())
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:117
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:118
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:119
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_boxes(a: bytes) -> uint64:
verify_acct_total_boxes:
    // tests/artifacts/StateOps/contract.py:121-122
    // @arc4.abimethod()
    // def verify_acct_total_boxes(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:123
    // value, funded = op.AcctParamsGet.acct_total_boxes(a)
    frame_dig -1
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:124
    // value_index, funded_index = op.AcctParamsGet.acct_total_boxes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:125
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:126
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:127
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_box_bytes(a: bytes) -> uint64:
verify_acct_total_box_bytes:
    // tests/artifacts/StateOps/contract.py:129-130
    // @arc4.abimethod()
    // def verify_acct_total_box_bytes(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:131
    // value, funded = op.AcctParamsGet.acct_total_box_bytes(a)
    frame_dig -1
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:132
    // value_index, funded_index = op.AcctParamsGet.acct_total_box_bytes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:133
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:134
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:135
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_incentive_eligible(a: bytes) -> uint64:
verify_acct_incentive_eligible:
    // tests/artifacts/StateOps/contract.py:137-138
    // @arc4.abimethod()
    // def verify_acct_incentive_eligible(self, a: algopy.Account) -> bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:139
    // value, funded = op.AcctParamsGet.acct_incentive_eligible(a)
    frame_dig -1
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:140
    // value_index, funded_index = op.AcctParamsGet.acct_incentive_eligible(_get_1st_ref_index())
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:141
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:142
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:143
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_heartbeat(a: bytes) -> uint64:
verify_acct_last_heartbeat:
    // tests/artifacts/StateOps/contract.py:145-146
    // @arc4.abimethod()
    // def verify_acct_last_heartbeat(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:147
    // value, funded = op.AcctParamsGet.acct_last_heartbeat(a)
    frame_dig -1
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:148
    // value_index, funded_index = op.AcctParamsGet.acct_last_heartbeat(_get_1st_ref_index())
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:149
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:150
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:151
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_proposed(a: bytes) -> uint64:
verify_acct_last_proposed:
    // tests/artifacts/StateOps/contract.py:153-154
    // @arc4.abimethod()
    // def verify_acct_last_proposed(self, a: algopy.Account) -> algopy.UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:155
    // value, funded = op.AcctParamsGet.acct_last_proposed(a)
    frame_dig -1
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:156
    // value_index, funded_index = op.AcctParamsGet.acct_last_proposed(_get_1st_ref_index())
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:157
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:158
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:159
    // return value
    retsub
", + "approval": "#pragma version 11
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:24
    // class StateAcctParamsGetContract(ARC4Contract, avm_version=11):
    txn NumAppArgs
    bz main___algopy_default_create@22
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0x5f5b43e4 0x73dc93c7 0x5626dfeb 0xdc8a25bf 0x198ebd8c 0x2301ab26 0x9f68fca6 0xa975c2d1 0xd1e04801 0xb6966be5 0x195d5418 0x6adae3f1 0xdf8cfee5 0x6ad70d21 0x1735fd22 // method "verify_acct_balance(account)uint64", method "verify_acct_min_balance(account)uint64", method "verify_acct_auth_addr(account)address", method "verify_acct_total_num_uint(account)uint64", method "verify_acct_total_num_byte_slice(account)uint64", method "verify_acct_total_extra_app_pages(account)uint64", method "verify_acct_total_apps_created(account)uint64", method "verify_acct_total_apps_opted_in(account)uint64", method "verify_acct_total_assets_created(account)uint64", method "verify_acct_total_assets(account)uint64", method "verify_acct_total_boxes(account)uint64", method "verify_acct_total_box_bytes(account)uint64", method "verify_acct_incentive_eligible(account)bool", method "verify_acct_last_heartbeat(account)uint64", method "verify_acct_last_proposed(account)uint64"
    txna ApplicationArgs 0
    match verify_acct_balance verify_acct_min_balance verify_acct_auth_addr verify_acct_total_num_uint verify_acct_total_num_byte_slice verify_acct_total_extra_app_pages verify_acct_total_apps_created verify_acct_total_apps_opted_in verify_acct_total_assets_created verify_acct_total_assets verify_acct_total_boxes verify_acct_total_box_bytes verify_acct_incentive_eligible verify_acct_last_heartbeat verify_acct_last_proposed
    err

main___algopy_default_create@22:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_balance[routing]() -> void:
verify_acct_balance:
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:27
    // value, funded = op.AcctParamsGet.acct_balance(a)
    dup
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:28
    // value_index, funded_index = op.AcctParamsGet.acct_balance(_get_1st_ref_index())
    acct_params_get AcctBalance
    // tests/artifacts/StateOps/contract.py:29
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:30
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:31
    // assert value == a.balance, "expected Account balance to match"
    dig 1
    acct_params_get AcctBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account balance to match
    // tests/artifacts/StateOps/contract.py:32
    // assert value == algopy.op.balance(a), "expected op.balance to match"
    swap
    balance
    dig 1
    ==
    assert // expected op.balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:33-35
    // assert value == algopy.op.balance(
    //     _get_1st_ref_index()
    // ), "expected op.balance by index to match"
    balance
    dig 1
    ==
    assert // expected op.balance by index to match
    // tests/artifacts/StateOps/contract.py:25
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_min_balance[routing]() -> void:
verify_acct_min_balance:
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:40
    // value, funded = op.AcctParamsGet.acct_min_balance(a)
    dup
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:41
    // value_index, funded_index = op.AcctParamsGet.acct_min_balance(_get_1st_ref_index())
    acct_params_get AcctMinBalance
    // tests/artifacts/StateOps/contract.py:42
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:43
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:44
    // assert value == a.min_balance, "expected Account min_balance to match"
    dig 1
    acct_params_get AcctMinBalance
    assert // account funded
    dig 1
    ==
    assert // expected Account min_balance to match
    // tests/artifacts/StateOps/contract.py:45
    // assert value == algopy.op.min_balance(a), "expected op.min_balance to match"
    swap
    min_balance
    dig 1
    ==
    assert // expected op.min_balance to match
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:46-48
    // assert value == algopy.op.min_balance(
    //     _get_1st_ref_index()
    // ), "expected op.min_balance by index to match"
    min_balance
    dig 1
    ==
    assert // expected op.min_balance by index to match
    // tests/artifacts/StateOps/contract.py:38
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_auth_addr[routing]() -> void:
verify_acct_auth_addr:
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:53
    // value, funded = op.AcctParamsGet.acct_auth_addr(a)
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:54
    // value_index, funded_index = op.AcctParamsGet.acct_auth_addr(_get_1st_ref_index())
    acct_params_get AcctAuthAddr
    // tests/artifacts/StateOps/contract.py:55
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:56
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:51
    // @arc4.abimethod(resource_encoding="index")
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_uint[routing]() -> void:
verify_acct_total_num_uint:
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:61
    // value, funded = op.AcctParamsGet.acct_total_num_uint(a)
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:62
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_uint(_get_1st_ref_index())
    acct_params_get AcctTotalNumUint
    // tests/artifacts/StateOps/contract.py:63
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:64
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:59
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_num_byte_slice[routing]() -> void:
verify_acct_total_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:69
    // value, funded = op.AcctParamsGet.acct_total_num_byte_slice(a)
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:70-72
    // value_index, funded_index = op.AcctParamsGet.acct_total_num_byte_slice(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalNumByteSlice
    // tests/artifacts/StateOps/contract.py:73
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:74
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:67
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_extra_app_pages[routing]() -> void:
verify_acct_total_extra_app_pages:
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:79
    // value, funded = op.AcctParamsGet.acct_total_extra_app_pages(a)
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:80-82
    // value_index, funded_index = op.AcctParamsGet.acct_total_extra_app_pages(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalExtraAppPages
    // tests/artifacts/StateOps/contract.py:83
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:84
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:77
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_created[routing]() -> void:
verify_acct_total_apps_created:
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:89
    // value, funded = op.AcctParamsGet.acct_total_apps_created(a)
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:90
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_created(_get_1st_ref_index())
    acct_params_get AcctTotalAppsCreated
    // tests/artifacts/StateOps/contract.py:91
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:92
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:87
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_apps_opted_in[routing]() -> void:
verify_acct_total_apps_opted_in:
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:97
    // value, funded = op.AcctParamsGet.acct_total_apps_opted_in(a)
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:98
    // value_index, funded_index = op.AcctParamsGet.acct_total_apps_opted_in(_get_1st_ref_index())
    acct_params_get AcctTotalAppsOptedIn
    // tests/artifacts/StateOps/contract.py:99
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:100
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:95
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets_created[routing]() -> void:
verify_acct_total_assets_created:
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:105
    // value, funded = op.AcctParamsGet.acct_total_assets_created(a)
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:106-108
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets_created(
    //     _get_1st_ref_index()
    // )
    acct_params_get AcctTotalAssetsCreated
    // tests/artifacts/StateOps/contract.py:109
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:110
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:103
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_assets[routing]() -> void:
verify_acct_total_assets:
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:115
    // value, funded = op.AcctParamsGet.acct_total_assets(a)
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:116
    // value_index, funded_index = op.AcctParamsGet.acct_total_assets(_get_1st_ref_index())
    acct_params_get AcctTotalAssets
    // tests/artifacts/StateOps/contract.py:117
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:118
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:113
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_boxes[routing]() -> void:
verify_acct_total_boxes:
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:123
    // value, funded = op.AcctParamsGet.acct_total_boxes(a)
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:124
    // value_index, funded_index = op.AcctParamsGet.acct_total_boxes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxes
    // tests/artifacts/StateOps/contract.py:125
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:126
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:121
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_total_box_bytes[routing]() -> void:
verify_acct_total_box_bytes:
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:131
    // value, funded = op.AcctParamsGet.acct_total_box_bytes(a)
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:132
    // value_index, funded_index = op.AcctParamsGet.acct_total_box_bytes(_get_1st_ref_index())
    acct_params_get AcctTotalBoxBytes
    // tests/artifacts/StateOps/contract.py:133
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:134
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:129
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_incentive_eligible[routing]() -> void:
verify_acct_incentive_eligible:
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:139
    // value, funded = op.AcctParamsGet.acct_incentive_eligible(a)
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:140
    // value_index, funded_index = op.AcctParamsGet.acct_incentive_eligible(_get_1st_ref_index())
    acct_params_get AcctIncentiveEligible
    // tests/artifacts/StateOps/contract.py:141
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:142
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:137
    // @arc4.abimethod(resource_encoding="index")
    pushbytes 0x00
    pushint 0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_heartbeat[routing]() -> void:
verify_acct_last_heartbeat:
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:147
    // value, funded = op.AcctParamsGet.acct_last_heartbeat(a)
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:148
    // value_index, funded_index = op.AcctParamsGet.acct_last_heartbeat(_get_1st_ref_index())
    acct_params_get AcctLastHeartbeat
    // tests/artifacts/StateOps/contract.py:149
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:150
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:145
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAcctParamsGetContract.verify_acct_last_proposed[routing]() -> void:
verify_acct_last_proposed:
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod(resource_encoding="index")
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    // tests/artifacts/StateOps/contract.py:155
    // value, funded = op.AcctParamsGet.acct_last_proposed(a)
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:156
    // value_index, funded_index = op.AcctParamsGet.acct_last_proposed(_get_1st_ref_index())
    acct_params_get AcctLastProposed
    // tests/artifacts/StateOps/contract.py:157
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:158
    // assert funded == funded_index, "expected funded by index to match"
    ==
    assert // expected funded by index to match
    // tests/artifacts/StateOps/contract.py:153
    // @arc4.abimethod(resource_encoding="index")
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CyACAQAmAQQVH3x1MRtBAdCCDwRfW0PkBHPck8cEVibf6wTciiW/BBmOvYwEIwGrJgSfaPymBKl1wtEE0eBIAQS2lmvlBBldVBgEatrj8QTfjP7lBGrXDSEEFzX9IjYaAI4PAUkBMgEcAQUA7gDXAMAAqQCSAHsAZABNADAAGQACI0MxGRREMRhENhoBF8AciAK/FihMULAiQzEZFEQxGEQ2GgEXwByIApIWKExQsCJDMRkURDEYRDYaARfAHIgCZYABACNPAlQoTFCwIkMxGRREMRhENhoBF8AciAIyFihMULAiQzEZFEQxGEQ2GgEXwByIAgUWKExQsCJDMRkURDEYRDYaARfAHIgB2BYoTFCwIkMxGRREMRhENhoBF8AciAGrFihMULAiQzEZFEQxGEQ2GgEXwByIAX4WKExQsCJDMRkURDEYRDYaARfAHIgBURYoTFCwIkMxGRREMRhENhoBF8AciAEkFihMULAiQzEZFEQxGEQ2GgEXwByIAPcWKExQsCJDMRkURDEYRDYaARfAHIgAyhYoTFCwIkMxGRREMRhENhoBF8AciACdKExQsCJDMRkURDEYRDYaARfAHIgAWBYoTFCwIkMxGRREMRhENhoBF8AciAASFihMULAiQzEZQP6bMRgURCJDigEBi/9zADYaARdzAEsDTwISRBJEi/9zAERLARJEi/9gSwESRDYaARdgSwESRImKAQGL/3MBNhoBF3MBSwNPAhJEEkSL/3MBREsBEkSL/3hLARJENhoBF3hLARJEiYoBAYv/cwI2GgEXcwJLA08CEkQSRImKAQGL/3MDNhoBF3MDSwNPAhJEEkSJigEBi/9zBDYaARdzBEsDTwISRBJEiYoBAYv/cwU2GgEXcwVLA08CEkQSRImKAQGL/3MGNhoBF3MGSwNPAhJEEkSJigEBi/9zBzYaARdzB0sDTwISRBJEiYoBAYv/cwg2GgEXcwhLA08CEkQSRImKAQGL/3MJNhoBF3MJSwNPAhJEEkSJigEBi/9zCjYaARdzCksDTwISRBJEiYoBAYv/cws2GgEXcwtLA08CEkQSRImKAQGL/3MMNhoBF3MMSwNPAhJEEkSJigEBi/9zDjYaARdzDksDTwISRBJEiYoBAYv/cw02GgEXcw1LA08CEkQSRIk=", + "approval": "CyABASYBBBUffHUxG0EAeDEZFEQxGESCDwRfW0PkBHPck8cEVibf6wTciiW/BBmOvYwEIwGrJgSfaPymBKl1wtEE0eBIAQS2lmvlBBldVBgEatrj8QTfjP7lBGrXDSEEFzX9IjYaAI4PAAkAPwB1AJEArgDLAOgBBQEiAT8BXAF5AZYBugHXADEZFDEYFBBDNhoBF8AcSXMANhoBF3MASwNPAhJEEkRLAXMAREsBEkRMYEsBEkQ2GgEXYEsBEkQWKExQsCJDNhoBF8AcSXMBNhoBF3MBSwNPAhJEEkRLAXMBREsBEkRMeEsBEkQ2GgEXeEsBEkQWKExQsCJDNhoBF8AccwI2GgEXcwJLA08CEkQSRChMULAiQzYaARfAHHMDNhoBF3MDSwNPAhJEEkQWKExQsCJDNhoBF8AccwQ2GgEXcwRLA08CEkQSRBYoTFCwIkM2GgEXwBxzBTYaARdzBUsDTwISRBJEFihMULAiQzYaARfAHHMGNhoBF3MGSwNPAhJEEkQWKExQsCJDNhoBF8Accwc2GgEXcwdLA08CEkQSRBYoTFCwIkM2GgEXwBxzCDYaARdzCEsDTwISRBJEFihMULAiQzYaARfAHHMJNhoBF3MJSwNPAhJEEkQWKExQsCJDNhoBF8Accwo2GgEXcwpLA08CEkQSRBYoTFCwIkM2GgEXwBxzCzYaARdzC0sDTwISRBJEFihMULAiQzYaARfAHHMMNhoBF3MMSwNPAhJEEkSAAQCBAE8CVChMULAiQzYaARfAHHMONhoBF3MOSwNPAhJEEkQWKExQsCJDNhoBF8Accw02GgEXcw1LA08CEkQSRBYoTFCwIkM=", "clear": "C4EBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAppGlobalContract.approval.teal b/tests/artifacts/StateOps/data/StateAppGlobalContract.approval.teal index 1b9e146..21ee1c2 100644 --- a/tests/artifacts/StateOps/data/StateAppGlobalContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAppGlobalContract.approval.teal @@ -8,100 +8,63 @@ main: // tests/artifacts/StateOps/contract.py:445 // class StateAppGlobalContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@12 - pushbytess 0xa997a187 0x4db8aa41 0x6693ab92 0x857fd923 0x93a852e1 0x36996451 0x3920a57b // method "verify_get_bytes(byte[])byte[]", method "verify_get_uint64(byte[])uint64", method "verify_get_ex_bytes(application,byte[])(byte[],bool)", method "verify_get_ex_uint64(application,byte[])(uint64,bool)", method "verify_delete(byte[])void", method "verify_put_uint64(byte[],uint64)void", method "verify_put_bytes(byte[],byte[])void" - txna ApplicationArgs 0 - match main_verify_get_bytes_route@5 main_verify_get_uint64_route@6 main_verify_get_ex_bytes_route@7 main_verify_get_ex_uint64_route@8 main_verify_delete_route@9 main_verify_put_uint64_route@10 main_verify_put_bytes_route@11 - -main_after_if_else@14: - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): - intc_1 // 0 - return - -main_verify_put_bytes_route@11: - // tests/artifacts/StateOps/contract.py:483 - // @arc4.abimethod() + bz main___algopy_default_create@14 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/StateOps/contract.py:483 - // @arc4.abimethod() - callsub verify_put_bytes - intc_0 // 1 - return + assert + pushbytess 0xa997a187 0x4db8aa41 0x0c1f56a7 0xafddb088 0x93a852e1 0x36996451 0x3920a57b // method "verify_get_bytes(byte[])byte[]", method "verify_get_uint64(byte[])uint64", method "verify_get_ex_bytes(uint64,byte[])(byte[],bool)", method "verify_get_ex_uint64(uint64,byte[])(uint64,bool)", method "verify_delete(byte[])void", method "verify_put_uint64(byte[],uint64)void", method "verify_put_bytes(byte[],byte[])void" + txna ApplicationArgs 0 + match verify_get_bytes verify_get_uint64 verify_get_ex_bytes verify_get_ex_uint64 verify_delete verify_put_uint64 verify_put_bytes + err -main_verify_put_uint64_route@10: - // tests/artifacts/StateOps/contract.py:479 - // @arc4.abimethod() +main___algopy_default_create@14: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - txna ApplicationArgs 2 - btoi - // tests/artifacts/StateOps/contract.py:479 - // @arc4.abimethod() - callsub verify_put_uint64 - intc_0 // 1 - return + ! + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_delete_route@9: - // tests/artifacts/StateOps/contract.py:475 + +// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_bytes[routing]() -> void: +verify_get_bytes: + // tests/artifacts/StateOps/contract.py:457 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): txna ApplicationArgs 1 extract 2 0 - // tests/artifacts/StateOps/contract.py:475 + // tests/artifacts/StateOps/contract.py:459 + // value = op.AppGlobal.get_bytes(a) + app_global_get + // tests/artifacts/StateOps/contract.py:457 // @arc4.abimethod() - callsub verify_delete + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log intc_0 // 1 return -main_verify_get_ex_uint64_route@8: - // tests/artifacts/StateOps/contract.py:471 + +// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_uint64[routing]() -> void: +verify_get_uint64: + // tests/artifacts/StateOps/contract.py:462 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): txna ApplicationArgs 1 - btoi - txnas Applications - txna ApplicationArgs 2 extract 2 0 - // tests/artifacts/StateOps/contract.py:471 + // tests/artifacts/StateOps/contract.py:464 + // value = op.AppGlobal.get_uint64(a) + app_global_get + // tests/artifacts/StateOps/contract.py:462 // @arc4.abimethod() - callsub verify_get_ex_uint64 - swap itob - bytec_1 // 0x00 - intc_1 // 0 - uncover 3 - setbit - concat bytec_0 // 0x151f7c75 swap concat @@ -109,24 +72,20 @@ main_verify_get_ex_uint64_route@8: intc_0 // 1 return -main_verify_get_ex_bytes_route@7: + +// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_bytes[routing]() -> void: +verify_get_ex_bytes: // tests/artifacts/StateOps/contract.py:467 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): txna ApplicationArgs 1 btoi - txnas Applications txna ApplicationArgs 2 extract 2 0 + // tests/artifacts/StateOps/contract.py:469 + // return op.AppGlobal.get_ex_bytes(a, b) + app_global_get_ex // tests/artifacts/StateOps/contract.py:467 // @arc4.abimethod() - callsub verify_get_ex_bytes dig 1 len itob @@ -149,49 +108,26 @@ main_verify_get_ex_bytes_route@7: intc_0 // 1 return -main_verify_get_uint64_route@6: - // tests/artifacts/StateOps/contract.py:462 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): - txna ApplicationArgs 1 - extract 2 0 - // tests/artifacts/StateOps/contract.py:462 - // @arc4.abimethod() - callsub verify_get_uint64 - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_get_bytes_route@5: - // tests/artifacts/StateOps/contract.py:457 +// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_uint64[routing]() -> void: +verify_get_ex_uint64: + // tests/artifacts/StateOps/contract.py:471 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): txna ApplicationArgs 1 + btoi + txna ApplicationArgs 2 extract 2 0 - // tests/artifacts/StateOps/contract.py:457 + // tests/artifacts/StateOps/contract.py:473 + // return op.AppGlobal.get_ex_uint64(a, b) + app_global_get_ex + // tests/artifacts/StateOps/contract.py:471 // @arc4.abimethod() - callsub verify_get_bytes - dup - len - itob - extract 6 2 swap + itob + bytec_1 // 0x00 + intc_1 // 0 + uncover 3 + setbit concat bytec_0 // 0x151f7c75 swap @@ -200,112 +136,51 @@ main_verify_get_bytes_route@5: intc_0 // 1 return -main_bare_routing@12: - // tests/artifacts/StateOps/contract.py:445 - // class StateAppGlobalContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@14 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_bytes(a: bytes) -> bytes: -verify_get_bytes: - // tests/artifacts/StateOps/contract.py:457-458 - // @arc4.abimethod() - // def verify_get_bytes(self, a: Bytes) -> Bytes: - proto 1 1 - // tests/artifacts/StateOps/contract.py:459 - // value = op.AppGlobal.get_bytes(a) - frame_dig -1 - app_global_get - // tests/artifacts/StateOps/contract.py:460 - // return value - retsub - - -// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_uint64(a: bytes) -> uint64: -verify_get_uint64: - // tests/artifacts/StateOps/contract.py:462-463 - // @arc4.abimethod() - // def verify_get_uint64(self, a: Bytes) -> UInt64: - proto 1 1 - // tests/artifacts/StateOps/contract.py:464 - // value = op.AppGlobal.get_uint64(a) - frame_dig -1 - app_global_get - // tests/artifacts/StateOps/contract.py:465 - // return value - retsub - - -// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_bytes(a: uint64, b: bytes) -> bytes, uint64: -verify_get_ex_bytes: - // tests/artifacts/StateOps/contract.py:467-468 - // @arc4.abimethod() - // def verify_get_ex_bytes(self, a: Application, b: Bytes) -> tuple[Bytes, bool]: - proto 2 2 - // tests/artifacts/StateOps/contract.py:469 - // return op.AppGlobal.get_ex_bytes(a, b) - frame_dig -2 - frame_dig -1 - app_global_get_ex - retsub - - -// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_uint64(a: uint64, b: bytes) -> uint64, uint64: -verify_get_ex_uint64: - // tests/artifacts/StateOps/contract.py:471-472 - // @arc4.abimethod() - // def verify_get_ex_uint64(self, a: Application, b: Bytes) -> tuple[UInt64, bool]: - proto 2 2 - // tests/artifacts/StateOps/contract.py:473 - // return op.AppGlobal.get_ex_uint64(a, b) - frame_dig -2 - frame_dig -1 - app_global_get_ex - retsub - -// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_delete(a: bytes) -> void: +// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_delete[routing]() -> void: verify_delete: - // tests/artifacts/StateOps/contract.py:475-476 + // tests/artifacts/StateOps/contract.py:475 // @arc4.abimethod() - // def verify_delete(self, a: Bytes) -> None: - proto 1 0 + txna ApplicationArgs 1 + extract 2 0 // tests/artifacts/StateOps/contract.py:477 // op.AppGlobal.delete(a) - frame_dig -1 app_global_del - retsub + // tests/artifacts/StateOps/contract.py:475 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_uint64(a: bytes, b: uint64) -> void: +// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_uint64[routing]() -> void: verify_put_uint64: - // tests/artifacts/StateOps/contract.py:479-480 + // tests/artifacts/StateOps/contract.py:479 // @arc4.abimethod() - // def verify_put_uint64(self, a: Bytes, b: UInt64) -> None: - proto 2 0 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + btoi // tests/artifacts/StateOps/contract.py:481 // op.AppGlobal.put(a, b) - frame_dig -2 - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:479 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_bytes(a: bytes, b: bytes) -> void: +// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_bytes[routing]() -> void: verify_put_bytes: - // tests/artifacts/StateOps/contract.py:483-484 + // tests/artifacts/StateOps/contract.py:483 // @arc4.abimethod() - // def verify_put_bytes(self, a: Bytes, b: Bytes) -> None: - proto 2 0 + txna ApplicationArgs 1 + extract 2 0 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/StateOps/contract.py:485 // op.AppGlobal.put(a, b) - frame_dig -2 - frame_dig -1 app_global_put - retsub + // tests/artifacts/StateOps/contract.py:483 + // @arc4.abimethod() + intc_0 // 1 + return diff --git a/tests/artifacts/StateOps/data/StateAppGlobalContract.arc32.json b/tests/artifacts/StateOps/data/StateAppGlobalContract.arc32.json index 026c747..99341e1 100644 --- a/tests/artifacts/StateOps/data/StateAppGlobalContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAppGlobalContract.arc32.json @@ -10,12 +10,12 @@ "no_op": "CALL" } }, - "verify_get_ex_bytes(application,byte[])(byte[],bool)": { + "verify_get_ex_bytes(uint64,byte[])(byte[],bool)": { "call_config": { "no_op": "CALL" } }, - "verify_get_ex_uint64(application,byte[])(uint64,bool)": { + "verify_get_ex_uint64(uint64,byte[])(uint64,bool)": { "call_config": { "no_op": "CALL" } @@ -37,7 +37,7 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.StateAppGlobalContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x00
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@12
    pushbytess 0xa997a187 0x4db8aa41 0x6693ab92 0x857fd923 0x93a852e1 0x36996451 0x3920a57b // method "verify_get_bytes(byte[])byte[]", method "verify_get_uint64(byte[])uint64", method "verify_get_ex_bytes(application,byte[])(byte[],bool)", method "verify_get_ex_uint64(application,byte[])(uint64,bool)", method "verify_delete(byte[])void", method "verify_put_uint64(byte[],uint64)void", method "verify_put_bytes(byte[],byte[])void"
    txna ApplicationArgs 0
    match main_verify_get_bytes_route@5 main_verify_get_uint64_route@6 main_verify_get_ex_bytes_route@7 main_verify_get_ex_uint64_route@8 main_verify_delete_route@9 main_verify_put_uint64_route@10 main_verify_put_bytes_route@11

main_after_if_else@14:
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_put_bytes_route@11:
    // tests/artifacts/StateOps/contract.py:483
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:483
    // @arc4.abimethod()
    callsub verify_put_bytes
    intc_0 // 1
    return

main_verify_put_uint64_route@10:
    // tests/artifacts/StateOps/contract.py:479
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/StateOps/contract.py:479
    // @arc4.abimethod()
    callsub verify_put_uint64
    intc_0 // 1
    return

main_verify_delete_route@9:
    // tests/artifacts/StateOps/contract.py:475
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/StateOps/contract.py:475
    // @arc4.abimethod()
    callsub verify_delete
    intc_0 // 1
    return

main_verify_get_ex_uint64_route@8:
    // tests/artifacts/StateOps/contract.py:471
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:471
    // @arc4.abimethod()
    callsub verify_get_ex_uint64
    swap
    itob
    bytec_1 // 0x00
    intc_1 // 0
    uncover 3
    setbit
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_ex_bytes_route@7:
    // tests/artifacts/StateOps/contract.py:467
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:467
    // @arc4.abimethod()
    callsub verify_get_ex_bytes
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    bytec_1 // 0x00
    intc_1 // 0
    uncover 3
    setbit
    pushbytes 0x0003
    swap
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_uint64_route@6:
    // tests/artifacts/StateOps/contract.py:462
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/StateOps/contract.py:462
    // @arc4.abimethod()
    callsub verify_get_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_bytes_route@5:
    // tests/artifacts/StateOps/contract.py:457
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/StateOps/contract.py:457
    // @arc4.abimethod()
    callsub verify_get_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@12:
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@14
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_bytes(a: bytes) -> bytes:
verify_get_bytes:
    // tests/artifacts/StateOps/contract.py:457-458
    // @arc4.abimethod()
    // def verify_get_bytes(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:459
    // value = op.AppGlobal.get_bytes(a)
    frame_dig -1
    app_global_get
    // tests/artifacts/StateOps/contract.py:460
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_uint64(a: bytes) -> uint64:
verify_get_uint64:
    // tests/artifacts/StateOps/contract.py:462-463
    // @arc4.abimethod()
    // def verify_get_uint64(self, a: Bytes) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:464
    // value = op.AppGlobal.get_uint64(a)
    frame_dig -1
    app_global_get
    // tests/artifacts/StateOps/contract.py:465
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_bytes(a: uint64, b: bytes) -> bytes, uint64:
verify_get_ex_bytes:
    // tests/artifacts/StateOps/contract.py:467-468
    // @arc4.abimethod()
    // def verify_get_ex_bytes(self, a: Application, b: Bytes) -> tuple[Bytes, bool]:
    proto 2 2
    // tests/artifacts/StateOps/contract.py:469
    // return op.AppGlobal.get_ex_bytes(a, b)
    frame_dig -2
    frame_dig -1
    app_global_get_ex
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_uint64(a: uint64, b: bytes) -> uint64, uint64:
verify_get_ex_uint64:
    // tests/artifacts/StateOps/contract.py:471-472
    // @arc4.abimethod()
    // def verify_get_ex_uint64(self, a: Application, b: Bytes) -> tuple[UInt64, bool]:
    proto 2 2
    // tests/artifacts/StateOps/contract.py:473
    // return op.AppGlobal.get_ex_uint64(a, b)
    frame_dig -2
    frame_dig -1
    app_global_get_ex
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_delete(a: bytes) -> void:
verify_delete:
    // tests/artifacts/StateOps/contract.py:475-476
    // @arc4.abimethod()
    // def verify_delete(self, a: Bytes) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:477
    // op.AppGlobal.delete(a)
    frame_dig -1
    app_global_del
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_uint64(a: bytes, b: uint64) -> void:
verify_put_uint64:
    // tests/artifacts/StateOps/contract.py:479-480
    // @arc4.abimethod()
    // def verify_put_uint64(self, a: Bytes, b: UInt64) -> None:
    proto 2 0
    // tests/artifacts/StateOps/contract.py:481
    // op.AppGlobal.put(a, b)
    frame_dig -2
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_bytes(a: bytes, b: bytes) -> void:
verify_put_bytes:
    // tests/artifacts/StateOps/contract.py:483-484
    // @arc4.abimethod()
    // def verify_put_bytes(self, a: Bytes, b: Bytes) -> None:
    proto 2 0
    // tests/artifacts/StateOps/contract.py:485
    // op.AppGlobal.put(a, b)
    frame_dig -2
    frame_dig -1
    app_global_put
    retsub
", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC5fX2FsZ29weV9lbnRyeXBvaW50X3dpdGhfaW5pdCgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDAKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NSAweDAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDQ1CiAgICAvLyBjbGFzcyBTdGF0ZUFwcEdsb2JhbENvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUAxNAogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQKICAgIHB1c2hieXRlc3MgMHhhOTk3YTE4NyAweDRkYjhhYTQxIDB4MGMxZjU2YTcgMHhhZmRkYjA4OCAweDkzYTg1MmUxIDB4MzY5OTY0NTEgMHgzOTIwYTU3YiAvLyBtZXRob2QgInZlcmlmeV9nZXRfYnl0ZXMoYnl0ZVtdKWJ5dGVbXSIsIG1ldGhvZCAidmVyaWZ5X2dldF91aW50NjQoYnl0ZVtdKXVpbnQ2NCIsIG1ldGhvZCAidmVyaWZ5X2dldF9leF9ieXRlcyh1aW50NjQsYnl0ZVtdKShieXRlW10sYm9vbCkiLCBtZXRob2QgInZlcmlmeV9nZXRfZXhfdWludDY0KHVpbnQ2NCxieXRlW10pKHVpbnQ2NCxib29sKSIsIG1ldGhvZCAidmVyaWZ5X2RlbGV0ZShieXRlW10pdm9pZCIsIG1ldGhvZCAidmVyaWZ5X3B1dF91aW50NjQoYnl0ZVtdLHVpbnQ2NCl2b2lkIiwgbWV0aG9kICJ2ZXJpZnlfcHV0X2J5dGVzKGJ5dGVbXSxieXRlW10pdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIHZlcmlmeV9nZXRfYnl0ZXMgdmVyaWZ5X2dldF91aW50NjQgdmVyaWZ5X2dldF9leF9ieXRlcyB2ZXJpZnlfZ2V0X2V4X3VpbnQ2NCB2ZXJpZnlfZGVsZXRlIHZlcmlmeV9wdXRfdWludDY0IHZlcmlmeV9wdXRfYnl0ZXMKICAgIGVycgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUAxNDoKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFwcEdsb2JhbENvbnRyYWN0LnZlcmlmeV9nZXRfYnl0ZXNbcm91dGluZ10oKSAtPiB2b2lkOgp2ZXJpZnlfZ2V0X2J5dGVzOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ1NwogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDU5CiAgICAvLyB2YWx1ZSA9IG9wLkFwcEdsb2JhbC5nZXRfYnl0ZXMoYSkKICAgIGFwcF9nbG9iYWxfZ2V0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDU3CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgZHVwCiAgICBsZW4KICAgIGl0b2IKICAgIGV4dHJhY3QgNiAyCiAgICBzd2FwCiAgICBjb25jYXQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfZ2V0X3VpbnQ2NFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9nZXRfdWludDY0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ2MgogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDY0CiAgICAvLyB2YWx1ZSA9IG9wLkFwcEdsb2JhbC5nZXRfdWludDY0KGEpCiAgICBhcHBfZ2xvYmFsX2dldAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ2MgogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGl0b2IKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfZ2V0X2V4X2J5dGVzW3JvdXRpbmddKCkgLT4gdm9pZDoKdmVyaWZ5X2dldF9leF9ieXRlczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NjcKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBidG9pCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICBleHRyYWN0IDIgMAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ2OQogICAgLy8gcmV0dXJuIG9wLkFwcEdsb2JhbC5nZXRfZXhfYnl0ZXMoYSwgYikKICAgIGFwcF9nbG9iYWxfZ2V0X2V4CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDY3CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgZGlnIDEKICAgIGxlbgogICAgaXRvYgogICAgZXh0cmFjdCA2IDIKICAgIHVuY292ZXIgMgogICAgY29uY2F0CiAgICBieXRlY18xIC8vIDB4MDAKICAgIGludGNfMSAvLyAwCiAgICB1bmNvdmVyIDMKICAgIHNldGJpdAogICAgcHVzaGJ5dGVzIDB4MDAwMwogICAgc3dhcAogICAgY29uY2F0CiAgICBzd2FwCiAgICBjb25jYXQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfZ2V0X2V4X3VpbnQ2NFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9nZXRfZXhfdWludDY0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3MQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGJ0b2kKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDczCiAgICAvLyByZXR1cm4gb3AuQXBwR2xvYmFsLmdldF9leF91aW50NjQoYSwgYikKICAgIGFwcF9nbG9iYWxfZ2V0X2V4CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDcxCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgc3dhcAogICAgaXRvYgogICAgYnl0ZWNfMSAvLyAweDAwCiAgICBpbnRjXzEgLy8gMAogICAgdW5jb3ZlciAzCiAgICBzZXRiaXQKICAgIGNvbmNhdAogICAgYnl0ZWNfMCAvLyAweDE1MWY3Yzc1CiAgICBzd2FwCiAgICBjb25jYXQKICAgIGxvZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFwcEdsb2JhbENvbnRyYWN0LnZlcmlmeV9kZWxldGVbcm91dGluZ10oKSAtPiB2b2lkOgp2ZXJpZnlfZGVsZXRlOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDc3CiAgICAvLyBvcC5BcHBHbG9iYWwuZGVsZXRlKGEpCiAgICBhcHBfZ2xvYmFsX2RlbAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfcHV0X3VpbnQ2NFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9wdXRfdWludDY0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICBidG9pCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDgxCiAgICAvLyBvcC5BcHBHbG9iYWwucHV0KGEsIGIpCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfcHV0X2J5dGVzW3JvdXRpbmddKCkgLT4gdm9pZDoKdmVyaWZ5X3B1dF9ieXRlczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODMKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBleHRyYWN0IDIgMAogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgogICAgZXh0cmFjdCAyIDAKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODUKICAgIC8vIG9wLkFwcEdsb2JhbC5wdXQoYSwgYikKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDgzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -102,7 +102,7 @@ "name": "verify_get_ex_bytes", "args": [ { - "type": "application", + "type": "uint64", "name": "a" }, { @@ -119,7 +119,7 @@ "name": "verify_get_ex_uint64", "args": [ { - "type": "application", + "type": "uint64", "name": "a" }, { diff --git a/tests/artifacts/StateOps/data/StateAppGlobalContract.arc56.json b/tests/artifacts/StateOps/data/StateAppGlobalContract.arc56.json index 81a0ae2..5545423 100644 --- a/tests/artifacts/StateOps/data/StateAppGlobalContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAppGlobalContract.arc56.json @@ -48,7 +48,7 @@ "name": "verify_get_ex_bytes", "args": [ { - "type": "application", + "type": "uint64", "name": "a" }, { @@ -73,7 +73,7 @@ "name": "verify_get_ex_uint64", "args": [ { - "type": "application", + "type": "uint64", "name": "a" }, { @@ -215,33 +215,15 @@ "sourceInfo": [ { "pc": [ - 80, - 104, - 126, - 144, - 180, - 231, - 254 - ], - "errorMessage": "OnCompletion is not NoOp" - }, - { - "pc": [ - 289 + 22 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 83, - 107, - 129, - 147, - 183, - 234, - 257 + 90 ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" } ], "pcOffsetMethod": "none" @@ -252,18 +234,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.StateAppGlobalContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75 0x00
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@12
    pushbytess 0xa997a187 0x4db8aa41 0x6693ab92 0x857fd923 0x93a852e1 0x36996451 0x3920a57b // method "verify_get_bytes(byte[])byte[]", method "verify_get_uint64(byte[])uint64", method "verify_get_ex_bytes(application,byte[])(byte[],bool)", method "verify_get_ex_uint64(application,byte[])(uint64,bool)", method "verify_delete(byte[])void", method "verify_put_uint64(byte[],uint64)void", method "verify_put_bytes(byte[],byte[])void"
    txna ApplicationArgs 0
    match main_verify_get_bytes_route@5 main_verify_get_uint64_route@6 main_verify_get_ex_bytes_route@7 main_verify_get_ex_uint64_route@8 main_verify_delete_route@9 main_verify_put_uint64_route@10 main_verify_put_bytes_route@11

main_after_if_else@14:
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_put_bytes_route@11:
    // tests/artifacts/StateOps/contract.py:483
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:483
    // @arc4.abimethod()
    callsub verify_put_bytes
    intc_0 // 1
    return

main_verify_put_uint64_route@10:
    // tests/artifacts/StateOps/contract.py:479
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    txna ApplicationArgs 2
    btoi
    // tests/artifacts/StateOps/contract.py:479
    // @arc4.abimethod()
    callsub verify_put_uint64
    intc_0 // 1
    return

main_verify_delete_route@9:
    // tests/artifacts/StateOps/contract.py:475
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/StateOps/contract.py:475
    // @arc4.abimethod()
    callsub verify_delete
    intc_0 // 1
    return

main_verify_get_ex_uint64_route@8:
    // tests/artifacts/StateOps/contract.py:471
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:471
    // @arc4.abimethod()
    callsub verify_get_ex_uint64
    swap
    itob
    bytec_1 // 0x00
    intc_1 // 0
    uncover 3
    setbit
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_ex_bytes_route@7:
    // tests/artifacts/StateOps/contract.py:467
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:467
    // @arc4.abimethod()
    callsub verify_get_ex_bytes
    dig 1
    len
    itob
    extract 6 2
    uncover 2
    concat
    bytec_1 // 0x00
    intc_1 // 0
    uncover 3
    setbit
    pushbytes 0x0003
    swap
    concat
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_uint64_route@6:
    // tests/artifacts/StateOps/contract.py:462
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/StateOps/contract.py:462
    // @arc4.abimethod()
    callsub verify_get_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_bytes_route@5:
    // tests/artifacts/StateOps/contract.py:457
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // tests/artifacts/StateOps/contract.py:457
    // @arc4.abimethod()
    callsub verify_get_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@12:
    // tests/artifacts/StateOps/contract.py:445
    // class StateAppGlobalContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@14
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_bytes(a: bytes) -> bytes:
verify_get_bytes:
    // tests/artifacts/StateOps/contract.py:457-458
    // @arc4.abimethod()
    // def verify_get_bytes(self, a: Bytes) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:459
    // value = op.AppGlobal.get_bytes(a)
    frame_dig -1
    app_global_get
    // tests/artifacts/StateOps/contract.py:460
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_uint64(a: bytes) -> uint64:
verify_get_uint64:
    // tests/artifacts/StateOps/contract.py:462-463
    // @arc4.abimethod()
    // def verify_get_uint64(self, a: Bytes) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:464
    // value = op.AppGlobal.get_uint64(a)
    frame_dig -1
    app_global_get
    // tests/artifacts/StateOps/contract.py:465
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_bytes(a: uint64, b: bytes) -> bytes, uint64:
verify_get_ex_bytes:
    // tests/artifacts/StateOps/contract.py:467-468
    // @arc4.abimethod()
    // def verify_get_ex_bytes(self, a: Application, b: Bytes) -> tuple[Bytes, bool]:
    proto 2 2
    // tests/artifacts/StateOps/contract.py:469
    // return op.AppGlobal.get_ex_bytes(a, b)
    frame_dig -2
    frame_dig -1
    app_global_get_ex
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_get_ex_uint64(a: uint64, b: bytes) -> uint64, uint64:
verify_get_ex_uint64:
    // tests/artifacts/StateOps/contract.py:471-472
    // @arc4.abimethod()
    // def verify_get_ex_uint64(self, a: Application, b: Bytes) -> tuple[UInt64, bool]:
    proto 2 2
    // tests/artifacts/StateOps/contract.py:473
    // return op.AppGlobal.get_ex_uint64(a, b)
    frame_dig -2
    frame_dig -1
    app_global_get_ex
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_delete(a: bytes) -> void:
verify_delete:
    // tests/artifacts/StateOps/contract.py:475-476
    // @arc4.abimethod()
    // def verify_delete(self, a: Bytes) -> None:
    proto 1 0
    // tests/artifacts/StateOps/contract.py:477
    // op.AppGlobal.delete(a)
    frame_dig -1
    app_global_del
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_uint64(a: bytes, b: uint64) -> void:
verify_put_uint64:
    // tests/artifacts/StateOps/contract.py:479-480
    // @arc4.abimethod()
    // def verify_put_uint64(self, a: Bytes, b: UInt64) -> None:
    proto 2 0
    // tests/artifacts/StateOps/contract.py:481
    // op.AppGlobal.put(a, b)
    frame_dig -2
    frame_dig -1
    app_global_put
    retsub


// tests.artifacts.StateOps.contract.StateAppGlobalContract.verify_put_bytes(a: bytes, b: bytes) -> void:
verify_put_bytes:
    // tests/artifacts/StateOps/contract.py:483-484
    // @arc4.abimethod()
    // def verify_put_bytes(self, a: Bytes, b: Bytes) -> None:
    proto 2 0
    // tests/artifacts/StateOps/contract.py:485
    // op.AppGlobal.put(a, b)
    frame_dig -2
    frame_dig -1
    app_global_put
    retsub
", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC5fX2FsZ29weV9lbnRyeXBvaW50X3dpdGhfaW5pdCgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDAKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NSAweDAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDQ1CiAgICAvLyBjbGFzcyBTdGF0ZUFwcEdsb2JhbENvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUAxNAogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQKICAgIHB1c2hieXRlc3MgMHhhOTk3YTE4NyAweDRkYjhhYTQxIDB4MGMxZjU2YTcgMHhhZmRkYjA4OCAweDkzYTg1MmUxIDB4MzY5OTY0NTEgMHgzOTIwYTU3YiAvLyBtZXRob2QgInZlcmlmeV9nZXRfYnl0ZXMoYnl0ZVtdKWJ5dGVbXSIsIG1ldGhvZCAidmVyaWZ5X2dldF91aW50NjQoYnl0ZVtdKXVpbnQ2NCIsIG1ldGhvZCAidmVyaWZ5X2dldF9leF9ieXRlcyh1aW50NjQsYnl0ZVtdKShieXRlW10sYm9vbCkiLCBtZXRob2QgInZlcmlmeV9nZXRfZXhfdWludDY0KHVpbnQ2NCxieXRlW10pKHVpbnQ2NCxib29sKSIsIG1ldGhvZCAidmVyaWZ5X2RlbGV0ZShieXRlW10pdm9pZCIsIG1ldGhvZCAidmVyaWZ5X3B1dF91aW50NjQoYnl0ZVtdLHVpbnQ2NCl2b2lkIiwgbWV0aG9kICJ2ZXJpZnlfcHV0X2J5dGVzKGJ5dGVbXSxieXRlW10pdm9pZCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIHZlcmlmeV9nZXRfYnl0ZXMgdmVyaWZ5X2dldF91aW50NjQgdmVyaWZ5X2dldF9leF9ieXRlcyB2ZXJpZnlfZ2V0X2V4X3VpbnQ2NCB2ZXJpZnlfZGVsZXRlIHZlcmlmeV9wdXRfdWludDY0IHZlcmlmeV9wdXRfYnl0ZXMKICAgIGVycgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUAxNDoKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAhCiAgICAmJgogICAgcmV0dXJuIC8vIG9uIGVycm9yOiBPbkNvbXBsZXRpb24gbXVzdCBiZSBOb09wICYmIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFwcEdsb2JhbENvbnRyYWN0LnZlcmlmeV9nZXRfYnl0ZXNbcm91dGluZ10oKSAtPiB2b2lkOgp2ZXJpZnlfZ2V0X2J5dGVzOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ1NwogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDU5CiAgICAvLyB2YWx1ZSA9IG9wLkFwcEdsb2JhbC5nZXRfYnl0ZXMoYSkKICAgIGFwcF9nbG9iYWxfZ2V0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDU3CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgZHVwCiAgICBsZW4KICAgIGl0b2IKICAgIGV4dHJhY3QgNiAyCiAgICBzd2FwCiAgICBjb25jYXQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfZ2V0X3VpbnQ2NFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9nZXRfdWludDY0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ2MgogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDY0CiAgICAvLyB2YWx1ZSA9IG9wLkFwcEdsb2JhbC5nZXRfdWludDY0KGEpCiAgICBhcHBfZ2xvYmFsX2dldAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ2MgogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGl0b2IKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfZ2V0X2V4X2J5dGVzW3JvdXRpbmddKCkgLT4gdm9pZDoKdmVyaWZ5X2dldF9leF9ieXRlczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NjcKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBidG9pCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICBleHRyYWN0IDIgMAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ2OQogICAgLy8gcmV0dXJuIG9wLkFwcEdsb2JhbC5nZXRfZXhfYnl0ZXMoYSwgYikKICAgIGFwcF9nbG9iYWxfZ2V0X2V4CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDY3CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgZGlnIDEKICAgIGxlbgogICAgaXRvYgogICAgZXh0cmFjdCA2IDIKICAgIHVuY292ZXIgMgogICAgY29uY2F0CiAgICBieXRlY18xIC8vIDB4MDAKICAgIGludGNfMSAvLyAwCiAgICB1bmNvdmVyIDMKICAgIHNldGJpdAogICAgcHVzaGJ5dGVzIDB4MDAwMwogICAgc3dhcAogICAgY29uY2F0CiAgICBzd2FwCiAgICBjb25jYXQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfZ2V0X2V4X3VpbnQ2NFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9nZXRfZXhfdWludDY0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3MQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGJ0b2kKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDczCiAgICAvLyByZXR1cm4gb3AuQXBwR2xvYmFsLmdldF9leF91aW50NjQoYSwgYikKICAgIGFwcF9nbG9iYWxfZ2V0X2V4CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDcxCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgc3dhcAogICAgaXRvYgogICAgYnl0ZWNfMSAvLyAweDAwCiAgICBpbnRjXzEgLy8gMAogICAgdW5jb3ZlciAzCiAgICBzZXRiaXQKICAgIGNvbmNhdAogICAgYnl0ZWNfMCAvLyAweDE1MWY3Yzc1CiAgICBzd2FwCiAgICBjb25jYXQKICAgIGxvZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFwcEdsb2JhbENvbnRyYWN0LnZlcmlmeV9kZWxldGVbcm91dGluZ10oKSAtPiB2b2lkOgp2ZXJpZnlfZGVsZXRlOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDc3CiAgICAvLyBvcC5BcHBHbG9iYWwuZGVsZXRlKGEpCiAgICBhcHBfZ2xvYmFsX2RlbAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3NQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfcHV0X3VpbnQ2NFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9wdXRfdWludDY0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIGV4dHJhY3QgMiAwCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAyCiAgICBidG9pCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDgxCiAgICAvLyBvcC5BcHBHbG9iYWwucHV0KGEsIGIpCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ3OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxDb250cmFjdC52ZXJpZnlfcHV0X2J5dGVzW3JvdXRpbmddKCkgLT4gdm9pZDoKdmVyaWZ5X3B1dF9ieXRlczoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODMKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBleHRyYWN0IDIgMAogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgogICAgZXh0cmFjdCAyIDAKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0ODUKICAgIC8vIG9wLkFwcEdsb2JhbC5wdXQoYSwgYikKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDgzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiACAQAmAgQVH3x1AQAxG0EBBoIHBKmXoYcETbiqQQRmk6uSBIV/2SMEk6hS4QQ2mWRRBDkgpXs2GgCOBwCwAJkAZgBCADAAGgACI0MxGRREMRhENhoBVwIANhoCVwIAiADxIkMxGRREMRhENhoBVwIANhoCF4gA0iJDMRkURDEYRDYaAVcCAIgAuSJDMRkURDEYRDYaARfAMjYaAlcCAIgAmEwWKSNPA1RQKExQsCJDMRkURDEYRDYaARfAMjYaAlcCAIgAa0sBFRZXBgJPAlApI08DVIACAANMUExQKExQsCJDMRkURDEYRDYaAVcCAIgANxYoTFCwIkMxGRREMRhENhoBVwIAiAAZSRUWVwYCTFAoTFCwIkMxGUD/LTEYFEQiQ4oBAYv/ZImKAQGL/2SJigICi/6L/2WJigICi/6L/2WJigEAi/9piYoCAIv+i/9niYoCAIv+i/9niQ==", + "approval": "CiACAQAmAgQVH3x1AQAxG0EAQDEZFEQxGESCBwSpl6GHBE24qkEEDB9WpwSv3bCIBJOoUuEENplkUQQ5IKV7NhoAjgcACQAeACwAVABtAHYAgwAxGRQxGBQQQzYaAVcCAGRJFRZXBgJMUChMULAiQzYaAVcCAGQWKExQsCJDNhoBFzYaAlcCAGVLARUWVwYCTwJQKSNPA1SAAgADTFBMUChMULAiQzYaARc2GgJXAgBlTBYpI08DVFAoTFCwIkM2GgFXAgBpIkM2GgFXAgA2GgIXZyJDNhoBVwIANhoCVwIAZyJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAppGlobalExContract.approval.teal b/tests/artifacts/StateOps/data/StateAppGlobalExContract.approval.teal index 9bf6840..7bee4fc 100644 --- a/tests/artifacts/StateOps/data/StateAppGlobalExContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAppGlobalExContract.approval.teal @@ -63,17 +63,11 @@ main_after_if_else@2: // tests/artifacts/StateOps/contract.py:427 // class StateAppGlobalExContract(ARC4Contract): txn NumAppArgs - bnz main_after_if_else@6 + ! + assert txn OnCompletion - bnz main_after_if_else@6 + ! txn ApplicationID ! - assert // can only call when creating - pushint 1 // 1 - return - -main_after_if_else@6: - // tests/artifacts/StateOps/contract.py:427 - // class StateAppGlobalExContract(ARC4Contract): - pushint 0 // 0 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating diff --git a/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc32.json b/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc32.json index 6106952..858fb49 100644 --- a/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc32.json @@ -1,7 +1,7 @@ { "hints": {}, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxFeENvbnRyYWN0Ll9fYWxnb3B5X2VudHJ5cG9pbnRfd2l0aF9pbml0KCkgLT4gdWludDY0OgptYWluOgogICAgYnl0ZWNibG9jayAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMgMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzEKICAgIC8vIGtleT0iZ2xvYmFsX3VpbnQ2NCIsCiAgICBwdXNoYnl0ZXMgImdsb2JhbF91aW50NjQiCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDMwCiAgICAvLyBVSW50NjQoMiksCiAgICBwdXNoaW50IDIgLy8gMgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQyOS00MzIKICAgIC8vIHNlbGYuZ2xvYmFsX3VpbnQ2NCA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIFVJbnQ2NCgyKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF91aW50NjQiLAogICAgLy8gKQogICAgYXBwX2dsb2JhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzUKICAgIC8vIGtleT0iZ2xvYmFsX2J5dGVzIiwKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzIgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNAogICAgLy8gQnl0ZXMoYiJkdW1teV9ieXRlcyIpLAogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzMtNDM2CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlcyA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIEJ5dGVzKGIiZHVtbXlfYnl0ZXMiKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF9ieXRlcyIsCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNwogICAgLy8gc2VsZi5nbG9iYWxfdWludDY0X2V4cGxpY2l0ID0gYWxnb3B5LlVJbnQ2NCgyKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfdWludDY0X2V4cGxpY2l0IgogICAgcHVzaGludCAyIC8vIDIKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDM4CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5CeXRlcyhiImR1bW15X2J5dGVzIikKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzX2V4cGxpY2l0IgogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDQwCiAgICAvLyBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICBwdXNoYnl0ZXMgImdsb2JhbF9hcmM0X2J5dGVzIgogICAgYnl0ZWNfMSAvLyAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzOS00NDEKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXMgPSBHbG9iYWxTdGF0ZSgKICAgIC8vICAgICBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ0MgogICAgLy8gc2VsZi5nbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDAKICAgIC8vIGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKSwga2V5PSJnbG9iYWxfYXJjNF9ieXRlcyIKICAgIGJ5dGVjXzEgLy8gMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDIKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXNfZXhwbGljaXQgPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIikKICAgIGFwcF9nbG9iYWxfcHV0CgptYWluX2FmdGVyX2lmX2Vsc2VAMjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MjcKICAgIC8vIGNsYXNzIFN0YXRlQXBwR2xvYmFsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJueiBtYWluX2FmdGVyX2lmX2Vsc2VANgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgYm56IG1haW5fYWZ0ZXJfaWZfZWxzZUA2CiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKbWFpbl9hZnRlcl9pZl9lbHNlQDY6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDI3CiAgICAvLyBjbGFzcyBTdGF0ZUFwcEdsb2JhbEV4Q29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHB1c2hpbnQgMCAvLyAwCiAgICByZXR1cm4K", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxFeENvbnRyYWN0Ll9fYWxnb3B5X2VudHJ5cG9pbnRfd2l0aF9pbml0KCkgLT4gdWludDY0OgptYWluOgogICAgYnl0ZWNibG9jayAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMgMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzEKICAgIC8vIGtleT0iZ2xvYmFsX3VpbnQ2NCIsCiAgICBwdXNoYnl0ZXMgImdsb2JhbF91aW50NjQiCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDMwCiAgICAvLyBVSW50NjQoMiksCiAgICBwdXNoaW50IDIgLy8gMgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQyOS00MzIKICAgIC8vIHNlbGYuZ2xvYmFsX3VpbnQ2NCA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIFVJbnQ2NCgyKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF91aW50NjQiLAogICAgLy8gKQogICAgYXBwX2dsb2JhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzUKICAgIC8vIGtleT0iZ2xvYmFsX2J5dGVzIiwKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzIgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNAogICAgLy8gQnl0ZXMoYiJkdW1teV9ieXRlcyIpLAogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzMtNDM2CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlcyA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIEJ5dGVzKGIiZHVtbXlfYnl0ZXMiKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF9ieXRlcyIsCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNwogICAgLy8gc2VsZi5nbG9iYWxfdWludDY0X2V4cGxpY2l0ID0gYWxnb3B5LlVJbnQ2NCgyKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfdWludDY0X2V4cGxpY2l0IgogICAgcHVzaGludCAyIC8vIDIKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDM4CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5CeXRlcyhiImR1bW15X2J5dGVzIikKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzX2V4cGxpY2l0IgogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDQwCiAgICAvLyBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICBwdXNoYnl0ZXMgImdsb2JhbF9hcmM0X2J5dGVzIgogICAgYnl0ZWNfMSAvLyAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzOS00NDEKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXMgPSBHbG9iYWxTdGF0ZSgKICAgIC8vICAgICBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ0MgogICAgLy8gc2VsZi5nbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDAKICAgIC8vIGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKSwga2V5PSJnbG9iYWxfYXJjNF9ieXRlcyIKICAgIGJ5dGVjXzEgLy8gMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDIKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXNfZXhwbGljaXQgPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIikKICAgIGFwcF9nbG9iYWxfcHV0CgptYWluX2FmdGVyX2lmX2Vsc2VAMjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MjcKICAgIC8vIGNsYXNzIFN0YXRlQXBwR2xvYmFsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgICEKICAgIGFzc2VydAogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc56.json b/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc56.json index 62a4225..9c59f8f 100644 --- a/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAppGlobalExContract.arc56.json @@ -71,9 +71,9 @@ "sourceInfo": [ { "pc": [ - 189 + 187 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" } ], "pcOffsetMethod": "none" @@ -84,18 +84,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxFeENvbnRyYWN0Ll9fYWxnb3B5X2VudHJ5cG9pbnRfd2l0aF9pbml0KCkgLT4gdWludDY0OgptYWluOgogICAgYnl0ZWNibG9jayAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMgMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzEKICAgIC8vIGtleT0iZ2xvYmFsX3VpbnQ2NCIsCiAgICBwdXNoYnl0ZXMgImdsb2JhbF91aW50NjQiCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDMwCiAgICAvLyBVSW50NjQoMiksCiAgICBwdXNoaW50IDIgLy8gMgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQyOS00MzIKICAgIC8vIHNlbGYuZ2xvYmFsX3VpbnQ2NCA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIFVJbnQ2NCgyKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF91aW50NjQiLAogICAgLy8gKQogICAgYXBwX2dsb2JhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzUKICAgIC8vIGtleT0iZ2xvYmFsX2J5dGVzIiwKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzIgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNAogICAgLy8gQnl0ZXMoYiJkdW1teV9ieXRlcyIpLAogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzMtNDM2CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlcyA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIEJ5dGVzKGIiZHVtbXlfYnl0ZXMiKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF9ieXRlcyIsCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNwogICAgLy8gc2VsZi5nbG9iYWxfdWludDY0X2V4cGxpY2l0ID0gYWxnb3B5LlVJbnQ2NCgyKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfdWludDY0X2V4cGxpY2l0IgogICAgcHVzaGludCAyIC8vIDIKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDM4CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5CeXRlcyhiImR1bW15X2J5dGVzIikKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzX2V4cGxpY2l0IgogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDQwCiAgICAvLyBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICBwdXNoYnl0ZXMgImdsb2JhbF9hcmM0X2J5dGVzIgogICAgYnl0ZWNfMSAvLyAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzOS00NDEKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXMgPSBHbG9iYWxTdGF0ZSgKICAgIC8vICAgICBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ0MgogICAgLy8gc2VsZi5nbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDAKICAgIC8vIGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKSwga2V5PSJnbG9iYWxfYXJjNF9ieXRlcyIKICAgIGJ5dGVjXzEgLy8gMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDIKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXNfZXhwbGljaXQgPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIikKICAgIGFwcF9nbG9iYWxfcHV0CgptYWluX2FmdGVyX2lmX2Vsc2VAMjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MjcKICAgIC8vIGNsYXNzIFN0YXRlQXBwR2xvYmFsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJueiBtYWluX2FmdGVyX2lmX2Vsc2VANgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgYm56IG1haW5fYWZ0ZXJfaWZfZWxzZUA2CiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKbWFpbl9hZnRlcl9pZl9lbHNlQDY6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDI3CiAgICAvLyBjbGFzcyBTdGF0ZUFwcEdsb2JhbEV4Q29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHB1c2hpbnQgMCAvLyAwCiAgICByZXR1cm4K", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBHbG9iYWxFeENvbnRyYWN0Ll9fYWxnb3B5X2VudHJ5cG9pbnRfd2l0aF9pbml0KCkgLT4gdWludDY0OgptYWluOgogICAgYnl0ZWNibG9jayAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMgMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzEKICAgIC8vIGtleT0iZ2xvYmFsX3VpbnQ2NCIsCiAgICBwdXNoYnl0ZXMgImdsb2JhbF91aW50NjQiCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDMwCiAgICAvLyBVSW50NjQoMiksCiAgICBwdXNoaW50IDIgLy8gMgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQyOS00MzIKICAgIC8vIHNlbGYuZ2xvYmFsX3VpbnQ2NCA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIFVJbnQ2NCgyKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF91aW50NjQiLAogICAgLy8gKQogICAgYXBwX2dsb2JhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzUKICAgIC8vIGtleT0iZ2xvYmFsX2J5dGVzIiwKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzIgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNAogICAgLy8gQnl0ZXMoYiJkdW1teV9ieXRlcyIpLAogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MzMtNDM2CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlcyA9IEdsb2JhbFN0YXRlKAogICAgLy8gICAgIEJ5dGVzKGIiZHVtbXlfYnl0ZXMiKSwKICAgIC8vICAgICBrZXk9Imdsb2JhbF9ieXRlcyIsCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzNwogICAgLy8gc2VsZi5nbG9iYWxfdWludDY0X2V4cGxpY2l0ID0gYWxnb3B5LlVJbnQ2NCgyKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfdWludDY0X2V4cGxpY2l0IgogICAgcHVzaGludCAyIC8vIDIKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDM4CiAgICAvLyBzZWxmLmdsb2JhbF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5CeXRlcyhiImR1bW15X2J5dGVzIikKICAgIHB1c2hieXRlcyAiZ2xvYmFsX2J5dGVzX2V4cGxpY2l0IgogICAgYnl0ZWNfMCAvLyAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzMKICAgIGFwcF9nbG9iYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6NDQwCiAgICAvLyBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICBwdXNoYnl0ZXMgImdsb2JhbF9hcmM0X2J5dGVzIgogICAgYnl0ZWNfMSAvLyAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQzOS00NDEKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXMgPSBHbG9iYWxTdGF0ZSgKICAgIC8vICAgICBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIiksIGtleT0iZ2xvYmFsX2FyYzRfYnl0ZXMiCiAgICAvLyApCiAgICBhcHBfZ2xvYmFsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjQ0MgogICAgLy8gc2VsZi5nbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKQogICAgcHVzaGJ5dGVzICJnbG9iYWxfYXJjNF9ieXRlc19leHBsaWNpdCIKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDAKICAgIC8vIGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcyhiImR1bW15X2FyYzRfYnl0ZXMiKSwga2V5PSJnbG9iYWxfYXJjNF9ieXRlcyIKICAgIGJ5dGVjXzEgLy8gMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0NDIKICAgIC8vIHNlbGYuZ2xvYmFsX2FyYzRfYnl0ZXNfZXhwbGljaXQgPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoYiJkdW1teV9hcmM0X2J5dGVzIikKICAgIGFwcF9nbG9iYWxfcHV0CgptYWluX2FmdGVyX2lmX2Vsc2VAMjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTo0MjcKICAgIC8vIGNsYXNzIFN0YXRlQXBwR2xvYmFsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgICEKICAgIGFzc2VydAogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiYCC2R1bW15X2J5dGVzEgAQZHVtbXlfYXJjNF9ieXRlczEYQACJgA1nbG9iYWxfdWludDY0gQJngAxnbG9iYWxfYnl0ZXMoZ4AWZ2xvYmFsX3VpbnQ2NF9leHBsaWNpdIECZ4AVZ2xvYmFsX2J5dGVzX2V4cGxpY2l0KGeAEWdsb2JhbF9hcmM0X2J5dGVzKWeAGmdsb2JhbF9hcmM0X2J5dGVzX2V4cGxpY2l0KWcxG0AADDEZQAAHMRgURIEBQ4EAQw==", + "approval": "CiYCC2R1bW15X2J5dGVzEgAQZHVtbXlfYXJjNF9ieXRlczEYQACJgA1nbG9iYWxfdWludDY0gQJngAxnbG9iYWxfYnl0ZXMoZ4AWZ2xvYmFsX3VpbnQ2NF9leHBsaWNpdIECZ4AVZ2xvYmFsX2J5dGVzX2V4cGxpY2l0KGeAEWdsb2JhbF9hcmM0X2J5dGVzKWeAGmdsb2JhbF9hcmM0X2J5dGVzX2V4cGxpY2l0KWcxGxREMRkUMRgUEEM=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAppLocalContract.approval.teal b/tests/artifacts/StateOps/data/StateAppLocalContract.approval.teal index 0f83909..ace3de8 100644 --- a/tests/artifacts/StateOps/data/StateAppLocalContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAppLocalContract.approval.teal @@ -8,163 +8,75 @@ main: // tests/artifacts/StateOps/contract.py:372 // class StateAppLocalContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@14 - pushbytess 0x30c6d58a 0x937b5e13 0x8d742b86 0x7a6d0b59 0x594ff1d9 0x95a31727 0xaa1f4792 0x46245287 0x7f0fdfdd // method "opt_in()void", method "verify_get_bytes(account,byte[])byte[]", method "verify_get_uint64(account,byte[])uint64", method "verify_get_ex_bytes(account,application,byte[])byte[]", method "verify_get_ex_uint64(account,application,byte[])uint64", method "verify_delete(account,byte[])void", method "verify_exists(account,byte[])bool", method "verify_put_uint64(account,byte[],uint64)void", method "verify_put_bytes(account,byte[],byte[])void" + bz main___algopy_default_create@17 + pushbytes 0x30c6d58a // method "opt_in()void" txna ApplicationArgs 0 - match main_opt_in_route@5 main_verify_get_bytes_route@6 main_verify_get_uint64_route@7 main_verify_get_ex_bytes_route@8 main_verify_get_ex_uint64_route@9 main_verify_delete_route@10 main_verify_exists_route@11 main_verify_put_uint64_route@12 main_verify_put_bytes_route@13 + match main_opt_in_route@5 -main_after_if_else@16: +main_switch_case_next@6: // tests/artifacts/StateOps/contract.py:372 // class StateAppLocalContract(ARC4Contract): - intc_1 // 0 - return - -main_verify_put_bytes_route@13: - // tests/artifacts/StateOps/contract.py:422 - // @arc4.abimethod() txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - extract 2 0 - // tests/artifacts/StateOps/contract.py:422 - // @arc4.abimethod() - callsub verify_put_bytes - intc_0 // 1 - return + assert + pushbytess 0xa88302fe 0x49b7ddf9 0xc078bead 0xa52f992b 0x8c56ad90 0x4c7ad823 0xcaa7b864 0x24f9f085 // method "verify_get_bytes(address,byte[])byte[]", method "verify_get_uint64(address,byte[])uint64", method "verify_get_ex_bytes(address,uint64,byte[])byte[]", method "verify_get_ex_uint64(address,uint64,byte[])uint64", method "verify_delete(address,byte[])void", method "verify_exists(address,byte[])bool", method "verify_put_uint64(address,byte[],uint64)void", method "verify_put_bytes(address,byte[],byte[])void" + txna ApplicationArgs 0 + match verify_get_bytes verify_get_uint64 verify_get_ex_bytes verify_get_ex_uint64 verify_delete verify_exists verify_put_uint64 verify_put_bytes + err -main_verify_put_uint64_route@12: - // tests/artifacts/StateOps/contract.py:418 - // @arc4.abimethod() +main_opt_in_route@5: + // tests/artifacts/StateOps/contract.py:384 + // @arc4.abimethod(allow_actions=["OptIn"]) txn OnCompletion - ! - assert // OnCompletion is not NoOp + intc_0 // OptIn + == txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - txna ApplicationArgs 2 - extract 2 0 - txna ApplicationArgs 3 - btoi - // tests/artifacts/StateOps/contract.py:418 - // @arc4.abimethod() - callsub verify_put_uint64 - intc_0 // 1 - return + && + assert // OnCompletion must be OptIn && can only call when not creating + b opt_in -main_verify_exists_route@11: - // tests/artifacts/StateOps/contract.py:413 - // @arc4.abimethod() +main___algopy_default_create@17: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/StateOps/contract.py:413 - // @arc4.abimethod() - callsub verify_exists - pushbytes 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_delete_route@10: - // tests/artifacts/StateOps/contract.py:409 - // @arc4.abimethod() - txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - txna ApplicationArgs 2 - extract 2 0 - // tests/artifacts/StateOps/contract.py:409 - // @arc4.abimethod() - callsub verify_delete - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_get_ex_uint64_route@9: - // tests/artifacts/StateOps/contract.py:404 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - txna ApplicationArgs 2 - btoi - txnas Applications - txna ApplicationArgs 3 - extract 2 0 - // tests/artifacts/StateOps/contract.py:404 - // @arc4.abimethod() - callsub verify_get_ex_uint64 - itob - bytec_0 // 0x151f7c75 - swap - concat - log + +// tests.artifacts.StateOps.contract.StateAppLocalContract.opt_in[routing]() -> void: +opt_in: + // tests/artifacts/StateOps/contract.py:386 + // self.local_bytes[Global.creator_address] = Bytes(b"dummy_bytes") + global CreatorAddress + pushbytess "local_bytes" 0x64756d6d795f6279746573 // "local_bytes", 0x64756d6d795f6279746573 + app_local_put + // tests/artifacts/StateOps/contract.py:387 + // self.local_uint64[Global.creator_address] = UInt64(999) + global CreatorAddress + pushbytes "local_uint64" + pushint 999 // 999 + app_local_put + // tests/artifacts/StateOps/contract.py:384 + // @arc4.abimethod(allow_actions=["OptIn"]) intc_0 // 1 return -main_verify_get_ex_bytes_route@8: - // tests/artifacts/StateOps/contract.py:399 + +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_bytes[routing]() -> void: +verify_get_bytes: + // tests/artifacts/StateOps/contract.py:389 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): txna ApplicationArgs 1 - btoi - txnas Accounts txna ApplicationArgs 2 - btoi - txnas Applications - txna ApplicationArgs 3 extract 2 0 - // tests/artifacts/StateOps/contract.py:399 + // tests/artifacts/StateOps/contract.py:391 + // value = op.AppLocal.get_bytes(a, b) + app_local_get + // tests/artifacts/StateOps/contract.py:389 // @arc4.abimethod() - callsub verify_get_ex_bytes dup len itob @@ -178,24 +90,19 @@ main_verify_get_ex_bytes_route@8: intc_0 // 1 return -main_verify_get_uint64_route@7: + +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_uint64[routing]() -> void: +verify_get_uint64: // tests/artifacts/StateOps/contract.py:394 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): txna ApplicationArgs 1 - btoi - txnas Accounts txna ApplicationArgs 2 extract 2 0 + // tests/artifacts/StateOps/contract.py:396 + // value = op.AppLocal.get_uint64(a, b) + app_local_get // tests/artifacts/StateOps/contract.py:394 // @arc4.abimethod() - callsub verify_get_uint64 itob bytec_0 // 0x151f7c75 swap @@ -204,24 +111,22 @@ main_verify_get_uint64_route@7: intc_0 // 1 return -main_verify_get_bytes_route@6: - // tests/artifacts/StateOps/contract.py:389 + +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_bytes[routing]() -> void: +verify_get_ex_bytes: + // tests/artifacts/StateOps/contract.py:399 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): txna ApplicationArgs 1 - btoi - txnas Accounts txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 extract 2 0 - // tests/artifacts/StateOps/contract.py:389 + // tests/artifacts/StateOps/contract.py:401 + // value, _val = op.AppLocal.get_ex_bytes(a, b, c) + app_local_get_ex + pop + // tests/artifacts/StateOps/contract.py:399 // @arc4.abimethod() - callsub verify_get_bytes dup len itob @@ -235,172 +140,105 @@ main_verify_get_bytes_route@6: intc_0 // 1 return -main_opt_in_route@5: - // tests/artifacts/StateOps/contract.py:384 - // @arc4.abimethod(allow_actions=["OptIn"]) - txn OnCompletion - intc_0 // OptIn - == - assert // OnCompletion is not OptIn - txn ApplicationID - assert // can only call when not creating - callsub opt_in - intc_0 // 1 - return - -main_bare_routing@14: - // tests/artifacts/StateOps/contract.py:372 - // class StateAppLocalContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@16 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.StateOps.contract.StateAppLocalContract.opt_in() -> void: -opt_in: - // tests/artifacts/StateOps/contract.py:386 - // self.local_bytes[Global.creator_address] = Bytes(b"dummy_bytes") - global CreatorAddress - pushbytess "local_bytes" 0x64756d6d795f6279746573 // "local_bytes", 0x64756d6d795f6279746573 - app_local_put - // tests/artifacts/StateOps/contract.py:387 - // self.local_uint64[Global.creator_address] = UInt64(999) - global CreatorAddress - pushbytes "local_uint64" - pushint 999 // 999 - app_local_put - retsub - - -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_bytes(a: bytes, b: bytes) -> bytes: -verify_get_bytes: - // tests/artifacts/StateOps/contract.py:389-390 - // @arc4.abimethod() - // def verify_get_bytes(self, a: Account, b: Bytes) -> Bytes: - proto 2 1 - // tests/artifacts/StateOps/contract.py:391 - // value = op.AppLocal.get_bytes(a, b) - frame_dig -2 - frame_dig -1 - app_local_get - // tests/artifacts/StateOps/contract.py:392 - // return value - retsub - - -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_uint64(a: bytes, b: bytes) -> uint64: -verify_get_uint64: - // tests/artifacts/StateOps/contract.py:394-395 - // @arc4.abimethod() - // def verify_get_uint64(self, a: Account, b: Bytes) -> UInt64: - proto 2 1 - // tests/artifacts/StateOps/contract.py:396 - // value = op.AppLocal.get_uint64(a, b) - frame_dig -2 - frame_dig -1 - app_local_get - // tests/artifacts/StateOps/contract.py:397 - // return value - retsub - - -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_bytes(a: bytes, b: uint64, c: bytes) -> bytes: -verify_get_ex_bytes: - // tests/artifacts/StateOps/contract.py:399-400 - // @arc4.abimethod() - // def verify_get_ex_bytes(self, a: Account, b: Application, c: Bytes) -> Bytes: - proto 3 1 - // tests/artifacts/StateOps/contract.py:401 - // value, _val = op.AppLocal.get_ex_bytes(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 - app_local_get_ex - pop - // tests/artifacts/StateOps/contract.py:402 - // return value - retsub - -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_uint64(a: bytes, b: uint64, c: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_uint64[routing]() -> void: verify_get_ex_uint64: - // tests/artifacts/StateOps/contract.py:404-405 + // tests/artifacts/StateOps/contract.py:404 // @arc4.abimethod() - // def verify_get_ex_uint64(self, a: Account, b: Application, c: Bytes) -> UInt64: - proto 3 1 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + btoi + txna ApplicationArgs 3 + extract 2 0 // tests/artifacts/StateOps/contract.py:406 // value, _val = op.AppLocal.get_ex_uint64(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 app_local_get_ex pop - // tests/artifacts/StateOps/contract.py:407 - // return value - retsub + // tests/artifacts/StateOps/contract.py:404 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_delete(a: bytes, b: bytes) -> void: +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_delete[routing]() -> void: verify_delete: - // tests/artifacts/StateOps/contract.py:409-410 + // tests/artifacts/StateOps/contract.py:409 // @arc4.abimethod() - // def verify_delete(self, a: Account, b: Bytes) -> None: - proto 2 0 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/StateOps/contract.py:411 // op.AppLocal.delete(a, b) - frame_dig -2 - frame_dig -1 app_local_del - retsub + // tests/artifacts/StateOps/contract.py:409 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_exists(a: bytes, b: bytes) -> uint64: +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_exists[routing]() -> void: verify_exists: - // tests/artifacts/StateOps/contract.py:413-414 + // tests/artifacts/StateOps/contract.py:413 // @arc4.abimethod() - // def verify_exists(self, a: Account, b: Bytes) -> bool: - proto 2 1 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + extract 2 0 // tests/artifacts/StateOps/contract.py:415 // _value, exists = op.AppLocal.get_ex_uint64(a, 0, b) - frame_dig -2 intc_1 // 0 - frame_dig -1 + swap app_local_get_ex bury 1 - // tests/artifacts/StateOps/contract.py:416 - // return exists - retsub + // tests/artifacts/StateOps/contract.py:413 + // @arc4.abimethod() + pushbytes 0x00 + intc_1 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_uint64(a: bytes, b: bytes, c: uint64) -> void: +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_uint64[routing]() -> void: verify_put_uint64: - // tests/artifacts/StateOps/contract.py:418-419 + // tests/artifacts/StateOps/contract.py:418 // @arc4.abimethod() - // def verify_put_uint64(self, a: Account, b: Bytes, c: UInt64) -> None: - proto 3 0 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + btoi // tests/artifacts/StateOps/contract.py:420 // op.AppLocal.put(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 app_local_put - retsub + // tests/artifacts/StateOps/contract.py:418 + // @arc4.abimethod() + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_bytes(a: bytes, b: bytes, c: bytes) -> void: +// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_bytes[routing]() -> void: verify_put_bytes: - // tests/artifacts/StateOps/contract.py:422-423 + // tests/artifacts/StateOps/contract.py:422 // @arc4.abimethod() - // def verify_put_bytes(self, a: Account, b: Bytes, c: Bytes) -> None: - proto 3 0 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + extract 2 0 + txna ApplicationArgs 3 + extract 2 0 // tests/artifacts/StateOps/contract.py:424 // op.AppLocal.put(a, b, c) - frame_dig -3 - frame_dig -2 - frame_dig -1 app_local_put - retsub + // tests/artifacts/StateOps/contract.py:422 + // @arc4.abimethod() + intc_0 // 1 + return diff --git a/tests/artifacts/StateOps/data/StateAppLocalContract.arc32.json b/tests/artifacts/StateOps/data/StateAppLocalContract.arc32.json index d893efc..ed08c0b 100644 --- a/tests/artifacts/StateOps/data/StateAppLocalContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAppLocalContract.arc32.json @@ -5,49 +5,49 @@ "opt_in": "CALL" } }, - "verify_get_bytes(account,byte[])byte[]": { + "verify_get_bytes(address,byte[])byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_get_uint64(account,byte[])uint64": { + "verify_get_uint64(address,byte[])uint64": { "call_config": { "no_op": "CALL" } }, - "verify_get_ex_bytes(account,application,byte[])byte[]": { + "verify_get_ex_bytes(address,uint64,byte[])byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_get_ex_uint64(account,application,byte[])uint64": { + "verify_get_ex_uint64(address,uint64,byte[])uint64": { "call_config": { "no_op": "CALL" } }, - "verify_delete(account,byte[])void": { + "verify_delete(address,byte[])void": { "call_config": { "no_op": "CALL" } }, - "verify_exists(account,byte[])bool": { + "verify_exists(address,byte[])bool": { "call_config": { "no_op": "CALL" } }, - "verify_put_uint64(account,byte[],uint64)void": { + "verify_put_uint64(address,byte[],uint64)void": { "call_config": { "no_op": "CALL" } }, - "verify_put_bytes(account,byte[],byte[])void": { + "verify_put_bytes(address,byte[],byte[])void": { "call_config": { "no_op": "CALL" } } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.StateAppLocalContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@14
    pushbytess 0x30c6d58a 0x937b5e13 0x8d742b86 0x7a6d0b59 0x594ff1d9 0x95a31727 0xaa1f4792 0x46245287 0x7f0fdfdd // method "opt_in()void", method "verify_get_bytes(account,byte[])byte[]", method "verify_get_uint64(account,byte[])uint64", method "verify_get_ex_bytes(account,application,byte[])byte[]", method "verify_get_ex_uint64(account,application,byte[])uint64", method "verify_delete(account,byte[])void", method "verify_exists(account,byte[])bool", method "verify_put_uint64(account,byte[],uint64)void", method "verify_put_bytes(account,byte[],byte[])void"
    txna ApplicationArgs 0
    match main_opt_in_route@5 main_verify_get_bytes_route@6 main_verify_get_uint64_route@7 main_verify_get_ex_bytes_route@8 main_verify_get_ex_uint64_route@9 main_verify_delete_route@10 main_verify_exists_route@11 main_verify_put_uint64_route@12 main_verify_put_bytes_route@13

main_after_if_else@16:
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_put_bytes_route@13:
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    callsub verify_put_bytes
    intc_0 // 1
    return

main_verify_put_uint64_route@12:
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    callsub verify_put_uint64
    intc_0 // 1
    return

main_verify_exists_route@11:
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    callsub verify_exists
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_delete_route@10:
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    callsub verify_delete
    intc_0 // 1
    return

main_verify_get_ex_uint64_route@9:
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    callsub verify_get_ex_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_ex_bytes_route@8:
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    callsub verify_get_ex_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_uint64_route@7:
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    callsub verify_get_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_bytes_route@6:
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    callsub verify_get_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:384
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_0 // OptIn
    ==
    assert // OnCompletion is not OptIn
    txn ApplicationID
    assert // can only call when not creating
    callsub opt_in
    intc_0 // 1
    return

main_bare_routing@14:
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@16
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.opt_in() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:386
    // self.local_bytes[Global.creator_address] = Bytes(b"dummy_bytes")
    global CreatorAddress
    pushbytess "local_bytes" 0x64756d6d795f6279746573 // "local_bytes", 0x64756d6d795f6279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:387
    // self.local_uint64[Global.creator_address] = UInt64(999)
    global CreatorAddress
    pushbytes "local_uint64"
    pushint 999 // 999
    app_local_put
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_bytes(a: bytes, b: bytes) -> bytes:
verify_get_bytes:
    // tests/artifacts/StateOps/contract.py:389-390
    // @arc4.abimethod()
    // def verify_get_bytes(self, a: Account, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/StateOps/contract.py:391
    // value = op.AppLocal.get_bytes(a, b)
    frame_dig -2
    frame_dig -1
    app_local_get
    // tests/artifacts/StateOps/contract.py:392
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_uint64(a: bytes, b: bytes) -> uint64:
verify_get_uint64:
    // tests/artifacts/StateOps/contract.py:394-395
    // @arc4.abimethod()
    // def verify_get_uint64(self, a: Account, b: Bytes) -> UInt64:
    proto 2 1
    // tests/artifacts/StateOps/contract.py:396
    // value = op.AppLocal.get_uint64(a, b)
    frame_dig -2
    frame_dig -1
    app_local_get
    // tests/artifacts/StateOps/contract.py:397
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_bytes(a: bytes, b: uint64, c: bytes) -> bytes:
verify_get_ex_bytes:
    // tests/artifacts/StateOps/contract.py:399-400
    // @arc4.abimethod()
    // def verify_get_ex_bytes(self, a: Account, b: Application, c: Bytes) -> Bytes:
    proto 3 1
    // tests/artifacts/StateOps/contract.py:401
    // value, _val = op.AppLocal.get_ex_bytes(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:402
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_uint64(a: bytes, b: uint64, c: bytes) -> uint64:
verify_get_ex_uint64:
    // tests/artifacts/StateOps/contract.py:404-405
    // @arc4.abimethod()
    // def verify_get_ex_uint64(self, a: Account, b: Application, c: Bytes) -> UInt64:
    proto 3 1
    // tests/artifacts/StateOps/contract.py:406
    // value, _val = op.AppLocal.get_ex_uint64(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:407
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_delete(a: bytes, b: bytes) -> void:
verify_delete:
    // tests/artifacts/StateOps/contract.py:409-410
    // @arc4.abimethod()
    // def verify_delete(self, a: Account, b: Bytes) -> None:
    proto 2 0
    // tests/artifacts/StateOps/contract.py:411
    // op.AppLocal.delete(a, b)
    frame_dig -2
    frame_dig -1
    app_local_del
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_exists(a: bytes, b: bytes) -> uint64:
verify_exists:
    // tests/artifacts/StateOps/contract.py:413-414
    // @arc4.abimethod()
    // def verify_exists(self, a: Account, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/StateOps/contract.py:415
    // _value, exists = op.AppLocal.get_ex_uint64(a, 0, b)
    frame_dig -2
    intc_1 // 0
    frame_dig -1
    app_local_get_ex
    bury 1
    // tests/artifacts/StateOps/contract.py:416
    // return exists
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_uint64(a: bytes, b: bytes, c: uint64) -> void:
verify_put_uint64:
    // tests/artifacts/StateOps/contract.py:418-419
    // @arc4.abimethod()
    // def verify_put_uint64(self, a: Account, b: Bytes, c: UInt64) -> None:
    proto 3 0
    // tests/artifacts/StateOps/contract.py:420
    // op.AppLocal.put(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_put
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_bytes(a: bytes, b: bytes, c: bytes) -> void:
verify_put_bytes:
    // tests/artifacts/StateOps/contract.py:422-423
    // @arc4.abimethod()
    // def verify_put_bytes(self, a: Account, b: Bytes, c: Bytes) -> None:
    proto 3 0
    // tests/artifacts/StateOps/contract.py:424
    // op.AppLocal.put(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_put
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.StateAppLocalContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@17
    pushbytes 0x30c6d58a // method "opt_in()void"
    txna ApplicationArgs 0
    match main_opt_in_route@5

main_switch_case_next@6:
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xa88302fe 0x49b7ddf9 0xc078bead 0xa52f992b 0x8c56ad90 0x4c7ad823 0xcaa7b864 0x24f9f085 // method "verify_get_bytes(address,byte[])byte[]", method "verify_get_uint64(address,byte[])uint64", method "verify_get_ex_bytes(address,uint64,byte[])byte[]", method "verify_get_ex_uint64(address,uint64,byte[])uint64", method "verify_delete(address,byte[])void", method "verify_exists(address,byte[])bool", method "verify_put_uint64(address,byte[],uint64)void", method "verify_put_bytes(address,byte[],byte[])void"
    txna ApplicationArgs 0
    match verify_get_bytes verify_get_uint64 verify_get_ex_bytes verify_get_ex_uint64 verify_delete verify_exists verify_put_uint64 verify_put_bytes
    err

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:384
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_0 // OptIn
    ==
    txn ApplicationID
    &&
    assert // OnCompletion must be OptIn && can only call when not creating
    b opt_in

main___algopy_default_create@17:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAppLocalContract.opt_in[routing]() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:386
    // self.local_bytes[Global.creator_address] = Bytes(b"dummy_bytes")
    global CreatorAddress
    pushbytess "local_bytes" 0x64756d6d795f6279746573 // "local_bytes", 0x64756d6d795f6279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:387
    // self.local_uint64[Global.creator_address] = UInt64(999)
    global CreatorAddress
    pushbytes "local_uint64"
    pushint 999 // 999
    app_local_put
    // tests/artifacts/StateOps/contract.py:384
    // @arc4.abimethod(allow_actions=["OptIn"])
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_bytes[routing]() -> void:
verify_get_bytes:
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:391
    // value = op.AppLocal.get_bytes(a, b)
    app_local_get
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_uint64[routing]() -> void:
verify_get_uint64:
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:396
    // value = op.AppLocal.get_uint64(a, b)
    app_local_get
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_bytes[routing]() -> void:
verify_get_ex_bytes:
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:401
    // value, _val = op.AppLocal.get_ex_bytes(a, b, c)
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_uint64[routing]() -> void:
verify_get_ex_uint64:
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:406
    // value, _val = op.AppLocal.get_ex_uint64(a, b, c)
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_delete[routing]() -> void:
verify_delete:
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:411
    // op.AppLocal.delete(a, b)
    app_local_del
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_exists[routing]() -> void:
verify_exists:
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:415
    // _value, exists = op.AppLocal.get_ex_uint64(a, 0, b)
    intc_1 // 0
    swap
    app_local_get_ex
    bury 1
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_uint64[routing]() -> void:
verify_put_uint64:
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/StateOps/contract.py:420
    // op.AppLocal.put(a, b, c)
    app_local_put
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_bytes[routing]() -> void:
verify_put_bytes:
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:424
    // op.AppLocal.put(a, b, c)
    app_local_put
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -94,7 +94,7 @@ "name": "verify_get_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -111,7 +111,7 @@ "name": "verify_get_uint64", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -128,11 +128,11 @@ "name": "verify_get_ex_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "application", + "type": "uint64", "name": "b" }, { @@ -149,11 +149,11 @@ "name": "verify_get_ex_uint64", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "application", + "type": "uint64", "name": "b" }, { @@ -170,7 +170,7 @@ "name": "verify_delete", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -187,7 +187,7 @@ "name": "verify_exists", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -204,7 +204,7 @@ "name": "verify_put_uint64", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -225,7 +225,7 @@ "name": "verify_put_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { diff --git a/tests/artifacts/StateOps/data/StateAppLocalContract.arc56.json b/tests/artifacts/StateOps/data/StateAppLocalContract.arc56.json index f9cd3c8..56f86d6 100644 --- a/tests/artifacts/StateOps/data/StateAppLocalContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAppLocalContract.arc56.json @@ -22,7 +22,7 @@ "name": "verify_get_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -47,7 +47,7 @@ "name": "verify_get_uint64", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -72,11 +72,11 @@ "name": "verify_get_ex_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "application", + "type": "uint64", "name": "b" }, { @@ -101,11 +101,11 @@ "name": "verify_get_ex_uint64", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "application", + "type": "uint64", "name": "b" }, { @@ -130,7 +130,7 @@ "name": "verify_delete", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -155,7 +155,7 @@ "name": "verify_exists", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -180,7 +180,7 @@ "name": "verify_put_uint64", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -209,7 +209,7 @@ "name": "verify_put_bytes", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { @@ -284,42 +284,21 @@ "sourceInfo": [ { "pc": [ - 92, - 122, - 150, - 185, - 209, - 244, - 286, - 315 - ], - "errorMessage": "OnCompletion is not NoOp" - }, - { - "pc": [ - 352 + 33 ], - "errorMessage": "OnCompletion is not OptIn" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 369 + 119 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 95, - 125, - 153, - 188, - 212, - 247, - 289, - 318, - 355 + 108 ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be OptIn && can only call when not creating" } ], "pcOffsetMethod": "none" @@ -330,18 +309,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.StateAppLocalContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@14
    pushbytess 0x30c6d58a 0x937b5e13 0x8d742b86 0x7a6d0b59 0x594ff1d9 0x95a31727 0xaa1f4792 0x46245287 0x7f0fdfdd // method "opt_in()void", method "verify_get_bytes(account,byte[])byte[]", method "verify_get_uint64(account,byte[])uint64", method "verify_get_ex_bytes(account,application,byte[])byte[]", method "verify_get_ex_uint64(account,application,byte[])uint64", method "verify_delete(account,byte[])void", method "verify_exists(account,byte[])bool", method "verify_put_uint64(account,byte[],uint64)void", method "verify_put_bytes(account,byte[],byte[])void"
    txna ApplicationArgs 0
    match main_opt_in_route@5 main_verify_get_bytes_route@6 main_verify_get_uint64_route@7 main_verify_get_ex_bytes_route@8 main_verify_get_ex_uint64_route@9 main_verify_delete_route@10 main_verify_exists_route@11 main_verify_put_uint64_route@12 main_verify_put_bytes_route@13

main_after_if_else@16:
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_put_bytes_route@13:
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    callsub verify_put_bytes
    intc_0 // 1
    return

main_verify_put_uint64_route@12:
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    callsub verify_put_uint64
    intc_0 // 1
    return

main_verify_exists_route@11:
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    callsub verify_exists
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_delete_route@10:
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    callsub verify_delete
    intc_0 // 1
    return

main_verify_get_ex_uint64_route@9:
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    callsub verify_get_ex_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_ex_bytes_route@8:
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    btoi
    txnas Applications
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    callsub verify_get_ex_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_uint64_route@7:
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    callsub verify_get_uint64
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_get_bytes_route@6:
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Accounts
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    callsub verify_get_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:384
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_0 // OptIn
    ==
    assert // OnCompletion is not OptIn
    txn ApplicationID
    assert // can only call when not creating
    callsub opt_in
    intc_0 // 1
    return

main_bare_routing@14:
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@16
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.opt_in() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:386
    // self.local_bytes[Global.creator_address] = Bytes(b"dummy_bytes")
    global CreatorAddress
    pushbytess "local_bytes" 0x64756d6d795f6279746573 // "local_bytes", 0x64756d6d795f6279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:387
    // self.local_uint64[Global.creator_address] = UInt64(999)
    global CreatorAddress
    pushbytes "local_uint64"
    pushint 999 // 999
    app_local_put
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_bytes(a: bytes, b: bytes) -> bytes:
verify_get_bytes:
    // tests/artifacts/StateOps/contract.py:389-390
    // @arc4.abimethod()
    // def verify_get_bytes(self, a: Account, b: Bytes) -> Bytes:
    proto 2 1
    // tests/artifacts/StateOps/contract.py:391
    // value = op.AppLocal.get_bytes(a, b)
    frame_dig -2
    frame_dig -1
    app_local_get
    // tests/artifacts/StateOps/contract.py:392
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_uint64(a: bytes, b: bytes) -> uint64:
verify_get_uint64:
    // tests/artifacts/StateOps/contract.py:394-395
    // @arc4.abimethod()
    // def verify_get_uint64(self, a: Account, b: Bytes) -> UInt64:
    proto 2 1
    // tests/artifacts/StateOps/contract.py:396
    // value = op.AppLocal.get_uint64(a, b)
    frame_dig -2
    frame_dig -1
    app_local_get
    // tests/artifacts/StateOps/contract.py:397
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_bytes(a: bytes, b: uint64, c: bytes) -> bytes:
verify_get_ex_bytes:
    // tests/artifacts/StateOps/contract.py:399-400
    // @arc4.abimethod()
    // def verify_get_ex_bytes(self, a: Account, b: Application, c: Bytes) -> Bytes:
    proto 3 1
    // tests/artifacts/StateOps/contract.py:401
    // value, _val = op.AppLocal.get_ex_bytes(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:402
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_uint64(a: bytes, b: uint64, c: bytes) -> uint64:
verify_get_ex_uint64:
    // tests/artifacts/StateOps/contract.py:404-405
    // @arc4.abimethod()
    // def verify_get_ex_uint64(self, a: Account, b: Application, c: Bytes) -> UInt64:
    proto 3 1
    // tests/artifacts/StateOps/contract.py:406
    // value, _val = op.AppLocal.get_ex_uint64(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:407
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_delete(a: bytes, b: bytes) -> void:
verify_delete:
    // tests/artifacts/StateOps/contract.py:409-410
    // @arc4.abimethod()
    // def verify_delete(self, a: Account, b: Bytes) -> None:
    proto 2 0
    // tests/artifacts/StateOps/contract.py:411
    // op.AppLocal.delete(a, b)
    frame_dig -2
    frame_dig -1
    app_local_del
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_exists(a: bytes, b: bytes) -> uint64:
verify_exists:
    // tests/artifacts/StateOps/contract.py:413-414
    // @arc4.abimethod()
    // def verify_exists(self, a: Account, b: Bytes) -> bool:
    proto 2 1
    // tests/artifacts/StateOps/contract.py:415
    // _value, exists = op.AppLocal.get_ex_uint64(a, 0, b)
    frame_dig -2
    intc_1 // 0
    frame_dig -1
    app_local_get_ex
    bury 1
    // tests/artifacts/StateOps/contract.py:416
    // return exists
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_uint64(a: bytes, b: bytes, c: uint64) -> void:
verify_put_uint64:
    // tests/artifacts/StateOps/contract.py:418-419
    // @arc4.abimethod()
    // def verify_put_uint64(self, a: Account, b: Bytes, c: UInt64) -> None:
    proto 3 0
    // tests/artifacts/StateOps/contract.py:420
    // op.AppLocal.put(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_put
    retsub


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_bytes(a: bytes, b: bytes, c: bytes) -> void:
verify_put_bytes:
    // tests/artifacts/StateOps/contract.py:422-423
    // @arc4.abimethod()
    // def verify_put_bytes(self, a: Account, b: Bytes, c: Bytes) -> None:
    proto 3 0
    // tests/artifacts/StateOps/contract.py:424
    // op.AppLocal.put(a, b, c)
    frame_dig -3
    frame_dig -2
    frame_dig -1
    app_local_put
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// tests.artifacts.StateOps.contract.StateAppLocalContract.__algopy_entrypoint_with_init() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@17
    pushbytes 0x30c6d58a // method "opt_in()void"
    txna ApplicationArgs 0
    match main_opt_in_route@5

main_switch_case_next@6:
    // tests/artifacts/StateOps/contract.py:372
    // class StateAppLocalContract(ARC4Contract):
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xa88302fe 0x49b7ddf9 0xc078bead 0xa52f992b 0x8c56ad90 0x4c7ad823 0xcaa7b864 0x24f9f085 // method "verify_get_bytes(address,byte[])byte[]", method "verify_get_uint64(address,byte[])uint64", method "verify_get_ex_bytes(address,uint64,byte[])byte[]", method "verify_get_ex_uint64(address,uint64,byte[])uint64", method "verify_delete(address,byte[])void", method "verify_exists(address,byte[])bool", method "verify_put_uint64(address,byte[],uint64)void", method "verify_put_bytes(address,byte[],byte[])void"
    txna ApplicationArgs 0
    match verify_get_bytes verify_get_uint64 verify_get_ex_bytes verify_get_ex_uint64 verify_delete verify_exists verify_put_uint64 verify_put_bytes
    err

main_opt_in_route@5:
    // tests/artifacts/StateOps/contract.py:384
    // @arc4.abimethod(allow_actions=["OptIn"])
    txn OnCompletion
    intc_0 // OptIn
    ==
    txn ApplicationID
    &&
    assert // OnCompletion must be OptIn && can only call when not creating
    b opt_in

main___algopy_default_create@17:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAppLocalContract.opt_in[routing]() -> void:
opt_in:
    // tests/artifacts/StateOps/contract.py:386
    // self.local_bytes[Global.creator_address] = Bytes(b"dummy_bytes")
    global CreatorAddress
    pushbytess "local_bytes" 0x64756d6d795f6279746573 // "local_bytes", 0x64756d6d795f6279746573
    app_local_put
    // tests/artifacts/StateOps/contract.py:387
    // self.local_uint64[Global.creator_address] = UInt64(999)
    global CreatorAddress
    pushbytes "local_uint64"
    pushint 999 // 999
    app_local_put
    // tests/artifacts/StateOps/contract.py:384
    // @arc4.abimethod(allow_actions=["OptIn"])
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_bytes[routing]() -> void:
verify_get_bytes:
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:391
    // value = op.AppLocal.get_bytes(a, b)
    app_local_get
    // tests/artifacts/StateOps/contract.py:389
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_uint64[routing]() -> void:
verify_get_uint64:
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:396
    // value = op.AppLocal.get_uint64(a, b)
    app_local_get
    // tests/artifacts/StateOps/contract.py:394
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_bytes[routing]() -> void:
verify_get_ex_bytes:
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:401
    // value, _val = op.AppLocal.get_ex_bytes(a, b, c)
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:399
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_get_ex_uint64[routing]() -> void:
verify_get_ex_uint64:
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:406
    // value, _val = op.AppLocal.get_ex_uint64(a, b, c)
    app_local_get_ex
    pop
    // tests/artifacts/StateOps/contract.py:404
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_delete[routing]() -> void:
verify_delete:
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:411
    // op.AppLocal.delete(a, b)
    app_local_del
    // tests/artifacts/StateOps/contract.py:409
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_exists[routing]() -> void:
verify_exists:
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    // tests/artifacts/StateOps/contract.py:415
    // _value, exists = op.AppLocal.get_ex_uint64(a, 0, b)
    intc_1 // 0
    swap
    app_local_get_ex
    bury 1
    // tests/artifacts/StateOps/contract.py:413
    // @arc4.abimethod()
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_uint64[routing]() -> void:
verify_put_uint64:
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    btoi
    // tests/artifacts/StateOps/contract.py:420
    // op.AppLocal.put(a, b, c)
    app_local_put
    // tests/artifacts/StateOps/contract.py:418
    // @arc4.abimethod()
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppLocalContract.verify_put_bytes[routing]() -> void:
verify_put_bytes:
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    extract 2 0
    txna ApplicationArgs 3
    extract 2 0
    // tests/artifacts/StateOps/contract.py:424
    // op.AppLocal.put(a, b, c)
    app_local_put
    // tests/artifacts/StateOps/contract.py:422
    // @arc4.abimethod()
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiACAQAmAQQVH3x1MRtBAViCCQQwxtWKBJN7XhMEjXQrhgR6bQtZBFlP8dkElaMXJwSqH0eSBEYkUocEfw/f3TYaAI4JAQUA4QDEAJoAdwBfADwAIAACI0MxGRREMRhENhoBF8AcNhoCVwIANhoDVwIAiAF7IkMxGRREMRhENhoBF8AcNhoCVwIANhoDF4gBVCJDMRkURDEYRDYaARfAHDYaAlcCAIgBMIABACNPAlQoTFCwIkMxGRREMRhENhoBF8AcNhoCVwIAiAEEIkMxGRREMRhENhoBF8AcNhoCF8AyNhoDVwIAiADaFihMULAiQzEZFEQxGEQ2GgEXwBw2GgIXwDI2GgNXAgCIAKtJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXwBw2GgJXAgCIAH4WKExQsCJDMRkURDEYRDYaARfAHDYaAlcCAIgAWEkVFlcGAkxQKExQsCJDMRkiEkQxGESIAA0iQzEZQP7pMRgURCJDMgmCAgtsb2NhbF9ieXRlcwtkdW1teV9ieXRlc2YyCYAMbG9jYWxfdWludDY0gecHZomKAgGL/ov/YomKAgGL/ov/YomKAwGL/Yv+i/9jSImKAwGL/Yv+i/9jSImKAgCL/ov/aImKAgGL/iOL/2NFAYmKAwCL/Yv+i/9miYoDAIv9i/6L/2aJ", + "approval": "CiACAQAmAQQVH3x1MRtBAF+ABDDG1Yo2GgCOAQBHMRkURDEYRIIIBKiDAv4ESbfd+QTAeL6tBKUvmSsEjFatkARMetgjBMqnuGQEJPnwhTYaAI4IAEcAXwBwAI0AowCvAMoA2gAxGSISMRgQREIACDEZFDEYFBBDMgmCAgtsb2NhbF9ieXRlcwtkdW1teV9ieXRlc2YyCYAMbG9jYWxfdWludDY0gecHZiJDNhoBNhoCVwIAYkkVFlcGAkxQKExQsCJDNhoBNhoCVwIAYhYoTFCwIkM2GgE2GgIXNhoDVwIAY0hJFRZXBgJMUChMULAiQzYaATYaAhc2GgNXAgBjSBYoTFCwIkM2GgE2GgJXAgBoIkM2GgE2GgJXAgAjTGNFAYABACNPAlQoTFCwIkM2GgE2GgJXAgA2GgMXZiJDNhoBNhoCVwIANhoDVwIAZiJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAppLocalExContract.approval.teal b/tests/artifacts/StateOps/data/StateAppLocalExContract.approval.teal index 6c3d4a5..9e5a212 100644 --- a/tests/artifacts/StateOps/data/StateAppLocalExContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAppLocalExContract.approval.teal @@ -6,16 +6,11 @@ main: // tests/artifacts/StateOps/contract.py:346 // class StateAppLocalExContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@6 + bz main___algopy_default_create@7 pushbytes 0x30c6d58a // method "opt_in()void" txna ApplicationArgs 0 match main_opt_in_route@5 - -main_after_if_else@8: - // tests/artifacts/StateOps/contract.py:346 - // class StateAppLocalExContract(ARC4Contract): - pushint 0 // 0 - return + err main_opt_in_route@5: // tests/artifacts/StateOps/contract.py:363 @@ -23,26 +18,21 @@ main_opt_in_route@5: txn OnCompletion pushint 1 // OptIn == - assert // OnCompletion is not OptIn txn ApplicationID - assert // can only call when not creating - callsub opt_in - pushint 1 // 1 - return + && + assert // OnCompletion must be OptIn && can only call when not creating + b opt_in -main_bare_routing@6: - // tests/artifacts/StateOps/contract.py:346 - // class StateAppLocalExContract(ARC4Contract): +main___algopy_default_create@7: txn OnCompletion - bnz main_after_if_else@8 + ! txn ApplicationID ! - assert // can only call when creating - pushint 1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -// tests.artifacts.StateOps.contract.StateAppLocalExContract.opt_in() -> void: +// tests.artifacts.StateOps.contract.StateAppLocalExContract.opt_in[routing]() -> void: opt_in: // tests/artifacts/StateOps/contract.py:365 // self.local_bytes[Global.creator_address] = Bytes(b"dummy_bytes_from_external_contract") @@ -64,4 +54,7 @@ opt_in: // ) pushbytess "local_arc4_bytes" 0x001064756d6d795f617263345f6279746573 // "local_arc4_bytes", 0x001064756d6d795f617263345f6279746573 app_local_put - retsub + // tests/artifacts/StateOps/contract.py:363 + // @arc4.abimethod(allow_actions=["OptIn"]) + pushint 1 // 1 + return diff --git a/tests/artifacts/StateOps/data/StateAppLocalExContract.arc32.json b/tests/artifacts/StateOps/data/StateAppLocalExContract.arc32.json index 0908da7..0599618 100644 --- a/tests/artifacts/StateOps/data/StateAppLocalExContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAppLocalExContract.arc32.json @@ -7,7 +7,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBMb2NhbEV4Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzQ2CiAgICAvLyBjbGFzcyBTdGF0ZUFwcExvY2FsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIHB1c2hieXRlcyAweDMwYzZkNThhIC8vIG1ldGhvZCAib3B0X2luKCl2b2lkIgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl9vcHRfaW5fcm91dGVANQoKbWFpbl9hZnRlcl9pZl9lbHNlQDg6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzQ2CiAgICAvLyBjbGFzcyBTdGF0ZUFwcExvY2FsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl9vcHRfaW5fcm91dGVANToKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjMKICAgIC8vIEBhcmM0LmFiaW1ldGhvZChhbGxvd19hY3Rpb25zPVsiT3B0SW4iXSkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgIHB1c2hpbnQgMSAvLyBPcHRJbgogICAgPT0KICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE9wdEluCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGNhbGxzdWIgb3B0X2luCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCgptYWluX2JhcmVfcm91dGluZ0A2OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM0NgogICAgLy8gY2xhc3MgU3RhdGVBcHBMb2NhbEV4Q29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgIGJueiBtYWluX2FmdGVyX2lmX2Vsc2VAOAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBMb2NhbEV4Q29udHJhY3Qub3B0X2luKCkgLT4gdm9pZDoKb3B0X2luOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM2NQogICAgLy8gc2VsZi5sb2NhbF9ieXRlc1tHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IEJ5dGVzKGIiZHVtbXlfYnl0ZXNfZnJvbV9leHRlcm5hbF9jb250cmFjdCIpCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgIHB1c2hieXRlc3MgImxvY2FsX2J5dGVzIiAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzM1ZjY2NzI2ZjZkNWY2NTc4NzQ2NTcyNmU2MTZjNWY2MzZmNmU3NDcyNjE2Mzc0IC8vICJsb2NhbF9ieXRlcyIsIDB4NjQ3NTZkNmQ3OTVmNjI3OTc0NjU3MzVmNjY3MjZmNmQ1ZjY1Nzg3NDY1NzI2ZTYxNmM1ZjYzNmY2ZTc0NzI2MTYzNzQKICAgIGFwcF9sb2NhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjYKICAgIC8vIHNlbGYubG9jYWxfdWludDY0W0dsb2JhbC5jcmVhdG9yX2FkZHJlc3NdID0gVUludDY0KDk5KQogICAgZ2xvYmFsIENyZWF0b3JBZGRyZXNzCiAgICBwdXNoYnl0ZXMgImxvY2FsX3VpbnQ2NCIKICAgIHB1c2hpbnQgOTkgLy8gOTkKICAgIGFwcF9sb2NhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjcKICAgIC8vIHNlbGYubG9jYWxfYXJjNF9ieXRlc1tHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcygKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM2Ny0zNjkKICAgIC8vIHNlbGYubG9jYWxfYXJjNF9ieXRlc1tHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcygKICAgIC8vICAgICBiImR1bW15X2FyYzRfYnl0ZXMiCiAgICAvLyApCiAgICBwdXNoYnl0ZXNzICJsb2NhbF9hcmM0X2J5dGVzIiAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MyAvLyAibG9jYWxfYXJjNF9ieXRlcyIsIDB4MDAxMDY0NzU2ZDZkNzk1ZjYxNzI2MzM0NWY2Mjc5NzQ2NTczCiAgICBhcHBfbG9jYWxfcHV0CiAgICByZXRzdWIK", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBMb2NhbEV4Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzQ2CiAgICAvLyBjbGFzcyBTdGF0ZUFwcExvY2FsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANwogICAgcHVzaGJ5dGVzIDB4MzBjNmQ1OGEgLy8gbWV0aG9kICJvcHRfaW4oKXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX29wdF9pbl9yb3V0ZUA1CiAgICBlcnIKCm1haW5fb3B0X2luX3JvdXRlQDU6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoYWxsb3dfYWN0aW9ucz1bIk9wdEluIl0pCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBwdXNoaW50IDEgLy8gT3B0SW4KICAgID09CiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgJiYKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gbXVzdCBiZSBPcHRJbiAmJiBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICBiIG9wdF9pbgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA3OgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLlN0YXRlT3BzLmNvbnRyYWN0LlN0YXRlQXBwTG9jYWxFeENvbnRyYWN0Lm9wdF9pbltyb3V0aW5nXSgpIC0+IHZvaWQ6Cm9wdF9pbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjUKICAgIC8vIHNlbGYubG9jYWxfYnl0ZXNbR2xvYmFsLmNyZWF0b3JfYWRkcmVzc10gPSBCeXRlcyhiImR1bW15X2J5dGVzX2Zyb21fZXh0ZXJuYWxfY29udHJhY3QiKQogICAgZ2xvYmFsIENyZWF0b3JBZGRyZXNzCiAgICBwdXNoYnl0ZXNzICJsb2NhbF9ieXRlcyIgMHg2NDc1NmQ2ZDc5NWY2Mjc5NzQ2NTczNWY2NjcyNmY2ZDVmNjU3ODc0NjU3MjZlNjE2YzVmNjM2ZjZlNzQ3MjYxNjM3NCAvLyAibG9jYWxfYnl0ZXMiLCAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzM1ZjY2NzI2ZjZkNWY2NTc4NzQ2NTcyNmU2MTZjNWY2MzZmNmU3NDcyNjE2Mzc0CiAgICBhcHBfbG9jYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzY2CiAgICAvLyBzZWxmLmxvY2FsX3VpbnQ2NFtHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IFVJbnQ2NCg5OSkKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgcHVzaGJ5dGVzICJsb2NhbF91aW50NjQiCiAgICBwdXNoaW50IDk5IC8vIDk5CiAgICBhcHBfbG9jYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzY3CiAgICAvLyBzZWxmLmxvY2FsX2FyYzRfYnl0ZXNbR2xvYmFsLmNyZWF0b3JfYWRkcmVzc10gPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjctMzY5CiAgICAvLyBzZWxmLmxvY2FsX2FyYzRfYnl0ZXNbR2xvYmFsLmNyZWF0b3JfYWRkcmVzc10gPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoCiAgICAvLyAgICAgYiJkdW1teV9hcmM0X2J5dGVzIgogICAgLy8gKQogICAgcHVzaGJ5dGVzcyAibG9jYWxfYXJjNF9ieXRlcyIgMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMgLy8gImxvY2FsX2FyYzRfYnl0ZXMiLCAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MwogICAgYXBwX2xvY2FsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM2MwogICAgLy8gQGFyYzQuYWJpbWV0aG9kKGFsbG93X2FjdGlvbnM9WyJPcHRJbiJdKQogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/StateOps/data/StateAppLocalExContract.arc56.json b/tests/artifacts/StateOps/data/StateAppLocalExContract.arc56.json index d05fb1e..2246bb0 100644 --- a/tests/artifacts/StateOps/data/StateAppLocalExContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAppLocalExContract.arc56.json @@ -73,21 +73,15 @@ "sourceInfo": [ { "pc": [ - 27 + 39 ], - "errorMessage": "OnCompletion is not OptIn" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 45 + 28 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 30 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be OptIn && can only call when not creating" } ], "pcOffsetMethod": "none" @@ -98,18 +92,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBMb2NhbEV4Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzQ2CiAgICAvLyBjbGFzcyBTdGF0ZUFwcExvY2FsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDYKICAgIHB1c2hieXRlcyAweDMwYzZkNThhIC8vIG1ldGhvZCAib3B0X2luKCl2b2lkIgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAogICAgbWF0Y2ggbWFpbl9vcHRfaW5fcm91dGVANQoKbWFpbl9hZnRlcl9pZl9lbHNlQDg6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzQ2CiAgICAvLyBjbGFzcyBTdGF0ZUFwcExvY2FsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl9vcHRfaW5fcm91dGVANToKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjMKICAgIC8vIEBhcmM0LmFiaW1ldGhvZChhbGxvd19hY3Rpb25zPVsiT3B0SW4iXSkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgIHB1c2hpbnQgMSAvLyBPcHRJbgogICAgPT0KICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE9wdEluCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBub3QgY3JlYXRpbmcKICAgIGNhbGxzdWIgb3B0X2luCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCgptYWluX2JhcmVfcm91dGluZ0A2OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM0NgogICAgLy8gY2xhc3MgU3RhdGVBcHBMb2NhbEV4Q29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIHR4biBPbkNvbXBsZXRpb24KICAgIGJueiBtYWluX2FmdGVyX2lmX2Vsc2VAOAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBMb2NhbEV4Q29udHJhY3Qub3B0X2luKCkgLT4gdm9pZDoKb3B0X2luOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM2NQogICAgLy8gc2VsZi5sb2NhbF9ieXRlc1tHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IEJ5dGVzKGIiZHVtbXlfYnl0ZXNfZnJvbV9leHRlcm5hbF9jb250cmFjdCIpCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgIHB1c2hieXRlc3MgImxvY2FsX2J5dGVzIiAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzM1ZjY2NzI2ZjZkNWY2NTc4NzQ2NTcyNmU2MTZjNWY2MzZmNmU3NDcyNjE2Mzc0IC8vICJsb2NhbF9ieXRlcyIsIDB4NjQ3NTZkNmQ3OTVmNjI3OTc0NjU3MzVmNjY3MjZmNmQ1ZjY1Nzg3NDY1NzI2ZTYxNmM1ZjYzNmY2ZTc0NzI2MTYzNzQKICAgIGFwcF9sb2NhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjYKICAgIC8vIHNlbGYubG9jYWxfdWludDY0W0dsb2JhbC5jcmVhdG9yX2FkZHJlc3NdID0gVUludDY0KDk5KQogICAgZ2xvYmFsIENyZWF0b3JBZGRyZXNzCiAgICBwdXNoYnl0ZXMgImxvY2FsX3VpbnQ2NCIKICAgIHB1c2hpbnQgOTkgLy8gOTkKICAgIGFwcF9sb2NhbF9wdXQKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjcKICAgIC8vIHNlbGYubG9jYWxfYXJjNF9ieXRlc1tHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcygKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM2Ny0zNjkKICAgIC8vIHNlbGYubG9jYWxfYXJjNF9ieXRlc1tHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IGFsZ29weS5hcmM0LkR5bmFtaWNCeXRlcygKICAgIC8vICAgICBiImR1bW15X2FyYzRfYnl0ZXMiCiAgICAvLyApCiAgICBwdXNoYnl0ZXNzICJsb2NhbF9hcmM0X2J5dGVzIiAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MyAvLyAibG9jYWxfYXJjNF9ieXRlcyIsIDB4MDAxMDY0NzU2ZDZkNzk1ZjYxNzI2MzM0NWY2Mjc5NzQ2NTczCiAgICBhcHBfbG9jYWxfcHV0CiAgICByZXRzdWIK", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBcHBMb2NhbEV4Q29udHJhY3QuX19hbGdvcHlfZW50cnlwb2ludF93aXRoX2luaXQoKSAtPiB1aW50NjQ6Cm1haW46CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzQ2CiAgICAvLyBjbGFzcyBTdGF0ZUFwcExvY2FsRXhDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVANwogICAgcHVzaGJ5dGVzIDB4MzBjNmQ1OGEgLy8gbWV0aG9kICJvcHRfaW4oKXZvaWQiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX29wdF9pbl9yb3V0ZUA1CiAgICBlcnIKCm1haW5fb3B0X2luX3JvdXRlQDU6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoYWxsb3dfYWN0aW9ucz1bIk9wdEluIl0pCiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBwdXNoaW50IDEgLy8gT3B0SW4KICAgID09CiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgJiYKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gbXVzdCBiZSBPcHRJbiAmJiBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICBiIG9wdF9pbgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA3OgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCgoKLy8gdGVzdHMuYXJ0aWZhY3RzLlN0YXRlT3BzLmNvbnRyYWN0LlN0YXRlQXBwTG9jYWxFeENvbnRyYWN0Lm9wdF9pbltyb3V0aW5nXSgpIC0+IHZvaWQ6Cm9wdF9pbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjUKICAgIC8vIHNlbGYubG9jYWxfYnl0ZXNbR2xvYmFsLmNyZWF0b3JfYWRkcmVzc10gPSBCeXRlcyhiImR1bW15X2J5dGVzX2Zyb21fZXh0ZXJuYWxfY29udHJhY3QiKQogICAgZ2xvYmFsIENyZWF0b3JBZGRyZXNzCiAgICBwdXNoYnl0ZXNzICJsb2NhbF9ieXRlcyIgMHg2NDc1NmQ2ZDc5NWY2Mjc5NzQ2NTczNWY2NjcyNmY2ZDVmNjU3ODc0NjU3MjZlNjE2YzVmNjM2ZjZlNzQ3MjYxNjM3NCAvLyAibG9jYWxfYnl0ZXMiLCAweDY0NzU2ZDZkNzk1ZjYyNzk3NDY1NzM1ZjY2NzI2ZjZkNWY2NTc4NzQ2NTcyNmU2MTZjNWY2MzZmNmU3NDcyNjE2Mzc0CiAgICBhcHBfbG9jYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzY2CiAgICAvLyBzZWxmLmxvY2FsX3VpbnQ2NFtHbG9iYWwuY3JlYXRvcl9hZGRyZXNzXSA9IFVJbnQ2NCg5OSkKICAgIGdsb2JhbCBDcmVhdG9yQWRkcmVzcwogICAgcHVzaGJ5dGVzICJsb2NhbF91aW50NjQiCiAgICBwdXNoaW50IDk5IC8vIDk5CiAgICBhcHBfbG9jYWxfcHV0CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MzY3CiAgICAvLyBzZWxmLmxvY2FsX2FyYzRfYnl0ZXNbR2xvYmFsLmNyZWF0b3JfYWRkcmVzc10gPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoCiAgICBnbG9iYWwgQ3JlYXRvckFkZHJlc3MKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weTozNjctMzY5CiAgICAvLyBzZWxmLmxvY2FsX2FyYzRfYnl0ZXNbR2xvYmFsLmNyZWF0b3JfYWRkcmVzc10gPSBhbGdvcHkuYXJjNC5EeW5hbWljQnl0ZXMoCiAgICAvLyAgICAgYiJkdW1teV9hcmM0X2J5dGVzIgogICAgLy8gKQogICAgcHVzaGJ5dGVzcyAibG9jYWxfYXJjNF9ieXRlcyIgMHgwMDEwNjQ3NTZkNmQ3OTVmNjE3MjYzMzQ1ZjYyNzk3NDY1NzMgLy8gImxvY2FsX2FyYzRfYnl0ZXMiLCAweDAwMTA2NDc1NmQ2ZDc5NWY2MTcyNjMzNDVmNjI3OTc0NjU3MwogICAgYXBwX2xvY2FsX3B1dAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjM2MwogICAgLy8gQGFyYzQuYWJpbWV0aG9kKGFsbG93X2FjdGlvbnM9WyJPcHRJbiJdKQogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgo=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CjEbQQAfgAQwxtWKNhoAjgEAA4EAQzEZgQESRDEYRIgAD4EBQzEZQP/pMRgURIEBQzIJggILbG9jYWxfYnl0ZXMiZHVtbXlfYnl0ZXNfZnJvbV9leHRlcm5hbF9jb250cmFjdGYyCYAMbG9jYWxfdWludDY0gWNmMgmCAhBsb2NhbF9hcmM0X2J5dGVzEgAQZHVtbXlfYXJjNF9ieXRlc2aJ", + "approval": "CjEbQQAagAQwxtWKNhoAjgEAAQAxGYEBEjEYEERCAAgxGRQxGBQQQzIJggILbG9jYWxfYnl0ZXMiZHVtbXlfYnl0ZXNfZnJvbV9leHRlcm5hbF9jb250cmFjdGYyCYAMbG9jYWxfdWludDY0gWNmMgmCAhBsb2NhbF9hcmM0X2J5dGVzEgAQZHVtbXlfYXJjNF9ieXRlc2aBAUM=", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAppParamsContract.approval.teal b/tests/artifacts/StateOps/data/StateAppParamsContract.approval.teal index 2663f80..7802694 100644 --- a/tests/artifacts/StateOps/data/StateAppParamsContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAppParamsContract.approval.teal @@ -8,262 +8,34 @@ main: // tests/artifacts/StateOps/contract.py:272 // class StateAppParamsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@14 - pushbytess 0x5e7b7d52 0xe29e30ee 0x58819099 0xca77b59b 0x53c0dd9b 0x5f000703 0xd77bd21f 0xa941a746 0xbd3e9eec // method "verify_app_params_get_approval_program(application)byte[]", method "verify_app_params_get_clear_state_program(application)byte[]", method "verify_app_params_get_global_num_uint(application)uint64", method "verify_app_params_get_global_num_byte_slice(application)uint64", method "verify_app_params_get_local_num_uint(application)uint64", method "verify_app_params_get_local_num_byte_slice(application)uint64", method "verify_app_params_get_extra_program_pages(application)uint64", method "verify_app_params_get_creator(application)address", method "verify_app_params_get_address(application)address" - txna ApplicationArgs 0 - match main_verify_app_params_get_approval_program_route@3 main_verify_app_params_get_clear_state_program_route@4 main_verify_app_params_get_global_num_uint_route@5 main_verify_app_params_get_global_num_byte_slice_route@6 main_verify_app_params_get_local_num_uint_route@7 main_verify_app_params_get_local_num_byte_slice_route@8 main_verify_app_params_get_extra_program_pages_route@9 main_verify_app_params_get_creator_route@10 main_verify_app_params_get_address_route@11 - -main_after_if_else@18: - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - pushint 0 // 0 - return - -main_verify_app_params_get_address_route@11: - // tests/artifacts/StateOps/contract.py:337 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:337 - // @arc4.abimethod() - callsub verify_app_params_get_address - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_app_params_get_creator_route@10: - // tests/artifacts/StateOps/contract.py:329 - // @arc4.abimethod() + bz main___algopy_default_create@16 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:329 - // @arc4.abimethod() - callsub verify_app_params_get_creator - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_app_params_get_extra_program_pages_route@9: - // tests/artifacts/StateOps/contract.py:321 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:321 - // @arc4.abimethod() - callsub verify_app_params_get_extra_program_pages - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_app_params_get_local_num_byte_slice_route@8: - // tests/artifacts/StateOps/contract.py:313 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:313 - // @arc4.abimethod() - callsub verify_app_params_get_local_num_byte_slice - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + assert + pushbytess 0xb9d13c1b 0xe5c3c889 0xee4e7b2a 0x7fa234cb 0x19f77439 0x92c572aa 0xae9c6efb 0xe36ed705 0x8c66a842 // method "verify_app_params_get_approval_program(uint64)byte[]", method "verify_app_params_get_clear_state_program(uint64)byte[]", method "verify_app_params_get_global_num_uint(uint64)uint64", method "verify_app_params_get_global_num_byte_slice(uint64)uint64", method "verify_app_params_get_local_num_uint(uint64)uint64", method "verify_app_params_get_local_num_byte_slice(uint64)uint64", method "verify_app_params_get_extra_program_pages(uint64)uint64", method "verify_app_params_get_creator(uint64)address", method "verify_app_params_get_address(uint64)address" + txna ApplicationArgs 0 + match verify_app_params_get_approval_program verify_app_params_get_clear_state_program verify_app_params_get_global_num_uint verify_app_params_get_global_num_byte_slice verify_app_params_get_local_num_uint verify_app_params_get_local_num_byte_slice verify_app_params_get_extra_program_pages verify_app_params_get_creator verify_app_params_get_address + err -main_verify_app_params_get_local_num_uint_route@7: - // tests/artifacts/StateOps/contract.py:305 - // @arc4.abimethod() +main___algopy_default_create@16: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:305 - // @arc4.abimethod() - callsub verify_app_params_get_local_num_uint - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_app_params_get_global_num_byte_slice_route@6: - // tests/artifacts/StateOps/contract.py:297 - // @arc4.abimethod() - txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:297 - // @arc4.abimethod() - callsub verify_app_params_get_global_num_byte_slice - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_app_params_get_global_num_uint_route@5: - // tests/artifacts/StateOps/contract.py:289 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:289 - // @arc4.abimethod() - callsub verify_app_params_get_global_num_uint - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_app_params_get_clear_state_program_route@4: - // tests/artifacts/StateOps/contract.py:281 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:281 - // @arc4.abimethod() - callsub verify_app_params_get_clear_state_program - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_app_params_get_approval_program_route@3: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_approval_program[routing]() -> void: +verify_app_params_get_approval_program: // tests/artifacts/StateOps/contract.py:273 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): txna ApplicationArgs 1 btoi - txnas Applications - // tests/artifacts/StateOps/contract.py:273 - // @arc4.abimethod() - callsub verify_app_params_get_approval_program - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_bare_routing@14: - // tests/artifacts/StateOps/contract.py:272 - // class StateAppParamsContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@18 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_approval_program(a: uint64) -> bytes: -verify_app_params_get_approval_program: - // tests/artifacts/StateOps/contract.py:273-274 - // @arc4.abimethod() - // def verify_app_params_get_approval_program(self, a: Application) -> Bytes: - proto 1 1 // tests/artifacts/StateOps/contract.py:275 // value, exists = op.AppParamsGet.app_approval_program(a) - frame_dig -1 app_params_get AppApprovalProgram // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -282,20 +54,30 @@ verify_app_params_get_approval_program: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:279 - // return value - retsub + // tests/artifacts/StateOps/contract.py:273 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_clear_state_program(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_clear_state_program[routing]() -> void: verify_app_params_get_clear_state_program: - // tests/artifacts/StateOps/contract.py:281-282 + // tests/artifacts/StateOps/contract.py:281 // @arc4.abimethod() - // def verify_app_params_get_clear_state_program(self, a: Application) -> Bytes: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:283 // value, exists = op.AppParamsGet.app_clear_state_program(a) - frame_dig -1 app_params_get AppClearStateProgram // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -314,20 +96,30 @@ verify_app_params_get_clear_state_program: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:287 - // return value - retsub + // tests/artifacts/StateOps/contract.py:281 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_uint(a: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_uint[routing]() -> void: verify_app_params_get_global_num_uint: - // tests/artifacts/StateOps/contract.py:289-290 + // tests/artifacts/StateOps/contract.py:289 // @arc4.abimethod() - // def verify_app_params_get_global_num_uint(self, a: Application) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:291 // value, exists = op.AppParamsGet.app_global_num_uint(a) - frame_dig -1 app_params_get AppGlobalNumUint // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -346,20 +138,25 @@ verify_app_params_get_global_num_uint: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:295 - // return value - retsub + // tests/artifacts/StateOps/contract.py:289 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_byte_slice(a: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_byte_slice[routing]() -> void: verify_app_params_get_global_num_byte_slice: - // tests/artifacts/StateOps/contract.py:297-298 + // tests/artifacts/StateOps/contract.py:297 // @arc4.abimethod() - // def verify_app_params_get_global_num_byte_slice(self, a: Application) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:299 // value, exists = op.AppParamsGet.app_global_num_byte_slice(a) - frame_dig -1 app_params_get AppGlobalNumByteSlice // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -378,20 +175,25 @@ verify_app_params_get_global_num_byte_slice: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:303 - // return value - retsub + // tests/artifacts/StateOps/contract.py:297 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_uint(a: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_uint[routing]() -> void: verify_app_params_get_local_num_uint: - // tests/artifacts/StateOps/contract.py:305-306 + // tests/artifacts/StateOps/contract.py:305 // @arc4.abimethod() - // def verify_app_params_get_local_num_uint(self, a: Application) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:307 // value, exists = op.AppParamsGet.app_local_num_uint(a) - frame_dig -1 app_params_get AppLocalNumUint // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -410,20 +212,25 @@ verify_app_params_get_local_num_uint: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:311 - // return value - retsub + // tests/artifacts/StateOps/contract.py:305 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_byte_slice(a: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_byte_slice[routing]() -> void: verify_app_params_get_local_num_byte_slice: - // tests/artifacts/StateOps/contract.py:313-314 + // tests/artifacts/StateOps/contract.py:313 // @arc4.abimethod() - // def verify_app_params_get_local_num_byte_slice(self, a: Application) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:315 // value, exists = op.AppParamsGet.app_local_num_byte_slice(a) - frame_dig -1 app_params_get AppLocalNumByteSlice // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -442,20 +249,25 @@ verify_app_params_get_local_num_byte_slice: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:319 - // return value - retsub + // tests/artifacts/StateOps/contract.py:313 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_extra_program_pages(a: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_extra_program_pages[routing]() -> void: verify_app_params_get_extra_program_pages: - // tests/artifacts/StateOps/contract.py:321-322 + // tests/artifacts/StateOps/contract.py:321 // @arc4.abimethod() - // def verify_app_params_get_extra_program_pages(self, a: Application) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:323 // value, exists = op.AppParamsGet.app_extra_program_pages(a) - frame_dig -1 app_params_get AppExtraProgramPages // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -474,20 +286,25 @@ verify_app_params_get_extra_program_pages: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:327 - // return value - retsub + // tests/artifacts/StateOps/contract.py:321 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_creator(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_creator[routing]() -> void: verify_app_params_get_creator: - // tests/artifacts/StateOps/contract.py:329-330 + // tests/artifacts/StateOps/contract.py:329 // @arc4.abimethod() - // def verify_app_params_get_creator(self, a: Application) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:331 // value, exists = op.AppParamsGet.app_creator(a) - frame_dig -1 app_params_get AppCreator // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -506,20 +323,24 @@ verify_app_params_get_creator: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:335 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:329 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_address(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_address[routing]() -> void: verify_app_params_get_address: - // tests/artifacts/StateOps/contract.py:337-338 + // tests/artifacts/StateOps/contract.py:337 // @arc4.abimethod() - // def verify_app_params_get_address(self, a: Application) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:339 // value, exists = op.AppParamsGet.app_address(a) - frame_dig -1 app_params_get AppAddress // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -538,6 +359,11 @@ verify_app_params_get_address: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:343 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:337 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return diff --git a/tests/artifacts/StateOps/data/StateAppParamsContract.arc32.json b/tests/artifacts/StateOps/data/StateAppParamsContract.arc32.json index 70ae17f..974ff1f 100644 --- a/tests/artifacts/StateOps/data/StateAppParamsContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAppParamsContract.arc32.json @@ -1,53 +1,53 @@ { "hints": { - "verify_app_params_get_approval_program(application)byte[]": { + "verify_app_params_get_approval_program(uint64)byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_clear_state_program(application)byte[]": { + "verify_app_params_get_clear_state_program(uint64)byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_global_num_uint(application)uint64": { + "verify_app_params_get_global_num_uint(uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_global_num_byte_slice(application)uint64": { + "verify_app_params_get_global_num_byte_slice(uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_local_num_uint(application)uint64": { + "verify_app_params_get_local_num_uint(uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_local_num_byte_slice(application)uint64": { + "verify_app_params_get_local_num_byte_slice(uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_extra_program_pages(application)uint64": { + "verify_app_params_get_extra_program_pages(uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_creator(application)address": { + "verify_app_params_get_creator(uint64)address": { "call_config": { "no_op": "CALL" } }, - "verify_app_params_get_address(application)address": { + "verify_app_params_get_address(uint64)address": { "call_config": { "no_op": "CALL" } } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@14
    pushbytess 0x5e7b7d52 0xe29e30ee 0x58819099 0xca77b59b 0x53c0dd9b 0x5f000703 0xd77bd21f 0xa941a746 0xbd3e9eec // method "verify_app_params_get_approval_program(application)byte[]", method "verify_app_params_get_clear_state_program(application)byte[]", method "verify_app_params_get_global_num_uint(application)uint64", method "verify_app_params_get_global_num_byte_slice(application)uint64", method "verify_app_params_get_local_num_uint(application)uint64", method "verify_app_params_get_local_num_byte_slice(application)uint64", method "verify_app_params_get_extra_program_pages(application)uint64", method "verify_app_params_get_creator(application)address", method "verify_app_params_get_address(application)address"
    txna ApplicationArgs 0
    match main_verify_app_params_get_approval_program_route@3 main_verify_app_params_get_clear_state_program_route@4 main_verify_app_params_get_global_num_uint_route@5 main_verify_app_params_get_global_num_byte_slice_route@6 main_verify_app_params_get_local_num_uint_route@7 main_verify_app_params_get_local_num_byte_slice_route@8 main_verify_app_params_get_extra_program_pages_route@9 main_verify_app_params_get_creator_route@10 main_verify_app_params_get_address_route@11

main_after_if_else@18:
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    pushint 0 // 0
    return

main_verify_app_params_get_address_route@11:
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    callsub verify_app_params_get_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_creator_route@10:
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    callsub verify_app_params_get_creator
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_extra_program_pages_route@9:
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    callsub verify_app_params_get_extra_program_pages
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_local_num_byte_slice_route@8:
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    callsub verify_app_params_get_local_num_byte_slice
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_local_num_uint_route@7:
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    callsub verify_app_params_get_local_num_uint
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_global_num_byte_slice_route@6:
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    callsub verify_app_params_get_global_num_byte_slice
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_global_num_uint_route@5:
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    callsub verify_app_params_get_global_num_uint
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_clear_state_program_route@4:
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    callsub verify_app_params_get_clear_state_program
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_approval_program_route@3:
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    callsub verify_app_params_get_approval_program
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@14:
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@18
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_approval_program(a: uint64) -> bytes:
verify_app_params_get_approval_program:
    // tests/artifacts/StateOps/contract.py:273-274
    // @arc4.abimethod()
    // def verify_app_params_get_approval_program(self, a: Application) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:275
    // value, exists = op.AppParamsGet.app_approval_program(a)
    frame_dig -1
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:276
    // value_index, exists_index = op.AppParamsGet.app_approval_program(_get_1st_ref_index())
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:277
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:278
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:279
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_clear_state_program(a: uint64) -> bytes:
verify_app_params_get_clear_state_program:
    // tests/artifacts/StateOps/contract.py:281-282
    // @arc4.abimethod()
    // def verify_app_params_get_clear_state_program(self, a: Application) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:283
    // value, exists = op.AppParamsGet.app_clear_state_program(a)
    frame_dig -1
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:284
    // value_index, exists_index = op.AppParamsGet.app_clear_state_program(_get_1st_ref_index())
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:285
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:286
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:287
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_uint(a: uint64) -> uint64:
verify_app_params_get_global_num_uint:
    // tests/artifacts/StateOps/contract.py:289-290
    // @arc4.abimethod()
    // def verify_app_params_get_global_num_uint(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:291
    // value, exists = op.AppParamsGet.app_global_num_uint(a)
    frame_dig -1
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:292
    // value_index, exists_index = op.AppParamsGet.app_global_num_uint(_get_1st_ref_index())
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:293
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:294
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:295
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_byte_slice(a: uint64) -> uint64:
verify_app_params_get_global_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:297-298
    // @arc4.abimethod()
    // def verify_app_params_get_global_num_byte_slice(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:299
    // value, exists = op.AppParamsGet.app_global_num_byte_slice(a)
    frame_dig -1
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:300
    // value_index, exists_index = op.AppParamsGet.app_global_num_byte_slice(_get_1st_ref_index())
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:301
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:302
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:303
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_uint(a: uint64) -> uint64:
verify_app_params_get_local_num_uint:
    // tests/artifacts/StateOps/contract.py:305-306
    // @arc4.abimethod()
    // def verify_app_params_get_local_num_uint(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:307
    // value, exists = op.AppParamsGet.app_local_num_uint(a)
    frame_dig -1
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:308
    // value_index, exists_index = op.AppParamsGet.app_local_num_uint(_get_1st_ref_index())
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:309
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:310
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:311
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_byte_slice(a: uint64) -> uint64:
verify_app_params_get_local_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:313-314
    // @arc4.abimethod()
    // def verify_app_params_get_local_num_byte_slice(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:315
    // value, exists = op.AppParamsGet.app_local_num_byte_slice(a)
    frame_dig -1
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:316
    // value_index, exists_index = op.AppParamsGet.app_local_num_byte_slice(_get_1st_ref_index())
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:317
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:318
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:319
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_extra_program_pages(a: uint64) -> uint64:
verify_app_params_get_extra_program_pages:
    // tests/artifacts/StateOps/contract.py:321-322
    // @arc4.abimethod()
    // def verify_app_params_get_extra_program_pages(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:323
    // value, exists = op.AppParamsGet.app_extra_program_pages(a)
    frame_dig -1
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:324
    // value_index, exists_index = op.AppParamsGet.app_extra_program_pages(_get_1st_ref_index())
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:325
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:326
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:327
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_creator(a: uint64) -> bytes:
verify_app_params_get_creator:
    // tests/artifacts/StateOps/contract.py:329-330
    // @arc4.abimethod()
    // def verify_app_params_get_creator(self, a: Application) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:331
    // value, exists = op.AppParamsGet.app_creator(a)
    frame_dig -1
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:332
    // value_index, exists_index = op.AppParamsGet.app_creator(_get_1st_ref_index())
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:333
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:334
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:335
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_address(a: uint64) -> bytes:
verify_app_params_get_address:
    // tests/artifacts/StateOps/contract.py:337-338
    // @arc4.abimethod()
    // def verify_app_params_get_address(self, a: Application) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:339
    // value, exists = op.AppParamsGet.app_address(a)
    frame_dig -1
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:340
    // value_index, exists_index = op.AppParamsGet.app_address(_get_1st_ref_index())
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:341
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:342
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:343
    // return arc4.Address(value)
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@16
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xb9d13c1b 0xe5c3c889 0xee4e7b2a 0x7fa234cb 0x19f77439 0x92c572aa 0xae9c6efb 0xe36ed705 0x8c66a842 // method "verify_app_params_get_approval_program(uint64)byte[]", method "verify_app_params_get_clear_state_program(uint64)byte[]", method "verify_app_params_get_global_num_uint(uint64)uint64", method "verify_app_params_get_global_num_byte_slice(uint64)uint64", method "verify_app_params_get_local_num_uint(uint64)uint64", method "verify_app_params_get_local_num_byte_slice(uint64)uint64", method "verify_app_params_get_extra_program_pages(uint64)uint64", method "verify_app_params_get_creator(uint64)address", method "verify_app_params_get_address(uint64)address"
    txna ApplicationArgs 0
    match verify_app_params_get_approval_program verify_app_params_get_clear_state_program verify_app_params_get_global_num_uint verify_app_params_get_global_num_byte_slice verify_app_params_get_local_num_uint verify_app_params_get_local_num_byte_slice verify_app_params_get_extra_program_pages verify_app_params_get_creator verify_app_params_get_address
    err

main___algopy_default_create@16:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_approval_program[routing]() -> void:
verify_app_params_get_approval_program:
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:275
    // value, exists = op.AppParamsGet.app_approval_program(a)
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:276
    // value_index, exists_index = op.AppParamsGet.app_approval_program(_get_1st_ref_index())
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:277
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:278
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_clear_state_program[routing]() -> void:
verify_app_params_get_clear_state_program:
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:283
    // value, exists = op.AppParamsGet.app_clear_state_program(a)
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:284
    // value_index, exists_index = op.AppParamsGet.app_clear_state_program(_get_1st_ref_index())
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:285
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:286
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_uint[routing]() -> void:
verify_app_params_get_global_num_uint:
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:291
    // value, exists = op.AppParamsGet.app_global_num_uint(a)
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:292
    // value_index, exists_index = op.AppParamsGet.app_global_num_uint(_get_1st_ref_index())
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:293
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:294
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_byte_slice[routing]() -> void:
verify_app_params_get_global_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:299
    // value, exists = op.AppParamsGet.app_global_num_byte_slice(a)
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:300
    // value_index, exists_index = op.AppParamsGet.app_global_num_byte_slice(_get_1st_ref_index())
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:301
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:302
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_uint[routing]() -> void:
verify_app_params_get_local_num_uint:
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:307
    // value, exists = op.AppParamsGet.app_local_num_uint(a)
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:308
    // value_index, exists_index = op.AppParamsGet.app_local_num_uint(_get_1st_ref_index())
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:309
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:310
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_byte_slice[routing]() -> void:
verify_app_params_get_local_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:315
    // value, exists = op.AppParamsGet.app_local_num_byte_slice(a)
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:316
    // value_index, exists_index = op.AppParamsGet.app_local_num_byte_slice(_get_1st_ref_index())
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:317
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:318
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_extra_program_pages[routing]() -> void:
verify_app_params_get_extra_program_pages:
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:323
    // value, exists = op.AppParamsGet.app_extra_program_pages(a)
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:324
    // value_index, exists_index = op.AppParamsGet.app_extra_program_pages(_get_1st_ref_index())
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:325
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:326
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_creator[routing]() -> void:
verify_app_params_get_creator:
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:331
    // value, exists = op.AppParamsGet.app_creator(a)
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:332
    // value_index, exists_index = op.AppParamsGet.app_creator(_get_1st_ref_index())
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:333
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:334
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_address[routing]() -> void:
verify_app_params_get_address:
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:339
    // value, exists = op.AppParamsGet.app_address(a)
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:340
    // value_index, exists_index = op.AppParamsGet.app_address(_get_1st_ref_index())
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:341
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:342
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -77,7 +77,7 @@ "name": "verify_app_params_get_approval_program", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -90,7 +90,7 @@ "name": "verify_app_params_get_clear_state_program", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -103,7 +103,7 @@ "name": "verify_app_params_get_global_num_uint", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -116,7 +116,7 @@ "name": "verify_app_params_get_global_num_byte_slice", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -129,7 +129,7 @@ "name": "verify_app_params_get_local_num_uint", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -142,7 +142,7 @@ "name": "verify_app_params_get_local_num_byte_slice", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -155,7 +155,7 @@ "name": "verify_app_params_get_extra_program_pages", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -168,7 +168,7 @@ "name": "verify_app_params_get_creator", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -181,7 +181,7 @@ "name": "verify_app_params_get_address", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], diff --git a/tests/artifacts/StateOps/data/StateAppParamsContract.arc56.json b/tests/artifacts/StateOps/data/StateAppParamsContract.arc56.json index 23d0670..9528f70 100644 --- a/tests/artifacts/StateOps/data/StateAppParamsContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAppParamsContract.arc56.json @@ -6,7 +6,7 @@ "name": "verify_app_params_get_approval_program", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -27,7 +27,7 @@ "name": "verify_app_params_get_clear_state_program", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -48,7 +48,7 @@ "name": "verify_app_params_get_global_num_uint", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -69,7 +69,7 @@ "name": "verify_app_params_get_global_num_byte_slice", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -90,7 +90,7 @@ "name": "verify_app_params_get_local_num_uint", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -111,7 +111,7 @@ "name": "verify_app_params_get_local_num_byte_slice", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -132,7 +132,7 @@ "name": "verify_app_params_get_extra_program_pages", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -153,7 +153,7 @@ "name": "verify_app_params_get_creator", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -174,7 +174,7 @@ "name": "verify_app_params_get_address", "args": [ { - "type": "application", + "type": "uint64", "name": "a" } ], @@ -230,63 +230,41 @@ "sourceInfo": [ { "pc": [ - 92, - 114, - 136, - 159, - 182, - 205, - 228, - 251, - 281 + 19 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 316 + 101 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 95, - 117, - 139, - 162, - 185, - 208, - 231, - 254, - 284 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 339, - 361, - 383, - 405, - 427, - 449, - 471, - 493, - 515 + 121, + 155, + 189, + 216, + 243, + 270, + 297, + 324, + 350 ], "errorMessage": "expected exists by index to match" }, { "pc": [ - 337, - 359, - 381, - 403, - 425, - 447, - 469, - 491, - 513 + 119, + 153, + 187, + 214, + 241, + 268, + 295, + 322, + 348 ], "errorMessage": "expected value by index to match" } @@ -299,18 +277,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@14
    pushbytess 0x5e7b7d52 0xe29e30ee 0x58819099 0xca77b59b 0x53c0dd9b 0x5f000703 0xd77bd21f 0xa941a746 0xbd3e9eec // method "verify_app_params_get_approval_program(application)byte[]", method "verify_app_params_get_clear_state_program(application)byte[]", method "verify_app_params_get_global_num_uint(application)uint64", method "verify_app_params_get_global_num_byte_slice(application)uint64", method "verify_app_params_get_local_num_uint(application)uint64", method "verify_app_params_get_local_num_byte_slice(application)uint64", method "verify_app_params_get_extra_program_pages(application)uint64", method "verify_app_params_get_creator(application)address", method "verify_app_params_get_address(application)address"
    txna ApplicationArgs 0
    match main_verify_app_params_get_approval_program_route@3 main_verify_app_params_get_clear_state_program_route@4 main_verify_app_params_get_global_num_uint_route@5 main_verify_app_params_get_global_num_byte_slice_route@6 main_verify_app_params_get_local_num_uint_route@7 main_verify_app_params_get_local_num_byte_slice_route@8 main_verify_app_params_get_extra_program_pages_route@9 main_verify_app_params_get_creator_route@10 main_verify_app_params_get_address_route@11

main_after_if_else@18:
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    pushint 0 // 0
    return

main_verify_app_params_get_address_route@11:
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    callsub verify_app_params_get_address
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_creator_route@10:
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    callsub verify_app_params_get_creator
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_extra_program_pages_route@9:
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    callsub verify_app_params_get_extra_program_pages
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_local_num_byte_slice_route@8:
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    callsub verify_app_params_get_local_num_byte_slice
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_local_num_uint_route@7:
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    callsub verify_app_params_get_local_num_uint
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_global_num_byte_slice_route@6:
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    callsub verify_app_params_get_global_num_byte_slice
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_global_num_uint_route@5:
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    callsub verify_app_params_get_global_num_uint
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_clear_state_program_route@4:
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    callsub verify_app_params_get_clear_state_program
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_app_params_get_approval_program_route@3:
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Applications
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    callsub verify_app_params_get_approval_program
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@14:
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@18
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_approval_program(a: uint64) -> bytes:
verify_app_params_get_approval_program:
    // tests/artifacts/StateOps/contract.py:273-274
    // @arc4.abimethod()
    // def verify_app_params_get_approval_program(self, a: Application) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:275
    // value, exists = op.AppParamsGet.app_approval_program(a)
    frame_dig -1
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:276
    // value_index, exists_index = op.AppParamsGet.app_approval_program(_get_1st_ref_index())
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:277
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:278
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:279
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_clear_state_program(a: uint64) -> bytes:
verify_app_params_get_clear_state_program:
    // tests/artifacts/StateOps/contract.py:281-282
    // @arc4.abimethod()
    // def verify_app_params_get_clear_state_program(self, a: Application) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:283
    // value, exists = op.AppParamsGet.app_clear_state_program(a)
    frame_dig -1
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:284
    // value_index, exists_index = op.AppParamsGet.app_clear_state_program(_get_1st_ref_index())
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:285
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:286
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:287
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_uint(a: uint64) -> uint64:
verify_app_params_get_global_num_uint:
    // tests/artifacts/StateOps/contract.py:289-290
    // @arc4.abimethod()
    // def verify_app_params_get_global_num_uint(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:291
    // value, exists = op.AppParamsGet.app_global_num_uint(a)
    frame_dig -1
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:292
    // value_index, exists_index = op.AppParamsGet.app_global_num_uint(_get_1st_ref_index())
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:293
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:294
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:295
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_byte_slice(a: uint64) -> uint64:
verify_app_params_get_global_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:297-298
    // @arc4.abimethod()
    // def verify_app_params_get_global_num_byte_slice(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:299
    // value, exists = op.AppParamsGet.app_global_num_byte_slice(a)
    frame_dig -1
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:300
    // value_index, exists_index = op.AppParamsGet.app_global_num_byte_slice(_get_1st_ref_index())
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:301
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:302
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:303
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_uint(a: uint64) -> uint64:
verify_app_params_get_local_num_uint:
    // tests/artifacts/StateOps/contract.py:305-306
    // @arc4.abimethod()
    // def verify_app_params_get_local_num_uint(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:307
    // value, exists = op.AppParamsGet.app_local_num_uint(a)
    frame_dig -1
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:308
    // value_index, exists_index = op.AppParamsGet.app_local_num_uint(_get_1st_ref_index())
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:309
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:310
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:311
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_byte_slice(a: uint64) -> uint64:
verify_app_params_get_local_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:313-314
    // @arc4.abimethod()
    // def verify_app_params_get_local_num_byte_slice(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:315
    // value, exists = op.AppParamsGet.app_local_num_byte_slice(a)
    frame_dig -1
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:316
    // value_index, exists_index = op.AppParamsGet.app_local_num_byte_slice(_get_1st_ref_index())
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:317
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:318
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:319
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_extra_program_pages(a: uint64) -> uint64:
verify_app_params_get_extra_program_pages:
    // tests/artifacts/StateOps/contract.py:321-322
    // @arc4.abimethod()
    // def verify_app_params_get_extra_program_pages(self, a: Application) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:323
    // value, exists = op.AppParamsGet.app_extra_program_pages(a)
    frame_dig -1
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:324
    // value_index, exists_index = op.AppParamsGet.app_extra_program_pages(_get_1st_ref_index())
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:325
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:326
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:327
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_creator(a: uint64) -> bytes:
verify_app_params_get_creator:
    // tests/artifacts/StateOps/contract.py:329-330
    // @arc4.abimethod()
    // def verify_app_params_get_creator(self, a: Application) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:331
    // value, exists = op.AppParamsGet.app_creator(a)
    frame_dig -1
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:332
    // value_index, exists_index = op.AppParamsGet.app_creator(_get_1st_ref_index())
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:333
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:334
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:335
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_address(a: uint64) -> bytes:
verify_app_params_get_address:
    // tests/artifacts/StateOps/contract.py:337-338
    // @arc4.abimethod()
    // def verify_app_params_get_address(self, a: Application) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:339
    // value, exists = op.AppParamsGet.app_address(a)
    frame_dig -1
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:340
    // value_index, exists_index = op.AppParamsGet.app_address(_get_1st_ref_index())
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:341
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:342
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:343
    // return arc4.Address(value)
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:272
    // class StateAppParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@16
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xb9d13c1b 0xe5c3c889 0xee4e7b2a 0x7fa234cb 0x19f77439 0x92c572aa 0xae9c6efb 0xe36ed705 0x8c66a842 // method "verify_app_params_get_approval_program(uint64)byte[]", method "verify_app_params_get_clear_state_program(uint64)byte[]", method "verify_app_params_get_global_num_uint(uint64)uint64", method "verify_app_params_get_global_num_byte_slice(uint64)uint64", method "verify_app_params_get_local_num_uint(uint64)uint64", method "verify_app_params_get_local_num_byte_slice(uint64)uint64", method "verify_app_params_get_extra_program_pages(uint64)uint64", method "verify_app_params_get_creator(uint64)address", method "verify_app_params_get_address(uint64)address"
    txna ApplicationArgs 0
    match verify_app_params_get_approval_program verify_app_params_get_clear_state_program verify_app_params_get_global_num_uint verify_app_params_get_global_num_byte_slice verify_app_params_get_local_num_uint verify_app_params_get_local_num_byte_slice verify_app_params_get_extra_program_pages verify_app_params_get_creator verify_app_params_get_address
    err

main___algopy_default_create@16:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_approval_program[routing]() -> void:
verify_app_params_get_approval_program:
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:275
    // value, exists = op.AppParamsGet.app_approval_program(a)
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:276
    // value_index, exists_index = op.AppParamsGet.app_approval_program(_get_1st_ref_index())
    app_params_get AppApprovalProgram
    // tests/artifacts/StateOps/contract.py:277
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:278
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:273
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_clear_state_program[routing]() -> void:
verify_app_params_get_clear_state_program:
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:283
    // value, exists = op.AppParamsGet.app_clear_state_program(a)
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:284
    // value_index, exists_index = op.AppParamsGet.app_clear_state_program(_get_1st_ref_index())
    app_params_get AppClearStateProgram
    // tests/artifacts/StateOps/contract.py:285
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:286
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:281
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_uint[routing]() -> void:
verify_app_params_get_global_num_uint:
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:291
    // value, exists = op.AppParamsGet.app_global_num_uint(a)
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:292
    // value_index, exists_index = op.AppParamsGet.app_global_num_uint(_get_1st_ref_index())
    app_params_get AppGlobalNumUint
    // tests/artifacts/StateOps/contract.py:293
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:294
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:289
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_global_num_byte_slice[routing]() -> void:
verify_app_params_get_global_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:299
    // value, exists = op.AppParamsGet.app_global_num_byte_slice(a)
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:300
    // value_index, exists_index = op.AppParamsGet.app_global_num_byte_slice(_get_1st_ref_index())
    app_params_get AppGlobalNumByteSlice
    // tests/artifacts/StateOps/contract.py:301
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:302
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:297
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_uint[routing]() -> void:
verify_app_params_get_local_num_uint:
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:307
    // value, exists = op.AppParamsGet.app_local_num_uint(a)
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:308
    // value_index, exists_index = op.AppParamsGet.app_local_num_uint(_get_1st_ref_index())
    app_params_get AppLocalNumUint
    // tests/artifacts/StateOps/contract.py:309
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:310
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:305
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_local_num_byte_slice[routing]() -> void:
verify_app_params_get_local_num_byte_slice:
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:315
    // value, exists = op.AppParamsGet.app_local_num_byte_slice(a)
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:316
    // value_index, exists_index = op.AppParamsGet.app_local_num_byte_slice(_get_1st_ref_index())
    app_params_get AppLocalNumByteSlice
    // tests/artifacts/StateOps/contract.py:317
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:318
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:313
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_extra_program_pages[routing]() -> void:
verify_app_params_get_extra_program_pages:
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:323
    // value, exists = op.AppParamsGet.app_extra_program_pages(a)
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:324
    // value_index, exists_index = op.AppParamsGet.app_extra_program_pages(_get_1st_ref_index())
    app_params_get AppExtraProgramPages
    // tests/artifacts/StateOps/contract.py:325
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:326
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:321
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_creator[routing]() -> void:
verify_app_params_get_creator:
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:331
    // value, exists = op.AppParamsGet.app_creator(a)
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:332
    // value_index, exists_index = op.AppParamsGet.app_creator(_get_1st_ref_index())
    app_params_get AppCreator
    // tests/artifacts/StateOps/contract.py:333
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:334
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:329
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAppParamsContract.verify_app_params_get_address[routing]() -> void:
verify_app_params_get_address:
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:339
    // value, exists = op.AppParamsGet.app_address(a)
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:340
    // value_index, exists_index = op.AppParamsGet.app_address(_get_1st_ref_index())
    app_params_get AppAddress
    // tests/artifacts/StateOps/contract.py:341
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:342
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:337
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiABASYBBBUffHUxG0EBJIIJBF57fVIE4p4w7gRYgZCZBMp3tZsEU8DdmwRfAAcDBNd70h8EqUGnRgS9Pp7sNhoAjgkAwACiAIsAdABdAEYALwAZAAOBAEMxGRREMRhENhoBF8AyiAGGKExQsCJDMRkURDEYRDYaARfAMogBWihMULAiQzEZFEQxGEQ2GgEXwDKIAS4WKExQsCJDMRkURDEYRDYaARfAMogBARYoTFCwIkMxGRREMRhENhoBF8AyiADUFihMULAiQzEZFEQxGEQ2GgEXwDKIAKcWKExQsCJDMRkURDEYRDYaARfAMogAehYoTFCwIkMxGRREMRhENhoBF8AyiABNSRUWVwYCTFAoTFCwIkMxGRREMRhENhoBF8AyiAAZSRUWVwYCTFAoTFCwIkMxGUD/HTEYFEQiQ4oBAYv/cgA2GgEXcgBLA08CEkQSRImKAQGL/3IBNhoBF3IBSwNPAhJEEkSJigEBi/9yAjYaARdyAksDTwISRBJEiYoBAYv/cgM2GgEXcgNLA08CEkQSRImKAQGL/3IENhoBF3IESwNPAhJEEkSJigEBi/9yBTYaARdyBUsDTwISRBJEiYoBAYv/cgY2GgEXcgZLA08CEkQSRImKAQGL/3IHNhoBF3IHSwNPAhJEEkSJigEBi/9yCDYaARdyCEsDTwISRBJEiQ==", + "approval": "CiABASYBBBUffHUxG0EATjEZFEQxGESCCQS50TwbBOXDyIkE7k57KgR/ojTLBBn3dDkEksVyqgSunG77BONu1wUEjGaoQjYaAI4JAAkAKwBNAGgAgwCeALkA1ADuADEZFDEYFBBDNhoBF3IANhoBF3IASwNPAhJEEkRJFRZXBgJMUChMULAiQzYaARdyATYaARdyAUsDTwISRBJESRUWVwYCTFAoTFCwIkM2GgEXcgI2GgEXcgJLA08CEkQSRBYoTFCwIkM2GgEXcgM2GgEXcgNLA08CEkQSRBYoTFCwIkM2GgEXcgQ2GgEXcgRLA08CEkQSRBYoTFCwIkM2GgEXcgU2GgEXcgVLA08CEkQSRBYoTFCwIkM2GgEXcgY2GgEXcgZLA08CEkQSRBYoTFCwIkM2GgEXcgc2GgEXcgdLA08CEkQSRChMULAiQzYaARdyCDYaARdyCEsDTwISRBJEKExQsCJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAssetHoldingContract.approval.teal b/tests/artifacts/StateOps/data/StateAssetHoldingContract.approval.teal index de5092f..694f29d 100644 --- a/tests/artifacts/StateOps/data/StateAssetHoldingContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAssetHoldingContract.approval.teal @@ -3,120 +3,72 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 0 bytecblock 0x151f7c75 // tests/artifacts/StateOps/contract.py:162 // class StateAssetHoldingContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@7 - pushbytess 0x68301476 0x784c64eb // method "verify_asset_holding_get(account,asset)uint64", method "verify_asset_frozen_get(account,asset)bool" + bz main___algopy_default_create@9 + txn OnCompletion + ! + assert // OnCompletion must be NoOp + txn ApplicationID + assert + pushbytess 0x8f5235b4 0xde7a39f6 // method "verify_asset_holding_get(address,uint64)uint64", method "verify_asset_frozen_get(address,uint64)bool" txna ApplicationArgs 0 - match main_verify_asset_holding_get_route@3 main_verify_asset_frozen_get_route@4 + match verify_asset_holding_get verify_asset_frozen_get + err -main_after_if_else@11: - // tests/artifacts/StateOps/contract.py:162 - // class StateAssetHoldingContract(ARC4Contract): - intc_1 // 0 - return - -main_verify_asset_frozen_get_route@4: - // tests/artifacts/StateOps/contract.py:168 - // @arc4.abimethod() +main___algopy_default_create@9: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:162 - // class StateAssetHoldingContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Accounts - txna ApplicationArgs 2 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:168 - // @arc4.abimethod() - callsub verify_asset_frozen_get - pushbytes 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + ! + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_asset_holding_get_route@3: + +// tests.artifacts.StateOps.contract.StateAssetHoldingContract.verify_asset_holding_get[routing]() -> void: +verify_asset_holding_get: // tests/artifacts/StateOps/contract.py:163 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:162 - // class StateAssetHoldingContract(ARC4Contract): txna ApplicationArgs 1 - btoi - txnas Accounts txna ApplicationArgs 2 btoi - txnas Assets + // tests/artifacts/StateOps/contract.py:165 + // balance, _val = op.AssetHoldingGet.asset_balance(a, b) + asset_holding_get AssetBalance + pop // tests/artifacts/StateOps/contract.py:163 // @arc4.abimethod() - callsub verify_asset_holding_get itob bytec_0 // 0x151f7c75 swap concat log - intc_0 // 1 - return - -main_bare_routing@7: - // tests/artifacts/StateOps/contract.py:162 - // class StateAssetHoldingContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@11 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 + pushint 1 // 1 return -// tests.artifacts.StateOps.contract.StateAssetHoldingContract.verify_asset_holding_get(a: bytes, b: uint64) -> uint64: -verify_asset_holding_get: - // tests/artifacts/StateOps/contract.py:163-164 - // @arc4.abimethod() - // def verify_asset_holding_get(self, a: Account, b: Asset) -> UInt64: - proto 2 1 - // tests/artifacts/StateOps/contract.py:165 - // balance, _val = op.AssetHoldingGet.asset_balance(a, b) - frame_dig -2 - frame_dig -1 - asset_holding_get AssetBalance - pop - // tests/artifacts/StateOps/contract.py:166 - // return balance - retsub - - -// tests.artifacts.StateOps.contract.StateAssetHoldingContract.verify_asset_frozen_get(a: bytes, b: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAssetHoldingContract.verify_asset_frozen_get[routing]() -> void: verify_asset_frozen_get: - // tests/artifacts/StateOps/contract.py:168-169 + // tests/artifacts/StateOps/contract.py:168 // @arc4.abimethod() - // def verify_asset_frozen_get(self, a: Account, b: Asset) -> bool: - proto 2 1 + txna ApplicationArgs 1 + txna ApplicationArgs 2 + btoi // tests/artifacts/StateOps/contract.py:170 // frozen, _val = op.AssetHoldingGet.asset_frozen(a, b) - frame_dig -2 - frame_dig -1 asset_holding_get AssetFrozen pop - // tests/artifacts/StateOps/contract.py:171 - // return frozen - retsub + // tests/artifacts/StateOps/contract.py:168 + // @arc4.abimethod() + pushbytes 0x00 + pushint 0 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + pushint 1 // 1 + return diff --git a/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc32.json b/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc32.json index 26daec7..aaf8f15 100644 --- a/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc32.json @@ -1,18 +1,18 @@ { "hints": { - "verify_asset_holding_get(account,asset)uint64": { + "verify_asset_holding_get(address,uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_asset_frozen_get(account,asset)bool": { + "verify_asset_frozen_get(address,uint64)bool": { "call_config": { "no_op": "CALL" } } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDAKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDcKICAgIHB1c2hieXRlc3MgMHg2ODMwMTQ3NiAweDc4NGM2NGViIC8vIG1ldGhvZCAidmVyaWZ5X2Fzc2V0X2hvbGRpbmdfZ2V0KGFjY291bnQsYXNzZXQpdWludDY0IiwgbWV0aG9kICJ2ZXJpZnlfYXNzZXRfZnJvemVuX2dldChhY2NvdW50LGFzc2V0KWJvb2wiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3ZlcmlmeV9hc3NldF9ob2xkaW5nX2dldF9yb3V0ZUAzIG1haW5fdmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXRfcm91dGVANAoKbWFpbl9hZnRlcl9pZl9lbHNlQDExOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgaW50Y18xIC8vIDAKICAgIHJldHVybgoKbWFpbl92ZXJpZnlfYXNzZXRfZnJvemVuX2dldF9yb3V0ZUA0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2OAogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQogICAgYnRvaQogICAgdHhuYXMgQWNjb3VudHMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIGJ0b2kKICAgIHR4bmFzIEFzc2V0cwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2OAogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGNhbGxzdWIgdmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXQKICAgIHB1c2hieXRlcyAweDAwCiAgICBpbnRjXzEgLy8gMAogICAgdW5jb3ZlciAyCiAgICBzZXRiaXQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCm1haW5fdmVyaWZ5X2Fzc2V0X2hvbGRpbmdfZ2V0X3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBpcyBub3QgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYyCiAgICAvLyBjbGFzcyBTdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBidG9pCiAgICB0eG5hcyBBY2NvdW50cwogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgogICAgYnRvaQogICAgdHhuYXMgQXNzZXRzCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgY2FsbHN1YiB2ZXJpZnlfYXNzZXRfaG9sZGluZ19nZXQKICAgIGl0b2IKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCm1haW5fYmFyZV9yb3V0aW5nQDc6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYyCiAgICAvLyBjbGFzcyBTdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDExCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0LnZlcmlmeV9hc3NldF9ob2xkaW5nX2dldChhOiBieXRlcywgYjogdWludDY0KSAtPiB1aW50NjQ6CnZlcmlmeV9hc3NldF9ob2xkaW5nX2dldDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNjMtMTY0CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgLy8gZGVmIHZlcmlmeV9hc3NldF9ob2xkaW5nX2dldChzZWxmLCBhOiBBY2NvdW50LCBiOiBBc3NldCkgLT4gVUludDY0OgogICAgcHJvdG8gMiAxCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTY1CiAgICAvLyBiYWxhbmNlLCBfdmFsID0gb3AuQXNzZXRIb2xkaW5nR2V0LmFzc2V0X2JhbGFuY2UoYSwgYikKICAgIGZyYW1lX2RpZyAtMgogICAgZnJhbWVfZGlnIC0xCiAgICBhc3NldF9ob2xkaW5nX2dldCBBc3NldEJhbGFuY2UKICAgIHBvcAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2NgogICAgLy8gcmV0dXJuIGJhbGFuY2UKICAgIHJldHN1YgoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0LnZlcmlmeV9hc3NldF9mcm96ZW5fZ2V0KGE6IGJ5dGVzLCBiOiB1aW50NjQpIC0+IHVpbnQ2NDoKdmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTY4LTE2OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIC8vIGRlZiB2ZXJpZnlfYXNzZXRfZnJvemVuX2dldChzZWxmLCBhOiBBY2NvdW50LCBiOiBBc3NldCkgLT4gYm9vbDoKICAgIHByb3RvIDIgMQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE3MAogICAgLy8gZnJvemVuLCBfdmFsID0gb3AuQXNzZXRIb2xkaW5nR2V0LmFzc2V0X2Zyb3plbihhLCBiKQogICAgZnJhbWVfZGlnIC0yCiAgICBmcmFtZV9kaWcgLTEKICAgIGFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0RnJvemVuCiAgICBwb3AKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNzEKICAgIC8vIHJldHVybiBmcm96ZW4KICAgIHJldHN1Ygo=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVAOQogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQKICAgIHB1c2hieXRlc3MgMHg4ZjUyMzViNCAweGRlN2EzOWY2IC8vIG1ldGhvZCAidmVyaWZ5X2Fzc2V0X2hvbGRpbmdfZ2V0KGFkZHJlc3MsdWludDY0KXVpbnQ2NCIsIG1ldGhvZCAidmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXQoYWRkcmVzcyx1aW50NjQpYm9vbCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIHZlcmlmeV9hc3NldF9ob2xkaW5nX2dldCB2ZXJpZnlfYXNzZXRfZnJvemVuX2dldAogICAgZXJyCgptYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgJiYKICAgIHJldHVybiAvLyBvbiBlcnJvcjogT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcCAmJiBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdC52ZXJpZnlfYXNzZXRfaG9sZGluZ19nZXRbcm91dGluZ10oKSAtPiB2b2lkOgp2ZXJpZnlfYXNzZXRfaG9sZGluZ19nZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgogICAgYnRvaQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2NQogICAgLy8gYmFsYW5jZSwgX3ZhbCA9IG9wLkFzc2V0SG9sZGluZ0dldC5hc3NldF9iYWxhbmNlKGEsIGIpCiAgICBhc3NldF9ob2xkaW5nX2dldCBBc3NldEJhbGFuY2UKICAgIHBvcAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MwogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGl0b2IKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdC52ZXJpZnlfYXNzZXRfZnJvemVuX2dldFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9hc3NldF9mcm96ZW5fZ2V0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2OAogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIGJ0b2kKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNzAKICAgIC8vIGZyb3plbiwgX3ZhbCA9IG9wLkFzc2V0SG9sZGluZ0dldC5hc3NldF9mcm96ZW4oYSwgYikKICAgIGFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0RnJvemVuCiAgICBwb3AKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNjgKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICBwdXNoYnl0ZXMgMHgwMAogICAgcHVzaGludCAwIC8vIDAKICAgIHVuY292ZXIgMgogICAgc2V0Yml0CiAgICBieXRlY18wIC8vIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -42,11 +42,11 @@ "name": "verify_asset_holding_get", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "asset", + "type": "uint64", "name": "b" } ], @@ -59,11 +59,11 @@ "name": "verify_asset_frozen_get", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "asset", + "type": "uint64", "name": "b" } ], diff --git a/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc56.json b/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc56.json index e58901a..e2a8754 100644 --- a/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAssetHoldingContract.arc56.json @@ -6,11 +6,11 @@ "name": "verify_asset_holding_get", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "asset", + "type": "uint64", "name": "b" } ], @@ -31,11 +31,11 @@ "name": "verify_asset_frozen_get", "args": [ { - "type": "account", + "type": "address", "name": "a" }, { - "type": "asset", + "type": "uint64", "name": "b" } ], @@ -91,23 +91,15 @@ "sourceInfo": [ { "pc": [ - 43, - 78 + 16 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 112 + 49 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 46, - 81 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" } ], "pcOffsetMethod": "none" @@ -118,18 +110,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGludGNibG9jayAxIDAKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fYmFyZV9yb3V0aW5nQDcKICAgIHB1c2hieXRlc3MgMHg2ODMwMTQ3NiAweDc4NGM2NGViIC8vIG1ldGhvZCAidmVyaWZ5X2Fzc2V0X2hvbGRpbmdfZ2V0KGFjY291bnQsYXNzZXQpdWludDY0IiwgbWV0aG9kICJ2ZXJpZnlfYXNzZXRfZnJvemVuX2dldChhY2NvdW50LGFzc2V0KWJvb2wiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3ZlcmlmeV9hc3NldF9ob2xkaW5nX2dldF9yb3V0ZUAzIG1haW5fdmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXRfcm91dGVANAoKbWFpbl9hZnRlcl9pZl9lbHNlQDExOgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgaW50Y18xIC8vIDAKICAgIHJldHVybgoKbWFpbl92ZXJpZnlfYXNzZXRfZnJvemVuX2dldF9yb3V0ZUA0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2OAogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQogICAgYnRvaQogICAgdHhuYXMgQWNjb3VudHMKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIGJ0b2kKICAgIHR4bmFzIEFzc2V0cwogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2OAogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGNhbGxzdWIgdmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXQKICAgIHB1c2hieXRlcyAweDAwCiAgICBpbnRjXzEgLy8gMAogICAgdW5jb3ZlciAyCiAgICBzZXRiaXQKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCm1haW5fdmVyaWZ5X2Fzc2V0X2hvbGRpbmdfZ2V0X3JvdXRlQDM6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBpcyBub3QgTm9PcAogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgIGFzc2VydCAvLyBjYW4gb25seSBjYWxsIHdoZW4gbm90IGNyZWF0aW5nCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYyCiAgICAvLyBjbGFzcyBTdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAxCiAgICBidG9pCiAgICB0eG5hcyBBY2NvdW50cwogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgogICAgYnRvaQogICAgdHhuYXMgQXNzZXRzCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgY2FsbHN1YiB2ZXJpZnlfYXNzZXRfaG9sZGluZ19nZXQKICAgIGl0b2IKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIGludGNfMCAvLyAxCiAgICByZXR1cm4KCm1haW5fYmFyZV9yb3V0aW5nQDc6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYyCiAgICAvLyBjbGFzcyBTdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0KEFSQzRDb250cmFjdCk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDExCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgaW50Y18wIC8vIDEKICAgIHJldHVybgoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0LnZlcmlmeV9hc3NldF9ob2xkaW5nX2dldChhOiBieXRlcywgYjogdWludDY0KSAtPiB1aW50NjQ6CnZlcmlmeV9hc3NldF9ob2xkaW5nX2dldDoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNjMtMTY0CiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgLy8gZGVmIHZlcmlmeV9hc3NldF9ob2xkaW5nX2dldChzZWxmLCBhOiBBY2NvdW50LCBiOiBBc3NldCkgLT4gVUludDY0OgogICAgcHJvdG8gMiAxCiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTY1CiAgICAvLyBiYWxhbmNlLCBfdmFsID0gb3AuQXNzZXRIb2xkaW5nR2V0LmFzc2V0X2JhbGFuY2UoYSwgYikKICAgIGZyYW1lX2RpZyAtMgogICAgZnJhbWVfZGlnIC0xCiAgICBhc3NldF9ob2xkaW5nX2dldCBBc3NldEJhbGFuY2UKICAgIHBvcAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2NgogICAgLy8gcmV0dXJuIGJhbGFuY2UKICAgIHJldHN1YgoKCi8vIHRlc3RzLmFydGlmYWN0cy5TdGF0ZU9wcy5jb250cmFjdC5TdGF0ZUFzc2V0SG9sZGluZ0NvbnRyYWN0LnZlcmlmeV9hc3NldF9mcm96ZW5fZ2V0KGE6IGJ5dGVzLCBiOiB1aW50NjQpIC0+IHVpbnQ2NDoKdmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTY4LTE2OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIC8vIGRlZiB2ZXJpZnlfYXNzZXRfZnJvemVuX2dldChzZWxmLCBhOiBBY2NvdW50LCBiOiBBc3NldCkgLT4gYm9vbDoKICAgIHByb3RvIDIgMQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE3MAogICAgLy8gZnJvemVuLCBfdmFsID0gb3AuQXNzZXRIb2xkaW5nR2V0LmFzc2V0X2Zyb3plbihhLCBiKQogICAgZnJhbWVfZGlnIC0yCiAgICBmcmFtZV9kaWcgLTEKICAgIGFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0RnJvemVuCiAgICBwb3AKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNzEKICAgIC8vIHJldHVybiBmcm96ZW4KICAgIHJldHN1Ygo=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIGJ5dGVjYmxvY2sgMHgxNTFmN2M3NQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MgogICAgLy8gY2xhc3MgU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdChBUkM0Q29udHJhY3QpOgogICAgdHhuIE51bUFwcEFyZ3MKICAgIGJ6IG1haW5fX19hbGdvcHlfZGVmYXVsdF9jcmVhdGVAOQogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQKICAgIHB1c2hieXRlc3MgMHg4ZjUyMzViNCAweGRlN2EzOWY2IC8vIG1ldGhvZCAidmVyaWZ5X2Fzc2V0X2hvbGRpbmdfZ2V0KGFkZHJlc3MsdWludDY0KXVpbnQ2NCIsIG1ldGhvZCAidmVyaWZ5X2Fzc2V0X2Zyb3plbl9nZXQoYWRkcmVzcyx1aW50NjQpYm9vbCIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIHZlcmlmeV9hc3NldF9ob2xkaW5nX2dldCB2ZXJpZnlfYXNzZXRfZnJvemVuX2dldAogICAgZXJyCgptYWluX19fYWxnb3B5X2RlZmF1bHRfY3JlYXRlQDk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICAhCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgJiYKICAgIHJldHVybiAvLyBvbiBlcnJvcjogT25Db21wbGV0aW9uIG11c3QgYmUgTm9PcCAmJiBjYW4gb25seSBjYWxsIHdoZW4gY3JlYXRpbmcKCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdC52ZXJpZnlfYXNzZXRfaG9sZGluZ19nZXRbcm91dGluZ10oKSAtPiB2b2lkOgp2ZXJpZnlfYXNzZXRfaG9sZGluZ19nZXQ6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvU3RhdGVPcHMvY29udHJhY3QucHk6MTYzCiAgICAvLyBAYXJjNC5hYmltZXRob2QoKQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQogICAgdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgogICAgYnRvaQogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2NQogICAgLy8gYmFsYW5jZSwgX3ZhbCA9IG9wLkFzc2V0SG9sZGluZ0dldC5hc3NldF9iYWxhbmNlKGEsIGIpCiAgICBhc3NldF9ob2xkaW5nX2dldCBBc3NldEJhbGFuY2UKICAgIHBvcAogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2MwogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIGl0b2IKICAgIGJ5dGVjXzAgLy8gMHgxNTFmN2M3NQogICAgc3dhcAogICAgY29uY2F0CiAgICBsb2cKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4KCgovLyB0ZXN0cy5hcnRpZmFjdHMuU3RhdGVPcHMuY29udHJhY3QuU3RhdGVBc3NldEhvbGRpbmdDb250cmFjdC52ZXJpZnlfYXNzZXRfZnJvemVuX2dldFtyb3V0aW5nXSgpIC0+IHZvaWQ6CnZlcmlmeV9hc3NldF9mcm96ZW5fZ2V0OgogICAgLy8gdGVzdHMvYXJ0aWZhY3RzL1N0YXRlT3BzL2NvbnRyYWN0LnB5OjE2OAogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDEKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDIKICAgIGJ0b2kKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNzAKICAgIC8vIGZyb3plbiwgX3ZhbCA9IG9wLkFzc2V0SG9sZGluZ0dldC5hc3NldF9mcm96ZW4oYSwgYikKICAgIGFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0RnJvemVuCiAgICBwb3AKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9TdGF0ZU9wcy9jb250cmFjdC5weToxNjgKICAgIC8vIEBhcmM0LmFiaW1ldGhvZCgpCiAgICBwdXNoYnl0ZXMgMHgwMAogICAgcHVzaGludCAwIC8vIDAKICAgIHVuY292ZXIgMgogICAgc2V0Yml0CiAgICBieXRlY18wIC8vIDB4MTUxZjdjNzUKICAgIHN3YXAKICAgIGNvbmNhdAogICAgbG9nCiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiACAQAmAQQVH3x1MRtBAFeCAgRoMBR2BHhMZOs2GgCOAgAlAAIjQzEZFEQxGEQ2GgEXwBw2GgIXwDCIAECAAQAjTwJUKExQsCJDMRkURDEYRDYaARfAHDYaAhfAMIgAEhYoTFCwIkMxGUD/uTEYFEQiQ4oCAYv+i/9wAEiJigIBi/6L/3ABSIk=", + "approval": "CiYBBBUffHUxG0EAHTEZFEQxGESCAgSPUjW0BN56OfY2GgCOAgAJABsAMRkUMRgUEEM2GgE2GgIXcABIFihMULCBAUM2GgE2GgIXcAFIgAEAgQBPAlQoTFCwgQFD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/StateOps/data/StateAssetParamsContract.approval.teal b/tests/artifacts/StateOps/data/StateAssetParamsContract.approval.teal index 227b140..18f563b 100644 --- a/tests/artifacts/StateOps/data/StateAssetParamsContract.approval.teal +++ b/tests/artifacts/StateOps/data/StateAssetParamsContract.approval.teal @@ -3,349 +3,39 @@ // algopy.arc4.ARC4Contract.approval_program() -> uint64: main: - intcblock 1 0 + intcblock 1 bytecblock 0x151f7c75 // tests/artifacts/StateOps/contract.py:174 // class StateAssetParamsContract(ARC4Contract): txn NumAppArgs - bz main_bare_routing@17 - pushbytess 0xad719a6f 0x1d603013 0x9fb731cd 0x0f5a4911 0xf5b370c6 0xc7d6af74 0x6b71a263 0x3040ebc8 0x1d07e844 0x3e40cb50 0x340c786b 0xe38a9815 // method "verify_asset_params_get_total(asset)uint64", method "verify_asset_params_get_decimals(asset)uint64", method "verify_asset_params_get_default_frozen(asset)bool", method "verify_asset_params_get_unit_name(asset)byte[]", method "verify_asset_params_get_name(asset)byte[]", method "verify_asset_params_get_url(asset)byte[]", method "verify_asset_params_get_metadata_hash(asset)byte[]", method "verify_asset_params_get_manager(asset)address", method "verify_asset_params_get_reserve(asset)address", method "verify_asset_params_get_freeze(asset)address", method "verify_asset_params_get_clawback(asset)address", method "verify_asset_params_get_creator(asset)address" - txna ApplicationArgs 0 - match main_verify_asset_params_get_total_route@3 main_verify_asset_params_get_decimals_route@4 main_verify_asset_params_get_default_frozen_route@5 main_verify_asset_params_get_unit_name_route@6 main_verify_asset_params_get_name_route@7 main_verify_asset_params_get_url_route@8 main_verify_asset_params_get_metadata_hash_route@9 main_verify_asset_params_get_manager_route@10 main_verify_asset_params_get_reserve_route@11 main_verify_asset_params_get_freeze_route@12 main_verify_asset_params_get_clawback_route@13 main_verify_asset_params_get_creator_route@14 - -main_after_if_else@21: - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - intc_1 // 0 - return - -main_verify_asset_params_get_creator_route@14: - // tests/artifacts/StateOps/contract.py:263 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:263 - // @arc4.abimethod() - callsub verify_asset_params_get_creator - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_clawback_route@13: - // tests/artifacts/StateOps/contract.py:255 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:255 - // @arc4.abimethod() - callsub verify_asset_params_get_clawback - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_freeze_route@12: - // tests/artifacts/StateOps/contract.py:247 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:247 - // @arc4.abimethod() - callsub verify_asset_params_get_freeze - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_reserve_route@11: - // tests/artifacts/StateOps/contract.py:239 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:239 - // @arc4.abimethod() - callsub verify_asset_params_get_reserve - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_manager_route@10: - // tests/artifacts/StateOps/contract.py:231 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:231 - // @arc4.abimethod() - callsub verify_asset_params_get_manager - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_metadata_hash_route@9: - // tests/artifacts/StateOps/contract.py:223 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:223 - // @arc4.abimethod() - callsub verify_asset_params_get_metadata_hash - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_url_route@8: - // tests/artifacts/StateOps/contract.py:215 - // @arc4.abimethod() + bz main___algopy_default_create@19 txn OnCompletion ! - assert // OnCompletion is not NoOp + assert // OnCompletion must be NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:215 - // @arc4.abimethod() - callsub verify_asset_params_get_url - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_name_route@7: - // tests/artifacts/StateOps/contract.py:207 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:207 - // @arc4.abimethod() - callsub verify_asset_params_get_name - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + assert + pushbytess 0xf05da7a4 0xc0e9c315 0xd8528273 0xf4468ad9 0x229d12f7 0xdf534f7b 0xe050b5a9 0x8b2a2d58 0xee15c4f7 0x157544ff 0x10492c07 0x5229fa37 // method "verify_asset_params_get_total(uint64)uint64", method "verify_asset_params_get_decimals(uint64)uint64", method "verify_asset_params_get_default_frozen(uint64)bool", method "verify_asset_params_get_unit_name(uint64)byte[]", method "verify_asset_params_get_name(uint64)byte[]", method "verify_asset_params_get_url(uint64)byte[]", method "verify_asset_params_get_metadata_hash(uint64)byte[]", method "verify_asset_params_get_manager(uint64)address", method "verify_asset_params_get_reserve(uint64)address", method "verify_asset_params_get_freeze(uint64)address", method "verify_asset_params_get_clawback(uint64)address", method "verify_asset_params_get_creator(uint64)address" + txna ApplicationArgs 0 + match verify_asset_params_get_total verify_asset_params_get_decimals verify_asset_params_get_default_frozen verify_asset_params_get_unit_name verify_asset_params_get_name verify_asset_params_get_url verify_asset_params_get_metadata_hash verify_asset_params_get_manager verify_asset_params_get_reserve verify_asset_params_get_freeze verify_asset_params_get_clawback verify_asset_params_get_creator + err -main_verify_asset_params_get_unit_name_route@6: - // tests/artifacts/StateOps/contract.py:199 - // @arc4.abimethod() +main___algopy_default_create@19: txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:199 - // @arc4.abimethod() - callsub verify_asset_params_get_unit_name - dup - len - itob - extract 6 2 - swap - concat - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_verify_asset_params_get_default_frozen_route@5: - // tests/artifacts/StateOps/contract.py:191 - // @arc4.abimethod() - txn OnCompletion ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:191 - // @arc4.abimethod() - callsub verify_asset_params_get_default_frozen - pushbytes 0x00 - intc_1 // 0 - uncover 2 - setbit - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating -main_verify_asset_params_get_decimals_route@4: - // tests/artifacts/StateOps/contract.py:183 - // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txna ApplicationArgs 1 - btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:183 - // @arc4.abimethod() - callsub verify_asset_params_get_decimals - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return -main_verify_asset_params_get_total_route@3: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_total[routing]() -> void: +verify_asset_params_get_total: // tests/artifacts/StateOps/contract.py:175 // @arc4.abimethod() - txn OnCompletion - ! - assert // OnCompletion is not NoOp - txn ApplicationID - assert // can only call when not creating - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): txna ApplicationArgs 1 btoi - txnas Assets - // tests/artifacts/StateOps/contract.py:175 - // @arc4.abimethod() - callsub verify_asset_params_get_total - itob - bytec_0 // 0x151f7c75 - swap - concat - log - intc_0 // 1 - return - -main_bare_routing@17: - // tests/artifacts/StateOps/contract.py:174 - // class StateAssetParamsContract(ARC4Contract): - txn OnCompletion - bnz main_after_if_else@21 - txn ApplicationID - ! - assert // can only call when creating - intc_0 // 1 - return - - -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_total(a: uint64) -> uint64: -verify_asset_params_get_total: - // tests/artifacts/StateOps/contract.py:175-176 - // @arc4.abimethod() - // def verify_asset_params_get_total(self, a: Asset) -> UInt64: - proto 1 1 // tests/artifacts/StateOps/contract.py:177 // value, exists = op.AssetParamsGet.asset_total(a) - frame_dig -1 asset_params_get AssetTotal // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -364,20 +54,25 @@ verify_asset_params_get_total: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:181 - // return value - retsub + // tests/artifacts/StateOps/contract.py:175 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_decimals(a: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_decimals[routing]() -> void: verify_asset_params_get_decimals: - // tests/artifacts/StateOps/contract.py:183-184 + // tests/artifacts/StateOps/contract.py:183 // @arc4.abimethod() - // def verify_asset_params_get_decimals(self, a: Asset) -> UInt64: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:185 // value, exists = op.AssetParamsGet.asset_decimals(a) - frame_dig -1 asset_params_get AssetDecimals // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -396,20 +91,25 @@ verify_asset_params_get_decimals: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:189 - // return value - retsub + // tests/artifacts/StateOps/contract.py:183 + // @arc4.abimethod() + itob + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_default_frozen(a: uint64) -> uint64: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_default_frozen[routing]() -> void: verify_asset_params_get_default_frozen: - // tests/artifacts/StateOps/contract.py:191-192 + // tests/artifacts/StateOps/contract.py:191 // @arc4.abimethod() - // def verify_asset_params_get_default_frozen(self, a: Asset) -> bool: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:193 // value, exists = op.AssetParamsGet.asset_default_frozen(a) - frame_dig -1 asset_params_get AssetDefaultFrozen // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -428,20 +128,28 @@ verify_asset_params_get_default_frozen: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:197 - // return value - retsub + // tests/artifacts/StateOps/contract.py:191 + // @arc4.abimethod() + pushbytes 0x00 + pushint 0 // 0 + uncover 2 + setbit + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_unit_name(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_unit_name[routing]() -> void: verify_asset_params_get_unit_name: - // tests/artifacts/StateOps/contract.py:199-200 + // tests/artifacts/StateOps/contract.py:199 // @arc4.abimethod() - // def verify_asset_params_get_unit_name(self, a: Asset) -> Bytes: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:201 // value, exists = op.AssetParamsGet.asset_unit_name(a) - frame_dig -1 asset_params_get AssetUnitName // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -460,20 +168,30 @@ verify_asset_params_get_unit_name: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:205 - // return value - retsub + // tests/artifacts/StateOps/contract.py:199 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_name(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_name[routing]() -> void: verify_asset_params_get_name: - // tests/artifacts/StateOps/contract.py:207-208 + // tests/artifacts/StateOps/contract.py:207 // @arc4.abimethod() - // def verify_asset_params_get_name(self, a: Asset) -> Bytes: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:209 // value, exists = op.AssetParamsGet.asset_name(a) - frame_dig -1 asset_params_get AssetName // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -492,20 +210,30 @@ verify_asset_params_get_name: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:213 - // return value - retsub + // tests/artifacts/StateOps/contract.py:207 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_url(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_url[routing]() -> void: verify_asset_params_get_url: - // tests/artifacts/StateOps/contract.py:215-216 + // tests/artifacts/StateOps/contract.py:215 // @arc4.abimethod() - // def verify_asset_params_get_url(self, a: Asset) -> Bytes: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:217 // value, exists = op.AssetParamsGet.asset_url(a) - frame_dig -1 asset_params_get AssetURL // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -524,20 +252,30 @@ verify_asset_params_get_url: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:221 - // return value - retsub + // tests/artifacts/StateOps/contract.py:215 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_metadata_hash(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_metadata_hash[routing]() -> void: verify_asset_params_get_metadata_hash: - // tests/artifacts/StateOps/contract.py:223-224 + // tests/artifacts/StateOps/contract.py:223 // @arc4.abimethod() - // def verify_asset_params_get_metadata_hash(self, a: Asset) -> Bytes: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:225 // value, exists = op.AssetParamsGet.asset_metadata_hash(a) - frame_dig -1 asset_params_get AssetMetadataHash // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -556,20 +294,30 @@ verify_asset_params_get_metadata_hash: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:229 - // return value - retsub + // tests/artifacts/StateOps/contract.py:223 + // @arc4.abimethod() + dup + len + itob + extract 6 2 + swap + concat + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_manager(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_manager[routing]() -> void: verify_asset_params_get_manager: - // tests/artifacts/StateOps/contract.py:231-232 + // tests/artifacts/StateOps/contract.py:231 // @arc4.abimethod() - // def verify_asset_params_get_manager(self, a: Asset) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:233 // value, exists = op.AssetParamsGet.asset_manager(a) - frame_dig -1 asset_params_get AssetManager // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -588,20 +336,24 @@ verify_asset_params_get_manager: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:237 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:231 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_reserve(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_reserve[routing]() -> void: verify_asset_params_get_reserve: - // tests/artifacts/StateOps/contract.py:239-240 + // tests/artifacts/StateOps/contract.py:239 // @arc4.abimethod() - // def verify_asset_params_get_reserve(self, a: Asset) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:241 // value, exists = op.AssetParamsGet.asset_reserve(a) - frame_dig -1 asset_params_get AssetReserve // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -620,20 +372,24 @@ verify_asset_params_get_reserve: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:245 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:239 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_freeze(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_freeze[routing]() -> void: verify_asset_params_get_freeze: - // tests/artifacts/StateOps/contract.py:247-248 + // tests/artifacts/StateOps/contract.py:247 // @arc4.abimethod() - // def verify_asset_params_get_freeze(self, a: Asset) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:249 // value, exists = op.AssetParamsGet.asset_freeze(a) - frame_dig -1 asset_params_get AssetFreeze // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -652,20 +408,24 @@ verify_asset_params_get_freeze: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:253 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:247 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_clawback(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_clawback[routing]() -> void: verify_asset_params_get_clawback: - // tests/artifacts/StateOps/contract.py:255-256 + // tests/artifacts/StateOps/contract.py:255 // @arc4.abimethod() - // def verify_asset_params_get_clawback(self, a: Asset) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:257 // value, exists = op.AssetParamsGet.asset_clawback(a) - frame_dig -1 asset_params_get AssetClawback // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -684,20 +444,24 @@ verify_asset_params_get_clawback: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:261 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:255 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return -// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_creator(a: uint64) -> bytes: +// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_creator[routing]() -> void: verify_asset_params_get_creator: - // tests/artifacts/StateOps/contract.py:263-264 + // tests/artifacts/StateOps/contract.py:263 // @arc4.abimethod() - // def verify_asset_params_get_creator(self, a: Asset) -> arc4.Address: - proto 1 1 + txna ApplicationArgs 1 + btoi // tests/artifacts/StateOps/contract.py:265 // value, exists = op.AssetParamsGet.asset_creator(a) - frame_dig -1 asset_params_get AssetCreator // tests/artifacts/StateOps/contract.py:21 // return op.btoi(Txn.application_args(1)) @@ -716,6 +480,11 @@ verify_asset_params_get_creator: // assert exists == exists_index, "expected exists by index to match" == assert // expected exists by index to match - // tests/artifacts/StateOps/contract.py:269 - // return arc4.Address(value) - retsub + // tests/artifacts/StateOps/contract.py:263 + // @arc4.abimethod() + bytec_0 // 0x151f7c75 + swap + concat + log + intc_0 // 1 + return diff --git a/tests/artifacts/StateOps/data/StateAssetParamsContract.arc32.json b/tests/artifacts/StateOps/data/StateAssetParamsContract.arc32.json index 446614a..db14c36 100644 --- a/tests/artifacts/StateOps/data/StateAssetParamsContract.arc32.json +++ b/tests/artifacts/StateOps/data/StateAssetParamsContract.arc32.json @@ -1,68 +1,68 @@ { "hints": { - "verify_asset_params_get_total(asset)uint64": { + "verify_asset_params_get_total(uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_decimals(asset)uint64": { + "verify_asset_params_get_decimals(uint64)uint64": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_default_frozen(asset)bool": { + "verify_asset_params_get_default_frozen(uint64)bool": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_unit_name(asset)byte[]": { + "verify_asset_params_get_unit_name(uint64)byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_name(asset)byte[]": { + "verify_asset_params_get_name(uint64)byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_url(asset)byte[]": { + "verify_asset_params_get_url(uint64)byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_metadata_hash(asset)byte[]": { + "verify_asset_params_get_metadata_hash(uint64)byte[]": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_manager(asset)address": { + "verify_asset_params_get_manager(uint64)address": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_reserve(asset)address": { + "verify_asset_params_get_reserve(uint64)address": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_freeze(asset)address": { + "verify_asset_params_get_freeze(uint64)address": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_clawback(asset)address": { + "verify_asset_params_get_clawback(uint64)address": { "call_config": { "no_op": "CALL" } }, - "verify_asset_params_get_creator(asset)address": { + "verify_asset_params_get_creator(uint64)address": { "call_config": { "no_op": "CALL" } } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@17
    pushbytess 0xad719a6f 0x1d603013 0x9fb731cd 0x0f5a4911 0xf5b370c6 0xc7d6af74 0x6b71a263 0x3040ebc8 0x1d07e844 0x3e40cb50 0x340c786b 0xe38a9815 // method "verify_asset_params_get_total(asset)uint64", method "verify_asset_params_get_decimals(asset)uint64", method "verify_asset_params_get_default_frozen(asset)bool", method "verify_asset_params_get_unit_name(asset)byte[]", method "verify_asset_params_get_name(asset)byte[]", method "verify_asset_params_get_url(asset)byte[]", method "verify_asset_params_get_metadata_hash(asset)byte[]", method "verify_asset_params_get_manager(asset)address", method "verify_asset_params_get_reserve(asset)address", method "verify_asset_params_get_freeze(asset)address", method "verify_asset_params_get_clawback(asset)address", method "verify_asset_params_get_creator(asset)address"
    txna ApplicationArgs 0
    match main_verify_asset_params_get_total_route@3 main_verify_asset_params_get_decimals_route@4 main_verify_asset_params_get_default_frozen_route@5 main_verify_asset_params_get_unit_name_route@6 main_verify_asset_params_get_name_route@7 main_verify_asset_params_get_url_route@8 main_verify_asset_params_get_metadata_hash_route@9 main_verify_asset_params_get_manager_route@10 main_verify_asset_params_get_reserve_route@11 main_verify_asset_params_get_freeze_route@12 main_verify_asset_params_get_clawback_route@13 main_verify_asset_params_get_creator_route@14

main_after_if_else@21:
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_asset_params_get_creator_route@14:
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    callsub verify_asset_params_get_creator
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_clawback_route@13:
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    callsub verify_asset_params_get_clawback
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_freeze_route@12:
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    callsub verify_asset_params_get_freeze
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_reserve_route@11:
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    callsub verify_asset_params_get_reserve
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_manager_route@10:
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    callsub verify_asset_params_get_manager
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_metadata_hash_route@9:
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    callsub verify_asset_params_get_metadata_hash
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_url_route@8:
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    callsub verify_asset_params_get_url
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_name_route@7:
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    callsub verify_asset_params_get_name
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_unit_name_route@6:
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    callsub verify_asset_params_get_unit_name
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_default_frozen_route@5:
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    callsub verify_asset_params_get_default_frozen
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_decimals_route@4:
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    callsub verify_asset_params_get_decimals
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_total_route@3:
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    callsub verify_asset_params_get_total
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@17:
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@21
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_total(a: uint64) -> uint64:
verify_asset_params_get_total:
    // tests/artifacts/StateOps/contract.py:175-176
    // @arc4.abimethod()
    // def verify_asset_params_get_total(self, a: Asset) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:177
    // value, exists = op.AssetParamsGet.asset_total(a)
    frame_dig -1
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:178
    // value_index, exists_index = op.AssetParamsGet.asset_total(_get_1st_ref_index())
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:179
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:180
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:181
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_decimals(a: uint64) -> uint64:
verify_asset_params_get_decimals:
    // tests/artifacts/StateOps/contract.py:183-184
    // @arc4.abimethod()
    // def verify_asset_params_get_decimals(self, a: Asset) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:185
    // value, exists = op.AssetParamsGet.asset_decimals(a)
    frame_dig -1
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:186
    // value_index, exists_index = op.AssetParamsGet.asset_decimals(_get_1st_ref_index())
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:187
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:188
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:189
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_default_frozen(a: uint64) -> uint64:
verify_asset_params_get_default_frozen:
    // tests/artifacts/StateOps/contract.py:191-192
    // @arc4.abimethod()
    // def verify_asset_params_get_default_frozen(self, a: Asset) -> bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:193
    // value, exists = op.AssetParamsGet.asset_default_frozen(a)
    frame_dig -1
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:194
    // value_index, exists_index = op.AssetParamsGet.asset_default_frozen(_get_1st_ref_index())
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:195
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:196
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:197
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_unit_name(a: uint64) -> bytes:
verify_asset_params_get_unit_name:
    // tests/artifacts/StateOps/contract.py:199-200
    // @arc4.abimethod()
    // def verify_asset_params_get_unit_name(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:201
    // value, exists = op.AssetParamsGet.asset_unit_name(a)
    frame_dig -1
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:202
    // value_index, exists_index = op.AssetParamsGet.asset_unit_name(_get_1st_ref_index())
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:203
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:204
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:205
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_name(a: uint64) -> bytes:
verify_asset_params_get_name:
    // tests/artifacts/StateOps/contract.py:207-208
    // @arc4.abimethod()
    // def verify_asset_params_get_name(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:209
    // value, exists = op.AssetParamsGet.asset_name(a)
    frame_dig -1
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:210
    // value_index, exists_index = op.AssetParamsGet.asset_name(_get_1st_ref_index())
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:211
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:212
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:213
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_url(a: uint64) -> bytes:
verify_asset_params_get_url:
    // tests/artifacts/StateOps/contract.py:215-216
    // @arc4.abimethod()
    // def verify_asset_params_get_url(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:217
    // value, exists = op.AssetParamsGet.asset_url(a)
    frame_dig -1
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:218
    // value_index, exists_index = op.AssetParamsGet.asset_url(_get_1st_ref_index())
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:219
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:220
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:221
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_metadata_hash(a: uint64) -> bytes:
verify_asset_params_get_metadata_hash:
    // tests/artifacts/StateOps/contract.py:223-224
    // @arc4.abimethod()
    // def verify_asset_params_get_metadata_hash(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:225
    // value, exists = op.AssetParamsGet.asset_metadata_hash(a)
    frame_dig -1
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:226
    // value_index, exists_index = op.AssetParamsGet.asset_metadata_hash(_get_1st_ref_index())
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:227
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:228
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:229
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_manager(a: uint64) -> bytes:
verify_asset_params_get_manager:
    // tests/artifacts/StateOps/contract.py:231-232
    // @arc4.abimethod()
    // def verify_asset_params_get_manager(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:233
    // value, exists = op.AssetParamsGet.asset_manager(a)
    frame_dig -1
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:234
    // value_index, exists_index = op.AssetParamsGet.asset_manager(_get_1st_ref_index())
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:235
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:236
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:237
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_reserve(a: uint64) -> bytes:
verify_asset_params_get_reserve:
    // tests/artifacts/StateOps/contract.py:239-240
    // @arc4.abimethod()
    // def verify_asset_params_get_reserve(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:241
    // value, exists = op.AssetParamsGet.asset_reserve(a)
    frame_dig -1
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:242
    // value_index, exists_index = op.AssetParamsGet.asset_reserve(_get_1st_ref_index())
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:243
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:244
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:245
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_freeze(a: uint64) -> bytes:
verify_asset_params_get_freeze:
    // tests/artifacts/StateOps/contract.py:247-248
    // @arc4.abimethod()
    // def verify_asset_params_get_freeze(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:249
    // value, exists = op.AssetParamsGet.asset_freeze(a)
    frame_dig -1
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:250
    // value_index, exists_index = op.AssetParamsGet.asset_freeze(_get_1st_ref_index())
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:251
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:252
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:253
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_clawback(a: uint64) -> bytes:
verify_asset_params_get_clawback:
    // tests/artifacts/StateOps/contract.py:255-256
    // @arc4.abimethod()
    // def verify_asset_params_get_clawback(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:257
    // value, exists = op.AssetParamsGet.asset_clawback(a)
    frame_dig -1
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:258
    // value_index, exists_index = op.AssetParamsGet.asset_clawback(_get_1st_ref_index())
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:259
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:260
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:261
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_creator(a: uint64) -> bytes:
verify_asset_params_get_creator:
    // tests/artifacts/StateOps/contract.py:263-264
    // @arc4.abimethod()
    // def verify_asset_params_get_creator(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:265
    // value, exists = op.AssetParamsGet.asset_creator(a)
    frame_dig -1
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:266
    // value_index, exists_index = op.AssetParamsGet.asset_creator(_get_1st_ref_index())
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:267
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:268
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:269
    // return arc4.Address(value)
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@19
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xf05da7a4 0xc0e9c315 0xd8528273 0xf4468ad9 0x229d12f7 0xdf534f7b 0xe050b5a9 0x8b2a2d58 0xee15c4f7 0x157544ff 0x10492c07 0x5229fa37 // method "verify_asset_params_get_total(uint64)uint64", method "verify_asset_params_get_decimals(uint64)uint64", method "verify_asset_params_get_default_frozen(uint64)bool", method "verify_asset_params_get_unit_name(uint64)byte[]", method "verify_asset_params_get_name(uint64)byte[]", method "verify_asset_params_get_url(uint64)byte[]", method "verify_asset_params_get_metadata_hash(uint64)byte[]", method "verify_asset_params_get_manager(uint64)address", method "verify_asset_params_get_reserve(uint64)address", method "verify_asset_params_get_freeze(uint64)address", method "verify_asset_params_get_clawback(uint64)address", method "verify_asset_params_get_creator(uint64)address"
    txna ApplicationArgs 0
    match verify_asset_params_get_total verify_asset_params_get_decimals verify_asset_params_get_default_frozen verify_asset_params_get_unit_name verify_asset_params_get_name verify_asset_params_get_url verify_asset_params_get_metadata_hash verify_asset_params_get_manager verify_asset_params_get_reserve verify_asset_params_get_freeze verify_asset_params_get_clawback verify_asset_params_get_creator
    err

main___algopy_default_create@19:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_total[routing]() -> void:
verify_asset_params_get_total:
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:177
    // value, exists = op.AssetParamsGet.asset_total(a)
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:178
    // value_index, exists_index = op.AssetParamsGet.asset_total(_get_1st_ref_index())
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:179
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:180
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_decimals[routing]() -> void:
verify_asset_params_get_decimals:
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:185
    // value, exists = op.AssetParamsGet.asset_decimals(a)
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:186
    // value_index, exists_index = op.AssetParamsGet.asset_decimals(_get_1st_ref_index())
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:187
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:188
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_default_frozen[routing]() -> void:
verify_asset_params_get_default_frozen:
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:193
    // value, exists = op.AssetParamsGet.asset_default_frozen(a)
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:194
    // value_index, exists_index = op.AssetParamsGet.asset_default_frozen(_get_1st_ref_index())
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:195
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:196
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    pushbytes 0x00
    pushint 0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_unit_name[routing]() -> void:
verify_asset_params_get_unit_name:
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:201
    // value, exists = op.AssetParamsGet.asset_unit_name(a)
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:202
    // value_index, exists_index = op.AssetParamsGet.asset_unit_name(_get_1st_ref_index())
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:203
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:204
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_name[routing]() -> void:
verify_asset_params_get_name:
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:209
    // value, exists = op.AssetParamsGet.asset_name(a)
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:210
    // value_index, exists_index = op.AssetParamsGet.asset_name(_get_1st_ref_index())
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:211
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:212
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_url[routing]() -> void:
verify_asset_params_get_url:
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:217
    // value, exists = op.AssetParamsGet.asset_url(a)
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:218
    // value_index, exists_index = op.AssetParamsGet.asset_url(_get_1st_ref_index())
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:219
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:220
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_metadata_hash[routing]() -> void:
verify_asset_params_get_metadata_hash:
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:225
    // value, exists = op.AssetParamsGet.asset_metadata_hash(a)
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:226
    // value_index, exists_index = op.AssetParamsGet.asset_metadata_hash(_get_1st_ref_index())
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:227
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:228
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_manager[routing]() -> void:
verify_asset_params_get_manager:
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:233
    // value, exists = op.AssetParamsGet.asset_manager(a)
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:234
    // value_index, exists_index = op.AssetParamsGet.asset_manager(_get_1st_ref_index())
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:235
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:236
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_reserve[routing]() -> void:
verify_asset_params_get_reserve:
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:241
    // value, exists = op.AssetParamsGet.asset_reserve(a)
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:242
    // value_index, exists_index = op.AssetParamsGet.asset_reserve(_get_1st_ref_index())
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:243
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:244
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_freeze[routing]() -> void:
verify_asset_params_get_freeze:
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:249
    // value, exists = op.AssetParamsGet.asset_freeze(a)
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:250
    // value_index, exists_index = op.AssetParamsGet.asset_freeze(_get_1st_ref_index())
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:251
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:252
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_clawback[routing]() -> void:
verify_asset_params_get_clawback:
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:257
    // value, exists = op.AssetParamsGet.asset_clawback(a)
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:258
    // value_index, exists_index = op.AssetParamsGet.asset_clawback(_get_1st_ref_index())
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:259
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:260
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_creator[routing]() -> void:
verify_asset_params_get_creator:
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:265
    // value, exists = op.AssetParamsGet.asset_creator(a)
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:266
    // value_index, exists_index = op.AssetParamsGet.asset_creator(_get_1st_ref_index())
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:267
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:268
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { @@ -92,7 +92,7 @@ "name": "verify_asset_params_get_total", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -105,7 +105,7 @@ "name": "verify_asset_params_get_decimals", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -118,7 +118,7 @@ "name": "verify_asset_params_get_default_frozen", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -131,7 +131,7 @@ "name": "verify_asset_params_get_unit_name", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -144,7 +144,7 @@ "name": "verify_asset_params_get_name", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -157,7 +157,7 @@ "name": "verify_asset_params_get_url", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -170,7 +170,7 @@ "name": "verify_asset_params_get_metadata_hash", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -183,7 +183,7 @@ "name": "verify_asset_params_get_manager", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -196,7 +196,7 @@ "name": "verify_asset_params_get_reserve", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -209,7 +209,7 @@ "name": "verify_asset_params_get_freeze", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -222,7 +222,7 @@ "name": "verify_asset_params_get_clawback", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -235,7 +235,7 @@ "name": "verify_asset_params_get_creator", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], diff --git a/tests/artifacts/StateOps/data/StateAssetParamsContract.arc56.json b/tests/artifacts/StateOps/data/StateAssetParamsContract.arc56.json index e075a58..59dee83 100644 --- a/tests/artifacts/StateOps/data/StateAssetParamsContract.arc56.json +++ b/tests/artifacts/StateOps/data/StateAssetParamsContract.arc56.json @@ -6,7 +6,7 @@ "name": "verify_asset_params_get_total", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -27,7 +27,7 @@ "name": "verify_asset_params_get_decimals", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -48,7 +48,7 @@ "name": "verify_asset_params_get_default_frozen", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -69,7 +69,7 @@ "name": "verify_asset_params_get_unit_name", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -90,7 +90,7 @@ "name": "verify_asset_params_get_name", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -111,7 +111,7 @@ "name": "verify_asset_params_get_url", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -132,7 +132,7 @@ "name": "verify_asset_params_get_metadata_hash", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -153,7 +153,7 @@ "name": "verify_asset_params_get_manager", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -174,7 +174,7 @@ "name": "verify_asset_params_get_reserve", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -195,7 +195,7 @@ "name": "verify_asset_params_get_freeze", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -216,7 +216,7 @@ "name": "verify_asset_params_get_clawback", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -237,7 +237,7 @@ "name": "verify_asset_params_get_creator", "args": [ { - "type": "asset", + "type": "uint64", "name": "a" } ], @@ -293,75 +293,47 @@ "sourceInfo": [ { "pc": [ - 113, - 135, - 157, - 179, - 201, - 223, - 253, - 283, - 313, - 343, - 372, - 395 + 19 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp" }, { "pc": [ - 423 + 122 ], - "errorMessage": "can only call when creating" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 116, - 138, - 160, - 182, - 204, - 226, - 256, - 286, - 316, - 346, - 375, - 398 - ], - "errorMessage": "can only call when not creating" - }, - { - "pc": [ - 446, - 468, - 490, - 512, - 534, - 556, - 578, - 600, - 622, - 644, - 666, - 688 + 142, + 169, + 196, + 230, + 264, + 298, + 332, + 366, + 392, + 418, + 444, + 470 ], "errorMessage": "expected exists by index to match" }, { "pc": [ - 444, - 466, - 488, - 510, - 532, - 554, - 576, - 598, - 620, - 642, - 664, - 686 + 140, + 167, + 194, + 228, + 262, + 296, + 330, + 364, + 390, + 416, + 442, + 468 ], "errorMessage": "expected value by index to match" } @@ -374,18 +346,18 @@ } }, "source": { - "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1 0
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@17
    pushbytess 0xad719a6f 0x1d603013 0x9fb731cd 0x0f5a4911 0xf5b370c6 0xc7d6af74 0x6b71a263 0x3040ebc8 0x1d07e844 0x3e40cb50 0x340c786b 0xe38a9815 // method "verify_asset_params_get_total(asset)uint64", method "verify_asset_params_get_decimals(asset)uint64", method "verify_asset_params_get_default_frozen(asset)bool", method "verify_asset_params_get_unit_name(asset)byte[]", method "verify_asset_params_get_name(asset)byte[]", method "verify_asset_params_get_url(asset)byte[]", method "verify_asset_params_get_metadata_hash(asset)byte[]", method "verify_asset_params_get_manager(asset)address", method "verify_asset_params_get_reserve(asset)address", method "verify_asset_params_get_freeze(asset)address", method "verify_asset_params_get_clawback(asset)address", method "verify_asset_params_get_creator(asset)address"
    txna ApplicationArgs 0
    match main_verify_asset_params_get_total_route@3 main_verify_asset_params_get_decimals_route@4 main_verify_asset_params_get_default_frozen_route@5 main_verify_asset_params_get_unit_name_route@6 main_verify_asset_params_get_name_route@7 main_verify_asset_params_get_url_route@8 main_verify_asset_params_get_metadata_hash_route@9 main_verify_asset_params_get_manager_route@10 main_verify_asset_params_get_reserve_route@11 main_verify_asset_params_get_freeze_route@12 main_verify_asset_params_get_clawback_route@13 main_verify_asset_params_get_creator_route@14

main_after_if_else@21:
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    intc_1 // 0
    return

main_verify_asset_params_get_creator_route@14:
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    callsub verify_asset_params_get_creator
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_clawback_route@13:
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    callsub verify_asset_params_get_clawback
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_freeze_route@12:
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    callsub verify_asset_params_get_freeze
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_reserve_route@11:
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    callsub verify_asset_params_get_reserve
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_manager_route@10:
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    callsub verify_asset_params_get_manager
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_metadata_hash_route@9:
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    callsub verify_asset_params_get_metadata_hash
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_url_route@8:
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    callsub verify_asset_params_get_url
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_name_route@7:
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    callsub verify_asset_params_get_name
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_unit_name_route@6:
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    callsub verify_asset_params_get_unit_name
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_default_frozen_route@5:
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    callsub verify_asset_params_get_default_frozen
    pushbytes 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_decimals_route@4:
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    callsub verify_asset_params_get_decimals
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_verify_asset_params_get_total_route@3:
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txna ApplicationArgs 1
    btoi
    txnas Assets
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    callsub verify_asset_params_get_total
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return

main_bare_routing@17:
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txn OnCompletion
    bnz main_after_if_else@21
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_total(a: uint64) -> uint64:
verify_asset_params_get_total:
    // tests/artifacts/StateOps/contract.py:175-176
    // @arc4.abimethod()
    // def verify_asset_params_get_total(self, a: Asset) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:177
    // value, exists = op.AssetParamsGet.asset_total(a)
    frame_dig -1
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:178
    // value_index, exists_index = op.AssetParamsGet.asset_total(_get_1st_ref_index())
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:179
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:180
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:181
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_decimals(a: uint64) -> uint64:
verify_asset_params_get_decimals:
    // tests/artifacts/StateOps/contract.py:183-184
    // @arc4.abimethod()
    // def verify_asset_params_get_decimals(self, a: Asset) -> UInt64:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:185
    // value, exists = op.AssetParamsGet.asset_decimals(a)
    frame_dig -1
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:186
    // value_index, exists_index = op.AssetParamsGet.asset_decimals(_get_1st_ref_index())
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:187
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:188
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:189
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_default_frozen(a: uint64) -> uint64:
verify_asset_params_get_default_frozen:
    // tests/artifacts/StateOps/contract.py:191-192
    // @arc4.abimethod()
    // def verify_asset_params_get_default_frozen(self, a: Asset) -> bool:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:193
    // value, exists = op.AssetParamsGet.asset_default_frozen(a)
    frame_dig -1
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:194
    // value_index, exists_index = op.AssetParamsGet.asset_default_frozen(_get_1st_ref_index())
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:195
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:196
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:197
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_unit_name(a: uint64) -> bytes:
verify_asset_params_get_unit_name:
    // tests/artifacts/StateOps/contract.py:199-200
    // @arc4.abimethod()
    // def verify_asset_params_get_unit_name(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:201
    // value, exists = op.AssetParamsGet.asset_unit_name(a)
    frame_dig -1
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:202
    // value_index, exists_index = op.AssetParamsGet.asset_unit_name(_get_1st_ref_index())
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:203
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:204
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:205
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_name(a: uint64) -> bytes:
verify_asset_params_get_name:
    // tests/artifacts/StateOps/contract.py:207-208
    // @arc4.abimethod()
    // def verify_asset_params_get_name(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:209
    // value, exists = op.AssetParamsGet.asset_name(a)
    frame_dig -1
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:210
    // value_index, exists_index = op.AssetParamsGet.asset_name(_get_1st_ref_index())
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:211
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:212
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:213
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_url(a: uint64) -> bytes:
verify_asset_params_get_url:
    // tests/artifacts/StateOps/contract.py:215-216
    // @arc4.abimethod()
    // def verify_asset_params_get_url(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:217
    // value, exists = op.AssetParamsGet.asset_url(a)
    frame_dig -1
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:218
    // value_index, exists_index = op.AssetParamsGet.asset_url(_get_1st_ref_index())
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:219
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:220
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:221
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_metadata_hash(a: uint64) -> bytes:
verify_asset_params_get_metadata_hash:
    // tests/artifacts/StateOps/contract.py:223-224
    // @arc4.abimethod()
    // def verify_asset_params_get_metadata_hash(self, a: Asset) -> Bytes:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:225
    // value, exists = op.AssetParamsGet.asset_metadata_hash(a)
    frame_dig -1
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:226
    // value_index, exists_index = op.AssetParamsGet.asset_metadata_hash(_get_1st_ref_index())
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:227
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:228
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:229
    // return value
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_manager(a: uint64) -> bytes:
verify_asset_params_get_manager:
    // tests/artifacts/StateOps/contract.py:231-232
    // @arc4.abimethod()
    // def verify_asset_params_get_manager(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:233
    // value, exists = op.AssetParamsGet.asset_manager(a)
    frame_dig -1
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:234
    // value_index, exists_index = op.AssetParamsGet.asset_manager(_get_1st_ref_index())
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:235
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:236
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:237
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_reserve(a: uint64) -> bytes:
verify_asset_params_get_reserve:
    // tests/artifacts/StateOps/contract.py:239-240
    // @arc4.abimethod()
    // def verify_asset_params_get_reserve(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:241
    // value, exists = op.AssetParamsGet.asset_reserve(a)
    frame_dig -1
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:242
    // value_index, exists_index = op.AssetParamsGet.asset_reserve(_get_1st_ref_index())
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:243
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:244
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:245
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_freeze(a: uint64) -> bytes:
verify_asset_params_get_freeze:
    // tests/artifacts/StateOps/contract.py:247-248
    // @arc4.abimethod()
    // def verify_asset_params_get_freeze(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:249
    // value, exists = op.AssetParamsGet.asset_freeze(a)
    frame_dig -1
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:250
    // value_index, exists_index = op.AssetParamsGet.asset_freeze(_get_1st_ref_index())
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:251
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:252
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:253
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_clawback(a: uint64) -> bytes:
verify_asset_params_get_clawback:
    // tests/artifacts/StateOps/contract.py:255-256
    // @arc4.abimethod()
    // def verify_asset_params_get_clawback(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:257
    // value, exists = op.AssetParamsGet.asset_clawback(a)
    frame_dig -1
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:258
    // value_index, exists_index = op.AssetParamsGet.asset_clawback(_get_1st_ref_index())
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:259
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:260
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:261
    // return arc4.Address(value)
    retsub


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_creator(a: uint64) -> bytes:
verify_asset_params_get_creator:
    // tests/artifacts/StateOps/contract.py:263-264
    // @arc4.abimethod()
    // def verify_asset_params_get_creator(self, a: Asset) -> arc4.Address:
    proto 1 1
    // tests/artifacts/StateOps/contract.py:265
    // value, exists = op.AssetParamsGet.asset_creator(a)
    frame_dig -1
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:266
    // value_index, exists_index = op.AssetParamsGet.asset_creator(_get_1st_ref_index())
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:267
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:268
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:269
    // return arc4.Address(value)
    retsub
", + "approval": "#pragma version 10
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 1
    bytecblock 0x151f7c75
    // tests/artifacts/StateOps/contract.py:174
    // class StateAssetParamsContract(ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@19
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    assert
    pushbytess 0xf05da7a4 0xc0e9c315 0xd8528273 0xf4468ad9 0x229d12f7 0xdf534f7b 0xe050b5a9 0x8b2a2d58 0xee15c4f7 0x157544ff 0x10492c07 0x5229fa37 // method "verify_asset_params_get_total(uint64)uint64", method "verify_asset_params_get_decimals(uint64)uint64", method "verify_asset_params_get_default_frozen(uint64)bool", method "verify_asset_params_get_unit_name(uint64)byte[]", method "verify_asset_params_get_name(uint64)byte[]", method "verify_asset_params_get_url(uint64)byte[]", method "verify_asset_params_get_metadata_hash(uint64)byte[]", method "verify_asset_params_get_manager(uint64)address", method "verify_asset_params_get_reserve(uint64)address", method "verify_asset_params_get_freeze(uint64)address", method "verify_asset_params_get_clawback(uint64)address", method "verify_asset_params_get_creator(uint64)address"
    txna ApplicationArgs 0
    match verify_asset_params_get_total verify_asset_params_get_decimals verify_asset_params_get_default_frozen verify_asset_params_get_unit_name verify_asset_params_get_name verify_asset_params_get_url verify_asset_params_get_metadata_hash verify_asset_params_get_manager verify_asset_params_get_reserve verify_asset_params_get_freeze verify_asset_params_get_clawback verify_asset_params_get_creator
    err

main___algopy_default_create@19:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return // on error: OnCompletion must be NoOp && can only call when creating


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_total[routing]() -> void:
verify_asset_params_get_total:
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:177
    // value, exists = op.AssetParamsGet.asset_total(a)
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:178
    // value_index, exists_index = op.AssetParamsGet.asset_total(_get_1st_ref_index())
    asset_params_get AssetTotal
    // tests/artifacts/StateOps/contract.py:179
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:180
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:175
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_decimals[routing]() -> void:
verify_asset_params_get_decimals:
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:185
    // value, exists = op.AssetParamsGet.asset_decimals(a)
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:186
    // value_index, exists_index = op.AssetParamsGet.asset_decimals(_get_1st_ref_index())
    asset_params_get AssetDecimals
    // tests/artifacts/StateOps/contract.py:187
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:188
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:183
    // @arc4.abimethod()
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_default_frozen[routing]() -> void:
verify_asset_params_get_default_frozen:
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:193
    // value, exists = op.AssetParamsGet.asset_default_frozen(a)
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:194
    // value_index, exists_index = op.AssetParamsGet.asset_default_frozen(_get_1st_ref_index())
    asset_params_get AssetDefaultFrozen
    // tests/artifacts/StateOps/contract.py:195
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:196
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:191
    // @arc4.abimethod()
    pushbytes 0x00
    pushint 0 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_unit_name[routing]() -> void:
verify_asset_params_get_unit_name:
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:201
    // value, exists = op.AssetParamsGet.asset_unit_name(a)
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:202
    // value_index, exists_index = op.AssetParamsGet.asset_unit_name(_get_1st_ref_index())
    asset_params_get AssetUnitName
    // tests/artifacts/StateOps/contract.py:203
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:204
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:199
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_name[routing]() -> void:
verify_asset_params_get_name:
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:209
    // value, exists = op.AssetParamsGet.asset_name(a)
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:210
    // value_index, exists_index = op.AssetParamsGet.asset_name(_get_1st_ref_index())
    asset_params_get AssetName
    // tests/artifacts/StateOps/contract.py:211
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:212
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:207
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_url[routing]() -> void:
verify_asset_params_get_url:
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:217
    // value, exists = op.AssetParamsGet.asset_url(a)
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:218
    // value_index, exists_index = op.AssetParamsGet.asset_url(_get_1st_ref_index())
    asset_params_get AssetURL
    // tests/artifacts/StateOps/contract.py:219
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:220
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:215
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_metadata_hash[routing]() -> void:
verify_asset_params_get_metadata_hash:
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:225
    // value, exists = op.AssetParamsGet.asset_metadata_hash(a)
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:226
    // value_index, exists_index = op.AssetParamsGet.asset_metadata_hash(_get_1st_ref_index())
    asset_params_get AssetMetadataHash
    // tests/artifacts/StateOps/contract.py:227
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:228
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:223
    // @arc4.abimethod()
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_manager[routing]() -> void:
verify_asset_params_get_manager:
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:233
    // value, exists = op.AssetParamsGet.asset_manager(a)
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:234
    // value_index, exists_index = op.AssetParamsGet.asset_manager(_get_1st_ref_index())
    asset_params_get AssetManager
    // tests/artifacts/StateOps/contract.py:235
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:236
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:231
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_reserve[routing]() -> void:
verify_asset_params_get_reserve:
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:241
    // value, exists = op.AssetParamsGet.asset_reserve(a)
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:242
    // value_index, exists_index = op.AssetParamsGet.asset_reserve(_get_1st_ref_index())
    asset_params_get AssetReserve
    // tests/artifacts/StateOps/contract.py:243
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:244
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:239
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_freeze[routing]() -> void:
verify_asset_params_get_freeze:
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:249
    // value, exists = op.AssetParamsGet.asset_freeze(a)
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:250
    // value_index, exists_index = op.AssetParamsGet.asset_freeze(_get_1st_ref_index())
    asset_params_get AssetFreeze
    // tests/artifacts/StateOps/contract.py:251
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:252
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:247
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_clawback[routing]() -> void:
verify_asset_params_get_clawback:
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:257
    // value, exists = op.AssetParamsGet.asset_clawback(a)
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:258
    // value_index, exists_index = op.AssetParamsGet.asset_clawback(_get_1st_ref_index())
    asset_params_get AssetClawback
    // tests/artifacts/StateOps/contract.py:259
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:260
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:255
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// tests.artifacts.StateOps.contract.StateAssetParamsContract.verify_asset_params_get_creator[routing]() -> void:
verify_asset_params_get_creator:
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:265
    // value, exists = op.AssetParamsGet.asset_creator(a)
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:21
    // return op.btoi(Txn.application_args(1))
    txna ApplicationArgs 1
    btoi
    // tests/artifacts/StateOps/contract.py:266
    // value_index, exists_index = op.AssetParamsGet.asset_creator(_get_1st_ref_index())
    asset_params_get AssetCreator
    // tests/artifacts/StateOps/contract.py:267
    // assert value == value_index, "expected value by index to match"
    dig 3
    uncover 2
    ==
    assert // expected value by index to match
    // tests/artifacts/StateOps/contract.py:268
    // assert exists == exists_index, "expected exists by index to match"
    ==
    assert // expected exists by index to match
    // tests/artifacts/StateOps/contract.py:263
    // @arc4.abimethod()
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CiACAQAmAQQVH3x1MRtBAY6CDAStcZpvBB1gMBMEn7cxzQQPWkkRBPWzcMYEx9avdARrcaJjBDBA68gEHQfoRAQ+QMtQBDQMeGsE44qYFTYaAI4MARwBBQDoAMoArACOAHAAWgBEAC4AGAACI0MxGRREMRhENhoBF8AwiAIeKExQsCJDMRkURDEYRDYaARfAMIgB8ihMULAiQzEZFEQxGEQ2GgEXwDCIAcYoTFCwIkMxGRREMRhENhoBF8AwiAGaKExQsCJDMRkURDEYRDYaARfAMIgBbihMULAiQzEZFEQxGEQ2GgEXwDCIAUJJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXwDCIAQ5JFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXwDCIANpJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXwDCIAKZJFRZXBgJMUChMULAiQzEZFEQxGEQ2GgEXwDCIAHKAAQAjTwJUKExQsCJDMRkURDEYRDYaARfAMIgAPxYoTFCwIkMxGRREMRhENhoBF8AwiAASFihMULAiQzEZQP7IMRgURCJDigEBi/9xADYaARdxAEsDTwISRBJEiYoBAYv/cQE2GgEXcQFLA08CEkQSRImKAQGL/3ECNhoBF3ECSwNPAhJEEkSJigEBi/9xAzYaARdxA0sDTwISRBJEiYoBAYv/cQQ2GgEXcQRLA08CEkQSRImKAQGL/3EFNhoBF3EFSwNPAhJEEkSJigEBi/9xBjYaARdxBksDTwISRBJEiYoBAYv/cQc2GgEXcQdLA08CEkQSRImKAQGL/3EINhoBF3EISwNPAhJEEkSJigEBi/9xCTYaARdxCUsDTwISRBJEiYoBAYv/cQo2GgEXcQpLA08CEkQSRImKAQGL/3ELNhoBF3ELSwNPAhJEEkSJ", + "approval": "CiABASYBBBUffHUxG0EAYzEZFEQxGESCDATwXaekBMDpwxUE2FKCcwT0RorZBCKdEvcE31NPewTgULWpBIsqLVgE7hXE9wQVdUT/BBBJLAcEUin6NzYaAI4MAAkAJAA/AGEAgwClAMcA6QEDAR0BNwFRADEZFDEYFBBDNhoBF3EANhoBF3EASwNPAhJEEkQWKExQsCJDNhoBF3EBNhoBF3EBSwNPAhJEEkQWKExQsCJDNhoBF3ECNhoBF3ECSwNPAhJEEkSAAQCBAE8CVChMULAiQzYaARdxAzYaARdxA0sDTwISRBJESRUWVwYCTFAoTFCwIkM2GgEXcQQ2GgEXcQRLA08CEkQSREkVFlcGAkxQKExQsCJDNhoBF3EFNhoBF3EFSwNPAhJEEkRJFRZXBgJMUChMULAiQzYaARdxBjYaARdxBksDTwISRBJESRUWVwYCTFAoTFCwIkM2GgEXcQc2GgEXcQdLA08CEkQSRChMULAiQzYaARdxCDYaARdxCEsDTwISRBJEKExQsCJDNhoBF3EJNhoBF3EJSwNPAhJEEkQoTFCwIkM2GgEXcQo2GgEXcQpLA08CEkQSRChMULAiQzYaARdxCzYaARdxC0sDTwISRBJEKExQsCJD", "clear": "CoEBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/artifacts/Tuples/data/TuplesContract.approval.teal b/tests/artifacts/Tuples/data/TuplesContract.approval.teal index 5aaa50f..dd3673b 100644 --- a/tests/artifacts/Tuples/data/TuplesContract.approval.teal +++ b/tests/artifacts/Tuples/data/TuplesContract.approval.teal @@ -6,37 +6,29 @@ main: // tests/artifacts/Tuples/contract.py:8 // class TuplesContract(ARC4Contract, avm_version=11): txn NumAppArgs - bz main_bare_routing@6 + bz main___algopy_default_create@5 pushbytes 0x7229d79a // method "test_tuple_with_primitive_type()(uint64,bool)" txna ApplicationArgs 0 match main_test_tuple_with_primitive_type_route@3 - -main_after_if_else@10: - // tests/artifacts/Tuples/contract.py:8 - // class TuplesContract(ARC4Contract, avm_version=11): - pushint 0 // 0 - return + err main_test_tuple_with_primitive_type_route@3: // tests/artifacts/Tuples/contract.py:9 // @arc4.abimethod() txn OnCompletion ! - assert // OnCompletion is not NoOp txn ApplicationID - assert // can only call when not creating + && + assert // OnCompletion must be NoOp && can only call when not creating pushbytes 0x151f7c75000000000000000080 log pushint 1 // 1 return -main_bare_routing@6: - // tests/artifacts/Tuples/contract.py:8 - // class TuplesContract(ARC4Contract, avm_version=11): +main___algopy_default_create@5: txn OnCompletion - bnz main_after_if_else@10 + ! txn ApplicationID ! - assert // can only call when creating - pushint 1 // 1 - return + && + return // on error: OnCompletion must be NoOp && can only call when creating diff --git a/tests/artifacts/Tuples/data/TuplesContract.arc32.json b/tests/artifacts/Tuples/data/TuplesContract.arc32.json index 0636f7a..18fe5b8 100644 --- a/tests/artifacts/Tuples/data/TuplesContract.arc32.json +++ b/tests/artifacts/Tuples/data/TuplesContract.arc32.json @@ -7,7 +7,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OAogICAgLy8gY2xhc3MgVHVwbGVzQ29udHJhY3QoQVJDNENvbnRyYWN0LCBhdm1fdmVyc2lvbj0xMSk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9iYXJlX3JvdXRpbmdANgogICAgcHVzaGJ5dGVzIDB4NzIyOWQ3OWEgLy8gbWV0aG9kICJ0ZXN0X3R1cGxlX3dpdGhfcHJpbWl0aXZlX3R5cGUoKSh1aW50NjQsYm9vbCkiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3Rlc3RfdHVwbGVfd2l0aF9wcmltaXRpdmVfdHlwZV9yb3V0ZUAzCgptYWluX2FmdGVyX2lmX2Vsc2VAMTA6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvVHVwbGVzL2NvbnRyYWN0LnB5OjgKICAgIC8vIGNsYXNzIFR1cGxlc0NvbnRyYWN0KEFSQzRDb250cmFjdCwgYXZtX3ZlcnNpb249MTEpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl90ZXN0X3R1cGxlX3dpdGhfcHJpbWl0aXZlX3R5cGVfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUwMDAwMDAwMDAwMDAwMDAwODAKICAgIGxvZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKbWFpbl9iYXJlX3JvdXRpbmdANjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OAogICAgLy8gY2xhc3MgVHVwbGVzQ29udHJhY3QoQVJDNENvbnRyYWN0LCBhdm1fdmVyc2lvbj0xMSk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDEwCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgo=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OAogICAgLy8gY2xhc3MgVHVwbGVzQ29udHJhY3QoQVJDNENvbnRyYWN0LCBhdm1fdmVyc2lvbj0xMSk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1CiAgICBwdXNoYnl0ZXMgMHg3MjI5ZDc5YSAvLyBtZXRob2QgInRlc3RfdHVwbGVfd2l0aF9wcmltaXRpdmVfdHlwZSgpKHVpbnQ2NCxib29sKSIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIG1haW5fdGVzdF90dXBsZV93aXRoX3ByaW1pdGl2ZV90eXBlX3JvdXRlQDMKICAgIGVycgoKbWFpbl90ZXN0X3R1cGxlX3dpdGhfcHJpbWl0aXZlX3R5cGVfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUwMDAwMDAwMDAwMDAwMDAwODAKICAgIGxvZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1OgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { diff --git a/tests/artifacts/Tuples/data/TuplesContract.arc56.json b/tests/artifacts/Tuples/data/TuplesContract.arc56.json index 911ea3c..8e8b4c5 100644 --- a/tests/artifacts/Tuples/data/TuplesContract.arc56.json +++ b/tests/artifacts/Tuples/data/TuplesContract.arc56.json @@ -57,21 +57,15 @@ "sourceInfo": [ { "pc": [ - 25 + 53 ], - "errorMessage": "OnCompletion is not NoOp" + "errorMessage": "OnCompletion must be NoOp && can only call when creating" }, { "pc": [ - 56 + 26 ], - "errorMessage": "can only call when creating" - }, - { - "pc": [ - 28 - ], - "errorMessage": "can only call when not creating" + "errorMessage": "OnCompletion must be NoOp && can only call when not creating" } ], "pcOffsetMethod": "none" @@ -82,18 +76,18 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OAogICAgLy8gY2xhc3MgVHVwbGVzQ29udHJhY3QoQVJDNENvbnRyYWN0LCBhdm1fdmVyc2lvbj0xMSk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9iYXJlX3JvdXRpbmdANgogICAgcHVzaGJ5dGVzIDB4NzIyOWQ3OWEgLy8gbWV0aG9kICJ0ZXN0X3R1cGxlX3dpdGhfcHJpbWl0aXZlX3R5cGUoKSh1aW50NjQsYm9vbCkiCiAgICB0eG5hIEFwcGxpY2F0aW9uQXJncyAwCiAgICBtYXRjaCBtYWluX3Rlc3RfdHVwbGVfd2l0aF9wcmltaXRpdmVfdHlwZV9yb3V0ZUAzCgptYWluX2FmdGVyX2lmX2Vsc2VAMTA6CiAgICAvLyB0ZXN0cy9hcnRpZmFjdHMvVHVwbGVzL2NvbnRyYWN0LnB5OjgKICAgIC8vIGNsYXNzIFR1cGxlc0NvbnRyYWN0KEFSQzRDb250cmFjdCwgYXZtX3ZlcnNpb249MTEpOgogICAgcHVzaGludCAwIC8vIDAKICAgIHJldHVybgoKbWFpbl90ZXN0X3R1cGxlX3dpdGhfcHJpbWl0aXZlX3R5cGVfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIGFzc2VydCAvLyBPbkNvbXBsZXRpb24gaXMgbm90IE5vT3AKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICBhc3NlcnQgLy8gY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUwMDAwMDAwMDAwMDAwMDAwODAKICAgIGxvZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKbWFpbl9iYXJlX3JvdXRpbmdANjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OAogICAgLy8gY2xhc3MgVHVwbGVzQ29udHJhY3QoQVJDNENvbnRyYWN0LCBhdm1fdmVyc2lvbj0xMSk6CiAgICB0eG4gT25Db21wbGV0aW9uCiAgICBibnogbWFpbl9hZnRlcl9pZl9lbHNlQDEwCiAgICB0eG4gQXBwbGljYXRpb25JRAogICAgIQogICAgYXNzZXJ0IC8vIGNhbiBvbmx5IGNhbGwgd2hlbiBjcmVhdGluZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgo=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuYXBwcm92YWxfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OAogICAgLy8gY2xhc3MgVHVwbGVzQ29udHJhY3QoQVJDNENvbnRyYWN0LCBhdm1fdmVyc2lvbj0xMSk6CiAgICB0eG4gTnVtQXBwQXJncwogICAgYnogbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1CiAgICBwdXNoYnl0ZXMgMHg3MjI5ZDc5YSAvLyBtZXRob2QgInRlc3RfdHVwbGVfd2l0aF9wcmltaXRpdmVfdHlwZSgpKHVpbnQ2NCxib29sKSIKICAgIHR4bmEgQXBwbGljYXRpb25BcmdzIDAKICAgIG1hdGNoIG1haW5fdGVzdF90dXBsZV93aXRoX3ByaW1pdGl2ZV90eXBlX3JvdXRlQDMKICAgIGVycgoKbWFpbl90ZXN0X3R1cGxlX3dpdGhfcHJpbWl0aXZlX3R5cGVfcm91dGVAMzoKICAgIC8vIHRlc3RzL2FydGlmYWN0cy9UdXBsZXMvY29udHJhY3QucHk6OQogICAgLy8gQGFyYzQuYWJpbWV0aG9kKCkKICAgIHR4biBPbkNvbXBsZXRpb24KICAgICEKICAgIHR4biBBcHBsaWNhdGlvbklECiAgICAmJgogICAgYXNzZXJ0IC8vIE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIG5vdCBjcmVhdGluZwogICAgcHVzaGJ5dGVzIDB4MTUxZjdjNzUwMDAwMDAwMDAwMDAwMDAwODAKICAgIGxvZwogICAgcHVzaGludCAxIC8vIDEKICAgIHJldHVybgoKbWFpbl9fX2FsZ29weV9kZWZhdWx0X2NyZWF0ZUA1OgogICAgdHhuIE9uQ29tcGxldGlvbgogICAgIQogICAgdHhuIEFwcGxpY2F0aW9uSUQKICAgICEKICAgICYmCiAgICByZXR1cm4gLy8gb24gZXJyb3I6IE9uQ29tcGxldGlvbiBtdXN0IGJlIE5vT3AgJiYgY2FuIG9ubHkgY2FsbCB3aGVuIGNyZWF0aW5nCg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "byteCode": { - "approval": "CzEbQQAqgARyKdeaNhoAjgEAA4EAQzEZFEQxGESADRUffHUAAAAAAAAAAICwgQFDMRlA/94xGBREgQFD", + "approval": "CzEbQQAogARyKdeaNhoAjgEAAQAxGRQxGBBEgA0VH3x1AAAAAAAAAACAsIEBQzEZFDEYFBBD", "clear": "C4EBQw==" }, "compilerInfo": { "compiler": "puya", "compilerVersion": { - "major": 4, - "minor": 10, + "major": 5, + "minor": 0, "patch": 0 } }, diff --git a/tests/models/test_box.py b/tests/models/test_box.py index 0155b94..a5d2851 100644 --- a/tests/models/test_box.py +++ b/tests/models/test_box.py @@ -372,8 +372,8 @@ def test_enums_in_boxes() -> None: oca, txn = defered_read.submit() # Assert - assert context.ledger.get_box(contract, b"oca") == itob(oca.native) - assert context.ledger.get_box(contract, b"txn") == itob(txn.native) + assert context.ledger.get_box(contract, b"oca") == itob(oca.as_uint64()) + assert context.ledger.get_box(contract, b"txn") == itob(txn.as_uint64()) class Swapped2(Struct): diff --git a/tests/state/test_global_state.py b/tests/state/test_global_state.py index cfed293..27e4946 100644 --- a/tests/state/test_global_state.py +++ b/tests/state/test_global_state.py @@ -204,7 +204,7 @@ def test_value_operations( gs = GlobalState(type_, key="test_key") gs.value = value - response = gs.value.native if hasattr(gs.value, "native") else gs.value + response = gs.value.as_uint64() if hasattr(gs.value, "as_uint64") else gs.value assert response == expected_value assert compare_type(type_of(gs.value), type_) or isinstance(gs.value, type_) diff --git a/tests/test_context.py b/tests/test_context.py index 64e0c41..18d6bf3 100644 --- a/tests/test_context.py +++ b/tests/test_context.py @@ -186,7 +186,7 @@ def test_arc4_uint_methods(method: str, type_: type, min_val: int, max_val: int) func = getattr(context.any.arc4, method) value = func(min_val, max_val) assert isinstance(value, type_) - assert min_val <= value.native <= max_val # type: ignore[attr-defined] + assert min_val <= value.as_biguint() <= max_val # type: ignore[attr-defined] with pytest.raises(ValueError): # noqa: PT011 func(max_val + 1) diff --git a/tests/test_miscellaneous_op.py b/tests/test_miscellaneous_op.py index 091837e..4c61d86 100644 --- a/tests/test_miscellaneous_op.py +++ b/tests/test_miscellaneous_op.py @@ -1017,21 +1017,26 @@ def test_select_uint64_input_overflow(a: int, b: int, c: int) -> None: @pytest.mark.parametrize( ("a", "b", "c"), [ - (b"\x00", 0, 1), - (b"\x00" * 2 + int_to_bytes(256), 3, 1), - (b"\x00" * 2 + int_to_bytes(256), 0, 1), - (b"\x00" * 2 + int_to_bytes(256), 11, 1), - (b"\x00" * 2 + int_to_bytes(65535), 31, 0), - (b"\x00" * 2 + int_to_bytes(65535), 24, 0), - (int_to_bytes(MAX_UINT64), 63, 0), - (int_to_bytes(MAX_UINT64 - 1), 63, 1), - (int_to_bytes(MAX_UINT512), 511, 0), - (int_to_bytes(MAX_UINT512 - 1), 511, 1), - (int_to_bytes(MAX_UINT64), 0, 0), - (int_to_bytes(MAX_UINT512), 0, 0), - ], -) -def test_setbit_bytes(get_ops_avm_result: AVMInvoker, a: bytes, b: int, c: int) -> None: + (b"\x00", 0, True), + (b"\x00" * 2 + int_to_bytes(256), 3, True), + (b"\x00" * 2 + int_to_bytes(256), 0, True), + (b"\x00" * 2 + int_to_bytes(256), 11, True), + (b"\x00" * 2 + int_to_bytes(65535), 31, False), + (b"\x00" * 2 + int_to_bytes(65535), 24, False), + (int_to_bytes(MAX_UINT64), 63, False), + (int_to_bytes(MAX_UINT64 - 1), 63, True), + (int_to_bytes(MAX_UINT512), 511, False), + (int_to_bytes(MAX_UINT512 - 1), 511, True), + (int_to_bytes(MAX_UINT64), 0, False), + (int_to_bytes(MAX_UINT512), 0, False), + ], +) +def test_setbit_bytes( + get_ops_avm_result: AVMInvoker, + a: bytes, + b: int, + c: bool, # noqa: FBT001 +) -> None: avm_result = get_ops_avm_result("verify_setbit_bytes", a=a, b=b, c=c) result = op.setbit_bytes(a, b, c) assert avm_result == result @@ -1040,15 +1045,18 @@ def test_setbit_bytes(get_ops_avm_result: AVMInvoker, a: bytes, b: int, c: int) @pytest.mark.parametrize( ("a", "b", "c"), [ - (b"\x00", 8, 1), - (int_to_bytes(MAX_UINT64), 64, 0), - (int_to_bytes(MAX_UINT64 - 1), 64, 1), - (int_to_bytes(MAX_UINT512), 512, 0), - (int_to_bytes(MAX_UINT512 - 1), 512, 1), + (b"\x00", 8, True), + (int_to_bytes(MAX_UINT64), 64, False), + (int_to_bytes(MAX_UINT64 - 1), 64, True), + (int_to_bytes(MAX_UINT512), 512, False), + (int_to_bytes(MAX_UINT512 - 1), 512, True), ], ) def test_setbit_bytes_index_error( - get_ops_avm_result: AVMInvoker, a: bytes, b: int, c: int + get_ops_avm_result: AVMInvoker, + a: bytes, + b: int, + c: bool, # noqa: FBT001 ) -> None: with pytest.raises(algokit_utils.LogicError, match="setbit index beyond byteslice"): get_ops_avm_result("verify_setbit_bytes", a=a, b=b, c=c) @@ -1056,34 +1064,29 @@ def test_setbit_bytes_index_error( op.setbit_bytes(a, b, c) -def test_setbit_bytes_bit_error(get_ops_avm_result: AVMInvoker) -> None: - a = b"\x00" - b = 0 - c = 2 - with pytest.raises(algokit_utils.LogicError, match="setbit value > 1"): - get_ops_avm_result("verify_setbit_bytes", a=a, b=b, c=c) - with pytest.raises(ValueError, match=_too_big_error(1)): - op.setbit_bytes(a, b, c) - - @pytest.mark.parametrize( ("a", "b", "c"), [ - (0, 0, 1), - (0, 3, 1), - (0, 10, 1), - (256, 3, 1), - (256, 0, 1), - (256, 11, 1), - (65535, 15, 0), - (65535, 7, 0), - (65535, 63, 1), - (MAX_UINT64, 63, 0), - (MAX_UINT64 - 1, 63, 1), - (MAX_UINT64, 0, 0), - ], -) -def test_setbit_uint64(get_ops_avm_result: AVMInvoker, a: int, b: int, c: int) -> None: + (0, 0, True), + (0, 3, True), + (0, 10, True), + (256, 3, True), + (256, 0, True), + (256, 11, True), + (65535, 15, False), + (65535, 7, False), + (65535, 63, True), + (MAX_UINT64, 63, False), + (MAX_UINT64 - 1, 63, True), + (MAX_UINT64, 0, False), + ], +) +def test_setbit_uint64( + get_ops_avm_result: AVMInvoker, + a: int, + b: int, + c: bool, # noqa: FBT001 +) -> None: avm_result = get_ops_avm_result("verify_setbit_uint64", a=a, b=b, c=c) result = op.setbit_uint64(a, b, c) assert avm_result == result @@ -1092,27 +1095,22 @@ def test_setbit_uint64(get_ops_avm_result: AVMInvoker, a: int, b: int, c: int) - @pytest.mark.parametrize( ("a", "b", "c"), [ - (MAX_UINT64, 64, 0), - (MAX_UINT64 - 1, 64, 1), + (MAX_UINT64, 64, False), + (MAX_UINT64 - 1, 64, True), ], ) -def test_setbit_uint64_index_error(get_ops_avm_result: AVMInvoker, a: int, b: int, c: int) -> None: +def test_setbit_uint64_index_error( + get_ops_avm_result: AVMInvoker, + a: int, + b: int, + c: bool, # noqa: FBT001 +) -> None: with pytest.raises(algokit_utils.LogicError, match="setbit index > 63 with Uint"): get_ops_avm_result("verify_setbit_uint64", a=a, b=b, c=c) with pytest.raises(ValueError, match=_too_big_error(7 if a == 0 else a.bit_length() - 1)): op.setbit_uint64(a, b, c) -def test_setbit_uint64_bit_error(get_ops_avm_result: AVMInvoker) -> None: - a = 0 - b = 0 - c = 2 - with pytest.raises(algokit_utils.LogicError, match="setbit value > 1"): - get_ops_avm_result("verify_setbit_uint64", a=a, b=b, c=c) - with pytest.raises(ValueError, match=_too_big_error(1)): - op.setbit_uint64(a, b, c) - - @pytest.mark.parametrize( ("a", "b", "c"), [ diff --git a/tests/utilities/test_log.py b/tests/utilities/test_log.py index 232eaad..a02529b 100644 --- a/tests/utilities/test_log.py +++ b/tests/utilities/test_log.py @@ -42,8 +42,8 @@ def test_log(get_avm_result: AVMInvoker, context: AlgopyTestContext) -> None: d=d.bytes.value, e=e.native, f=f.native.value, - g=g.native.value, - h=h.native.value, + g=g.as_uint64().value, + h=h.as_biguint().value, i=int.from_bytes(i.bytes.value), j=int.from_bytes(j.bytes.value), k=k.bytes.value,