Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create helper for max size, as bounded by Limit #20

Open
arnetheduck opened this issue Jan 3, 2022 · 1 comment
Open

Create helper for max size, as bounded by Limit #20

arnetheduck opened this issue Jan 3, 2022 · 1 comment

Comments

@arnetheduck
Copy link
Member

Many types like Attestation have a useful max serialized size that can be computed by using the Limit of every List as upper bound - a helper to compute this value would be generally useful for example to harden the decompression code against overlong messages: status-im/nimbus-eth2#3230 (comment)

@arnetheduck
Copy link
Member Author

import
  std/typetraits,
  ../beacon_chain/spec/eth2_ssz_serialization,
  ../beacon_chain/spec/datatypes/[deneb]

proc maxSize(T: type): int =
  when isFixedSize(T):
    fixedPortionSize(T)
  elif T is HashList:
    maxSize(T.T)
  elif T is BitList:
    (T.maxLen div 8) + 1
  elif T is BitArray:
    (T.maxLen + 7) div 8
  elif T is List:
    type E = T.T
    when isFixedSize(E):
      T.maxLen * maxSize(E)
    else:
      T.maxLen * (maxSize(E) + 4)

  elif T is object|tuple:
    var size = fixedPortionSize(T)
    for field in fields(default(T)):
      when not isFixedSize(typeof(field)):
        size += maxSize(typeof(field))
    size
  else:
    0

proc printSizes(T: type, indent: string) =
  when T is object:
    for name, field in fieldPairs(default(T)):
      type F = typeof(field)
      echo indent, name, ": ", maxSize(F)

      when not isFixedSize(F):
        printSizes(F, indent & "  ")

proc printSizes(T: type) =
  echo T.name, ": ", maxSize(T)
  printSizes(T, "  ")

printSizes(deneb.SignedBeaconBlock)
printSizes(Attestation)

a humble beginning that gets us as far as the deneb block I think

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant