mirror of
https://github.com/status-im/eth2.0-specs.git
synced 2025-01-13 12:14:19 +00:00
improve type coercion; coerce between equal-length uint subclasses
This commit is contained in:
parent
8c6d2b42d8
commit
8bd204827b
@ -94,7 +94,12 @@ def coerce_type_maybe(v, typ: SSZType, strict: bool = False):
|
|||||||
# shortcut if it's already the type we are looking for
|
# shortcut if it's already the type we are looking for
|
||||||
if v_typ == typ:
|
if v_typ == typ:
|
||||||
return v
|
return v
|
||||||
elif isinstance(v, int) and not isinstance(v, uint): # do not coerce from one uintX to another uintY
|
elif isinstance(v, int):
|
||||||
|
if isinstance(v, uint): # do not coerce from one uintX to another uintY
|
||||||
|
if issubclass(typ, uint) and v.type().byte_len == typ.byte_len:
|
||||||
|
return typ(v)
|
||||||
|
# revert to default behavior below if-else. (ValueError/bare)
|
||||||
|
else:
|
||||||
return typ(v)
|
return typ(v)
|
||||||
elif isinstance(v, (list, tuple)):
|
elif isinstance(v, (list, tuple)):
|
||||||
return typ(*v)
|
return typ(*v)
|
||||||
@ -102,7 +107,7 @@ def coerce_type_maybe(v, typ: SSZType, strict: bool = False):
|
|||||||
return typ(v)
|
return typ(v)
|
||||||
elif isinstance(v, GeneratorType):
|
elif isinstance(v, GeneratorType):
|
||||||
return typ(v)
|
return typ(v)
|
||||||
else:
|
|
||||||
# just return as-is, Value-checkers will take care of it not being coerced, if we are not strict.
|
# just return as-is, Value-checkers will take care of it not being coerced, if we are not strict.
|
||||||
if strict and not isinstance(v, typ):
|
if strict and not isinstance(v, typ):
|
||||||
raise ValueError("Type coercion of {} to {} failed".format(v, typ))
|
raise ValueError("Type coercion of {} to {} failed".format(v, typ))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user