From b72da44529c7005408db096e62b033cf1c96149b Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Tue, 29 Oct 2024 10:58:22 +0100 Subject: [PATCH 1/3] chore: update boa --- boa_zksync/contract.py | 6 +++--- boa_zksync/deployer.py | 10 +++++----- pyproject.toml | 2 +- tests/test_boa_loads.py | 6 +++--- 4 files changed, 12 insertions(+), 12 deletions(-) diff --git a/boa_zksync/contract.py b/boa_zksync/contract.py index 40f5648..3d93cf4 100644 --- a/boa_zksync/contract.py +++ b/boa_zksync/contract.py @@ -33,7 +33,7 @@ class ZksyncContract(ABIContract): def __init__( self, compiler_data: ZksyncCompilerData, - name: str, + contract_name: str, functions: list[ABIFunction], *args, value=0, @@ -55,7 +55,7 @@ def __init__( self._abi = compiler_data.abi self.env = Env.get_singleton() if env is None else env self.filename = filename - self.contract_name = name + self.contract_name = contract_name # run the constructor if not skipping if skip_initcode: @@ -69,7 +69,7 @@ def __init__( # only now initialize the ABI contract super().__init__( - name=name, + name=contract_name, abi=compiler_data.abi, functions=functions, address=address, diff --git a/boa_zksync/deployer.py b/boa_zksync/deployer.py index 7f90ed2..7f64559 100644 --- a/boa_zksync/deployer.py +++ b/boa_zksync/deployer.py @@ -1,6 +1,6 @@ from functools import cached_property from pathlib import Path -from typing import TYPE_CHECKING +from typing import TYPE_CHECKING, Optional from boa import Env from boa.contracts.abi.abi_contract import ABIContractFactory @@ -43,10 +43,10 @@ def _compile( def from_abi_dict(cls, abi, name="", filename=None): raise NotImplementedError("ZksyncDeployer does not support loading from ABI") - def deploy(self, *args, **kwargs) -> ZksyncContract: + def deploy(self, *args, contract_name: Optional[str]=None, **kwargs) -> ZksyncContract: return ZksyncContract( self.zkvyper_data, - self._name, + contract_name or self._name, self.functions, *args, filename=self.filename, @@ -59,14 +59,14 @@ def at(self, address: Address | str) -> ZksyncContract: """ return self.deploy(override_address=Address(address), skip_initcode=True) - def deploy_as_blueprint(self, **kwargs) -> ZksyncContract: + def deploy_as_blueprint(self, contract_name: Optional[str]=None, **kwargs) -> ZksyncContract: """ In zkSync, any contract can be used as a blueprint. The only difference here is that we don't need to run the constructor. """ return ZksyncBlueprint( self.zkvyper_data, - self._name, + contract_name or self._name, self.functions, filename=self.filename, **kwargs, diff --git a/pyproject.toml b/pyproject.toml index 649caf7..9c4858e 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -17,7 +17,7 @@ classifiers = [ ] dependencies = [ - "titanoboa==0.2.4", + "titanoboa @ git+https://github.com/vyperlang/titanoboa.git", ] [project.optional-dependencies] diff --git a/tests/test_boa_loads.py b/tests/test_boa_loads.py index f8a2702..7d4dc15 100644 --- a/tests/test_boa_loads.py +++ b/tests/test_boa_loads.py @@ -126,14 +126,14 @@ def get_name_of(addr: HasName) -> String[32]: assert stack_trace == StackTrace( [ " Test an error( (file CalledContract).name() -> ['string'])", + f"{called_addr}> (file ).name() -> ['string'])", " Test an error( (file " - "CallerContract).get_name_of(address) -> ['string'])", + ").get_name_of(address) -> ['string'])", " ", " ", " Test an error( (file CallerContract).get_name_of(address) -> " + f"{caller_contract.address}> (file ).get_name_of(address) -> " "['string'])", ] ) From 362a6f1a05ca2fe84f6455d08a336ee1a7fb97d7 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Tue, 29 Oct 2024 15:12:27 +0100 Subject: [PATCH 2/3] chore: package versions --- pyproject.toml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 9c4858e..fcdb34a 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "titanoboa-zksync" -version = "0.2.5" +version = "0.2.6" description = "A Zksync plugin for the Titanoboa Vyper interpreter" license = { file = "LICENSE" } readme = "README.md" @@ -17,7 +17,7 @@ classifiers = [ ] dependencies = [ - "titanoboa @ git+https://github.com/vyperlang/titanoboa.git", + "titanoboa==0.2.5b1" ] [project.optional-dependencies] From 8b96fce6eb6f73350c63e3877aadd75bda86d8e5 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Tue, 29 Oct 2024 15:14:26 +0100 Subject: [PATCH 3/3] Reformat --- boa_zksync/deployer.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/boa_zksync/deployer.py b/boa_zksync/deployer.py index 7f64559..fb6d5fa 100644 --- a/boa_zksync/deployer.py +++ b/boa_zksync/deployer.py @@ -43,7 +43,9 @@ def _compile( def from_abi_dict(cls, abi, name="", filename=None): raise NotImplementedError("ZksyncDeployer does not support loading from ABI") - def deploy(self, *args, contract_name: Optional[str]=None, **kwargs) -> ZksyncContract: + def deploy( + self, *args, contract_name: Optional[str] = None, **kwargs + ) -> ZksyncContract: return ZksyncContract( self.zkvyper_data, contract_name or self._name, @@ -59,7 +61,9 @@ def at(self, address: Address | str) -> ZksyncContract: """ return self.deploy(override_address=Address(address), skip_initcode=True) - def deploy_as_blueprint(self, contract_name: Optional[str]=None, **kwargs) -> ZksyncContract: + def deploy_as_blueprint( + self, contract_name: Optional[str] = None, **kwargs + ) -> ZksyncContract: """ In zkSync, any contract can be used as a blueprint. The only difference here is that we don't need to run the constructor.