From 81cb4a23b31ef11ae2b17d7b4f19d92608466cfe Mon Sep 17 00:00:00 2001 From: protolambda Date: Sat, 25 May 2019 00:10:06 +0200 Subject: [PATCH] update some common usage of SSZ types, as a start --- scripts/phase0/build_spec.py | 6 ++-- scripts/phase0/function_puller.py | 18 ------------ specs/core/0_beacon-chain.md | 48 +++++++++++++++---------------- 3 files changed, 27 insertions(+), 45 deletions(-) diff --git a/scripts/phase0/build_spec.py b/scripts/phase0/build_spec.py index b226194d6..b188dada2 100644 --- a/scripts/phase0/build_spec.py +++ b/scripts/phase0/build_spec.py @@ -33,9 +33,9 @@ Epoch = NewType('Epoch', int) # uint64 Shard = NewType('Shard', int) # uint64 ValidatorIndex = NewType('ValidatorIndex', int) # uint64 Gwei = NewType('Gwei', int) # uint64 -Bytes32 = NewType('Bytes32', bytes) # bytes32 -BLSPubkey = NewType('BLSPubkey', bytes) # bytes48 -BLSSignature = NewType('BLSSignature', bytes) # bytes96 +Bytes32 = BytesN[32] +BLSPubkey = NewType('BLSPubkey', BytesN[48]) +BLSSignature = NewType('BLSSignature', BytesN[96]) Store = None """) diff --git a/scripts/phase0/function_puller.py b/scripts/phase0/function_puller.py index f94687344..5c1cf859b 100644 --- a/scripts/phase0/function_puller.py +++ b/scripts/phase0/function_puller.py @@ -2,22 +2,6 @@ import sys from typing import List -def translate_ssz_type_line(line: str) -> str: - if ':' not in line: - return line - start = line[:line.index(':')] - field_type = line[line.index(':')+2:] - if field_type.startswith('['): - if ',' in line: - # TODO: translate [Foobar, SOME_THING] to Vector[Foobar, SSZLen(SOME_THING)] cleanly. - # just brute it here - field_type = 'Vector[%s, SSLen(%s)]' % (field_type[1:field_type.index(',')], field_type[field_type.index(',')+2:len(field_type)-1]) - else: - field_type = 'List[%s]' % field_type[1:len(field_type)-1] - line = start + ': ' + field_type - return line - - def get_spec(file_name: str) -> List[str]: code_lines = [] pulling_from = None @@ -51,8 +35,6 @@ def get_spec(file_name: str) -> List[str]: if line[:3] == 'def': code_lines.append('') code_lines.append('') - if current_typedef is not None: - line = translate_ssz_type_line(line) code_lines.append(line) elif pulling_from is None and len(line) > 0 and line[0] == '|': row = line[1:].split('|') diff --git a/specs/core/0_beacon-chain.md b/specs/core/0_beacon-chain.md index ff5a082ef..35d273a2e 100644 --- a/specs/core/0_beacon-chain.md +++ b/specs/core/0_beacon-chain.md @@ -340,8 +340,8 @@ The types are defined topologically to aid in facilitating an executable version ```python { # Validator indices - custody_bit_0_indices: [uint64] - custody_bit_1_indices: [uint64] + custody_bit_0_indices: List[uint64] + custody_bit_1_indices: List[uint64] # Attestation data data: AttestationData # Aggregate signature @@ -418,9 +418,9 @@ The types are defined topologically to aid in facilitating an executable version ```python { # Block roots - block_roots: [bytes32, SLOTS_PER_HISTORICAL_ROOT] + block_roots: Vector[bytes32, SLOTS_PER_HISTORICAL_ROOT] # State roots - state_roots: [bytes32, SLOTS_PER_HISTORICAL_ROOT] + state_roots: Vector[bytes32, SLOTS_PER_HISTORICAL_ROOT] } ``` @@ -470,7 +470,7 @@ The types are defined topologically to aid in facilitating an executable version ```python { # Branch in the deposit tree - proof: [bytes32, DEPOSIT_CONTRACT_TREE_DEPTH] + proof: Vector[bytes32, DEPOSIT_CONTRACT_TREE_DEPTH] # Index in the deposit tree index: uint64 # Data @@ -521,12 +521,12 @@ The types are defined topologically to aid in facilitating an executable version randao_reveal: bytes96 eth1_data: Eth1Data graffiti: bytes32 - proposer_slashings: [ProposerSlashing] - attester_slashings: [AttesterSlashing] - attestations: [Attestation] - deposits: [Deposit] - voluntary_exits: [VoluntaryExit] - transfers: [Transfer] + proposer_slashings: List[ProposerSlashing] + attester_slashings: List[AttesterSlashing] + attestations: List[Attestation] + deposits: List[Deposit] + voluntary_exits: List[VoluntaryExit] + transfers: List[Transfer] } ``` @@ -555,16 +555,16 @@ The types are defined topologically to aid in facilitating an executable version fork: Fork # For versioning hard forks # Validator registry - validator_registry: [Validator] - balances: [uint64] + validator_registry: List[Validator] + balances: List[uint64] # Randomness and committees - latest_randao_mixes: [bytes32, LATEST_RANDAO_MIXES_LENGTH] + latest_randao_mixes: Vector[bytes32, LATEST_RANDAO_MIXES_LENGTH] latest_start_shard: uint64 # Finality - previous_epoch_attestations: [PendingAttestation] - current_epoch_attestations: [PendingAttestation] + previous_epoch_attestations: List[PendingAttestation] + current_epoch_attestations: List[PendingAttestation] previous_justified_epoch: uint64 current_justified_epoch: uint64 previous_justified_root: bytes32 @@ -574,20 +574,20 @@ The types are defined topologically to aid in facilitating an executable version finalized_root: bytes32 # Recent state - current_crosslinks: [Crosslink, SHARD_COUNT] - previous_crosslinks: [Crosslink, SHARD_COUNT] - latest_block_roots: [bytes32, SLOTS_PER_HISTORICAL_ROOT] - latest_state_roots: [bytes32, SLOTS_PER_HISTORICAL_ROOT] - latest_active_index_roots: [bytes32, LATEST_ACTIVE_INDEX_ROOTS_LENGTH] + current_crosslinks: Vector[Crosslink, SHARD_COUNT] + previous_crosslinks: Vector[Crosslink, SHARD_COUNT] + latest_block_roots: Vector[bytes32, SLOTS_PER_HISTORICAL_ROOT] + latest_state_roots: Vector[bytes32, SLOTS_PER_HISTORICAL_ROOT] + latest_active_index_roots: Vector[bytes32, LATEST_ACTIVE_INDEX_ROOTS_LENGTH] # Balances slashed at every withdrawal period - latest_slashed_balances: [uint64, LATEST_SLASHED_EXIT_LENGTH] + latest_slashed_balances: Vector[uint64, LATEST_SLASHED_EXIT_LENGTH] # `latest_block_header.state_root == ZERO_HASH` temporarily latest_block_header: BeaconBlockHeader - historical_roots: [bytes32] + historical_roots: List[bytes32] # Ethereum 1.0 chain data latest_eth1_data: Eth1Data - eth1_data_votes: [Eth1Data] + eth1_data_votes: List[Eth1Data] deposit_index: uint64 } ```