Skip to content

Commit

Permalink
feat: is_account_empty
Browse files Browse the repository at this point in the history
  • Loading branch information
obatirou committed Jan 15, 2025
1 parent e12b8cc commit 5a7cfb5
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 0 deletions.
29 changes: 29 additions & 0 deletions cairo/ethereum/cancun/state.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -436,3 +436,32 @@ func account_exists{poseidon_ptr: PoseidonBuiltin*, state: State}(address: Addre
tempvar result = bool(1);
return result;
}

func is_account_empty{poseidon_ptr: PoseidonBuiltin*, state: State}(address: Address) -> bool {
// Get the account at the address
let account = get_account(address);

// Check if nonce is 0, code is empty, and balance is 0
if (account.value.nonce.value != 0) {
tempvar res = bool(0);
return res;
}

if (account.value.code.value.len != 0) {
tempvar res = bool(0);
return res;
}

if (account.value.balance.value.low != 0) {
tempvar res = bool(0);
return res;
}

if (account.value.balance.value.high != 0) {
tempvar res = bool(0);
return res;
}

tempvar res = bool(1);
return res;
}
8 changes: 8 additions & 0 deletions cairo/tests/ethereum/cancun/test_state.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
get_account_optional,
get_storage,
get_transient_storage,
is_account_empty,
set_storage,
set_transient_storage,
)
Expand Down Expand Up @@ -82,6 +83,13 @@ def test_account_exists(self, cairo_run, data):
assert result_cairo == account_exists(state, address)
assert state_cairo == state

@given(data=state_and_address_and_optional_key())
def test_is_account_empty(self, cairo_run, data):
state, address = data
state_cairo, result_cairo = cairo_run("is_account_empty", state, address)
assert result_cairo == is_account_empty(state, address)
assert state_cairo == state


class TestStateStorage:
@given(data=state_and_address_and_optional_key(key_strategy=bytes32))
Expand Down

0 comments on commit 5a7cfb5

Please sign in to comment.