fix spec builder

This commit is contained in:
protolambda 2019-05-27 21:14:59 +02:00
parent f3088884b3
commit 132d3c976a
No known key found for this signature in database
GPG Key ID: EC89FDBB2B4C7623
2 changed files with 44 additions and 24 deletions

View File

@ -16,7 +16,10 @@ from eth2spec.utils.ssz.ssz_impl import (
hash_tree_root, hash_tree_root,
signing_root, signing_root,
) )
from eth2spec.utils.ssz.ssz_typing import * from eth2spec.utils.ssz.ssz_typing import (
uint8, uint16, uint32, uint64, uint128, uint256,
Container, Vector, BytesN
)
from eth2spec.utils.bls_stub import ( from eth2spec.utils.bls_stub import (
bls_aggregate_pubkeys, bls_aggregate_pubkeys,
bls_verify, bls_verify,
@ -24,19 +27,18 @@ from eth2spec.utils.bls_stub import (
) )
from eth2spec.utils.hash_function import hash from eth2spec.utils.hash_function import hash
# Note: 'int' type defaults to being interpreted as a uint64 by SSZ implementation.
# stub, will get overwritten by real var
SLOTS_PER_EPOCH = 64
Slot = NewType('Slot', int) # uint64 Slot = NewType('Slot', int) # uint64
Epoch = NewType('Epoch', int) # uint64 Epoch = NewType('Epoch', int) # uint64
Shard = NewType('Shard', int) # uint64 Shard = NewType('Shard', int) # uint64
ValidatorIndex = NewType('ValidatorIndex', int) # uint64 ValidatorIndex = NewType('ValidatorIndex', int) # uint64
Gwei = NewType('Gwei', int) # uint64 Gwei = NewType('Gwei', int) # uint64
Bytes4 = BytesN[4]
Bytes32 = BytesN[32] Bytes32 = BytesN[32]
BLSPubkey = NewType('BLSPubkey', BytesN[48]) Bytes48 = BytesN[48]
BLSSignature = NewType('BLSSignature', BytesN[96]) Bytes96 = BytesN[96]
Store = None
""") """)
code_lines += function_puller.get_spec(sourcefile) code_lines += function_puller.get_spec(sourcefile)

View File

@ -1,4 +1,3 @@
import sys
from typing import List from typing import List
@ -6,9 +5,11 @@ def get_spec(file_name: str) -> List[str]:
code_lines = [] code_lines = []
pulling_from = None pulling_from = None
current_name = None current_name = None
# list of current type definition being parsed, or None otherwise
current_typedef = None current_typedef = None
# list of (name, definition lines list) tuples.
type_defs = [] type_defs = []
for linenum, line in enumerate(open(sys.argv[1]).readlines()): for linenum, line in enumerate(open(file_name).readlines()):
line = line.rstrip() line = line.rstrip()
if pulling_from is None and len(line) > 0 and line[0] == '#' and line[-1] == '`': if pulling_from is None and len(line) > 0 and line[0] == '#' and line[-1] == '`':
current_name = line[line[:-1].rfind('`') + 1: -1] current_name = line[line[:-1].rfind('`') + 1: -1]
@ -19,22 +20,24 @@ def get_spec(file_name: str) -> List[str]:
if pulling_from is None: if pulling_from is None:
pulling_from = linenum pulling_from = linenum
else: else:
if current_typedef is not None:
assert code_lines[-1] == '}'
code_lines[-1] = ''
code_lines.append('')
pulling_from = None pulling_from = None
if current_typedef is not None:
type_defs.append((current_name, current_typedef))
current_typedef = None current_typedef = None
else: else:
if pulling_from == linenum and line == '{': if pulling_from is not None:
code_lines.append('class %s(SSZContainer):' % current_name)
current_typedef = current_name
type_defs.append(current_name)
elif pulling_from is not None:
# Add some whitespace between functions # Add some whitespace between functions
if line[:3] == 'def': if line[:3] == 'def' or line[:5] == 'class':
code_lines.append('') code_lines.append('')
code_lines.append('') code_lines.append('')
# Check for SSZ type definitions
if len(line) > 18 and line[:6] == 'class ' and line[-12:] == '(Container):':
name = line[6:-12]
# Check consistency with markdown header
assert name == current_name
current_typedef = []
if current_typedef is not None:
current_typedef.append(line)
code_lines.append(line) code_lines.append(line)
elif pulling_from is None and len(line) > 0 and line[0] == '|': elif pulling_from is None and len(line) > 0 and line[0] == '|':
row = line[1:].split('|') row = line[1:].split('|')
@ -54,11 +57,26 @@ def get_spec(file_name: str) -> List[str]:
# Build type-def re-initialization # Build type-def re-initialization
code_lines.append('\n') code_lines.append('\n')
code_lines.append('ssz_types = [\n') code_lines.append('ssz_types = [\n')
for ssz_type_name in type_defs: for (ssz_type_name, _) in type_defs:
code_lines.append(f' {ssz_type_name},\n') code_lines.append(f' {ssz_type_name},')
code_lines.append(']') code_lines.append(']')
code_lines.append('\n') code_lines.append('\n')
code_lines.append('def get_ssz_type_by_name(name: str) -> SSZType:') code_lines.append('def init_SSZ_types():')
code_lines.append(' global_vars = globals()')
for ssz_type_name, ssz_type in type_defs:
code_lines.append('')
for type_line in ssz_type:
if len(type_line) > 0:
code_lines.append(' ' + type_line)
code_lines.append('\n')
for (ssz_type_name, _) in type_defs:
code_lines.append(f' global_vars["{ssz_type_name}"] = {ssz_type_name},')
code_lines.append(' global_vars["ssz_types"] = [')
for (ssz_type_name, _) in type_defs:
code_lines.append(f' {ssz_type_name},')
code_lines.append(' ]')
code_lines.append('\n')
code_lines.append('def get_ssz_type_by_name(name: str) -> Container:')
code_lines.append(' return globals()[name]') code_lines.append(' return globals()[name]')
code_lines.append('') code_lines.append('')
return code_lines return code_lines