580 lines
12 KiB
Go
580 lines
12 KiB
Go
package chain
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
|
|
"github.com/filecoin-project/go-lotus/chain/types"
|
|
cid "github.com/ipfs/go-cid"
|
|
cbg "github.com/whyrusleeping/cbor-gen"
|
|
xerrors "golang.org/x/xerrors"
|
|
)
|
|
|
|
/* This file was generated by github.com/whyrusleeping/cbor-gen */
|
|
|
|
var _ = xerrors.Errorf
|
|
|
|
func (t *BlockSyncRequest) MarshalCBOR(w io.Writer) error {
|
|
if _, err := w.Write([]byte{131}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.t.Start ([]cid.Cid)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.Start)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.Start {
|
|
if err := cbg.WriteCid(w, v); err != nil {
|
|
return xerrors.Errorf("failed writing cid field t.Start: %w", err)
|
|
}
|
|
}
|
|
|
|
// t.t.RequestLength (uint64)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajUnsignedInt, t.RequestLength)); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.t.Options (uint64)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajUnsignedInt, t.Options)); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *BlockSyncRequest) UnmarshalCBOR(br io.Reader) error {
|
|
|
|
maj, extra, err := cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("cbor input should be of type array")
|
|
}
|
|
|
|
if extra != 3 {
|
|
return fmt.Errorf("cbor input had wrong number of fields")
|
|
}
|
|
|
|
// t.t.Start ([]cid.Cid)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.Start = make([]cid.Cid, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
if err != nil {
|
|
return xerrors.Errorf("reading cid field t.Start failed: %w", err)
|
|
}
|
|
t.Start[i] = c
|
|
}
|
|
|
|
// t.t.RequestLength (uint64)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajUnsignedInt {
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
}
|
|
t.RequestLength = extra
|
|
// t.t.Options (uint64)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajUnsignedInt {
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
}
|
|
t.Options = extra
|
|
return nil
|
|
}
|
|
|
|
func (t *BlockSyncResponse) MarshalCBOR(w io.Writer) error {
|
|
if _, err := w.Write([]byte{131}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.t.Chain ([]*chain.BSTipSet)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.Chain)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.Chain {
|
|
if err := v.MarshalCBOR(w); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// t.t.Status (uint64)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajUnsignedInt, t.Status)); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.t.Message (string)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajTextString, uint64(len(t.Message)))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := w.Write([]byte(t.Message)); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *BlockSyncResponse) UnmarshalCBOR(br io.Reader) error {
|
|
|
|
maj, extra, err := cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("cbor input should be of type array")
|
|
}
|
|
|
|
if extra != 3 {
|
|
return fmt.Errorf("cbor input had wrong number of fields")
|
|
}
|
|
|
|
// t.t.Chain ([]*chain.BSTipSet)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.Chain = make([]*BSTipSet, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
var v BSTipSet
|
|
if err := v.UnmarshalCBOR(br); err != nil {
|
|
return err
|
|
}
|
|
|
|
t.Chain[i] = &v
|
|
}
|
|
|
|
// t.t.Status (uint64)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajUnsignedInt {
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
}
|
|
t.Status = extra
|
|
// t.t.Message (string)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if maj != cbg.MajTextString {
|
|
return fmt.Errorf("expected cbor type 'text string' in input")
|
|
}
|
|
|
|
if extra > 256*1024 {
|
|
return fmt.Errorf("string in cbor input too long")
|
|
}
|
|
|
|
{
|
|
buf := make([]byte, extra)
|
|
if _, err := io.ReadFull(br, buf); err != nil {
|
|
return err
|
|
}
|
|
|
|
t.Message = string(buf)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *BSTipSet) MarshalCBOR(w io.Writer) error {
|
|
if _, err := w.Write([]byte{133}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.t.Blocks ([]*types.BlockHeader)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.Blocks)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.Blocks {
|
|
if err := v.MarshalCBOR(w); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// t.t.BlsMessages ([]*types.Message)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.BlsMessages)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.BlsMessages {
|
|
if err := v.MarshalCBOR(w); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// t.t.BlsMsgIncludes ([][]uint64)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.BlsMsgIncludes)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.BlsMsgIncludes {
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(v)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range v {
|
|
if err := cbg.CborWriteHeader(w, cbg.MajUnsignedInt, v); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
|
|
// t.t.SecpkMessages ([]*types.SignedMessage)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.SecpkMessages)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.SecpkMessages {
|
|
if err := v.MarshalCBOR(w); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// t.t.SecpkMsgIncludes ([][]uint64)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.SecpkMsgIncludes)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.SecpkMsgIncludes {
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(v)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range v {
|
|
if err := cbg.CborWriteHeader(w, cbg.MajUnsignedInt, v); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *BSTipSet) UnmarshalCBOR(br io.Reader) error {
|
|
|
|
maj, extra, err := cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("cbor input should be of type array")
|
|
}
|
|
|
|
if extra != 5 {
|
|
return fmt.Errorf("cbor input had wrong number of fields")
|
|
}
|
|
|
|
// t.t.Blocks ([]*types.BlockHeader)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.Blocks = make([]*types.BlockHeader, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
var v types.BlockHeader
|
|
if err := v.UnmarshalCBOR(br); err != nil {
|
|
return err
|
|
}
|
|
|
|
t.Blocks[i] = &v
|
|
}
|
|
|
|
// t.t.BlsMessages ([]*types.Message)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.BlsMessages = make([]*types.Message, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
var v types.Message
|
|
if err := v.UnmarshalCBOR(br); err != nil {
|
|
return err
|
|
}
|
|
|
|
t.BlsMessages[i] = &v
|
|
}
|
|
|
|
// t.t.BlsMsgIncludes ([][]uint64)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.BlsMsgIncludes = make([][]uint64, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
{
|
|
var maj byte
|
|
var extra uint64
|
|
var err error
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.BlsMsgIncludes[i] = make([]uint64, extra)
|
|
}
|
|
for j := 0; j < int(extra); j++ {
|
|
|
|
maj, val, err := cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return xerrors.Errorf("failed to read uint64 for t.BlsMsgIncludes[i] slice: %w", err)
|
|
}
|
|
|
|
if maj != cbg.MajUnsignedInt {
|
|
return xerrors.Errorf("value read for array t.BlsMsgIncludes[i] was not a uint, instead got %d", maj)
|
|
}
|
|
|
|
t.BlsMsgIncludes[i][j] = val
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
// t.t.SecpkMessages ([]*types.SignedMessage)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.SecpkMessages = make([]*types.SignedMessage, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
var v types.SignedMessage
|
|
if err := v.UnmarshalCBOR(br); err != nil {
|
|
return err
|
|
}
|
|
|
|
t.SecpkMessages[i] = &v
|
|
}
|
|
|
|
// t.t.SecpkMsgIncludes ([][]uint64)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.SecpkMsgIncludes = make([][]uint64, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
{
|
|
var maj byte
|
|
var extra uint64
|
|
var err error
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.SecpkMsgIncludes[i] = make([]uint64, extra)
|
|
}
|
|
for j := 0; j < int(extra); j++ {
|
|
|
|
maj, val, err := cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return xerrors.Errorf("failed to read uint64 for t.SecpkMsgIncludes[i] slice: %w", err)
|
|
}
|
|
|
|
if maj != cbg.MajUnsignedInt {
|
|
return xerrors.Errorf("value read for array t.SecpkMsgIncludes[i] was not a uint, instead got %d", maj)
|
|
}
|
|
|
|
t.SecpkMsgIncludes[i][j] = val
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (t *BlockMsg) MarshalCBOR(w io.Writer) error {
|
|
if _, err := w.Write([]byte{131}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.t.Header (types.BlockHeader)
|
|
if err := t.Header.MarshalCBOR(w); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.t.BlsMessages ([]cid.Cid)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.BlsMessages)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.BlsMessages {
|
|
if err := cbg.WriteCid(w, v); err != nil {
|
|
return xerrors.Errorf("failed writing cid field t.BlsMessages: %w", err)
|
|
}
|
|
}
|
|
|
|
// t.t.SecpkMessages ([]cid.Cid)
|
|
if _, err := w.Write(cbg.CborEncodeMajorType(cbg.MajArray, uint64(len(t.SecpkMessages)))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.SecpkMessages {
|
|
if err := cbg.WriteCid(w, v); err != nil {
|
|
return xerrors.Errorf("failed writing cid field t.SecpkMessages: %w", err)
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *BlockMsg) UnmarshalCBOR(br io.Reader) error {
|
|
|
|
maj, extra, err := cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("cbor input should be of type array")
|
|
}
|
|
|
|
if extra != 3 {
|
|
return fmt.Errorf("cbor input had wrong number of fields")
|
|
}
|
|
|
|
// t.t.Header (types.BlockHeader)
|
|
|
|
t.Header = new(types.BlockHeader)
|
|
if err := t.Header.UnmarshalCBOR(br); err != nil {
|
|
return err
|
|
}
|
|
// t.t.BlsMessages ([]cid.Cid)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.BlsMessages = make([]cid.Cid, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
if err != nil {
|
|
return xerrors.Errorf("reading cid field t.BlsMessages failed: %w", err)
|
|
}
|
|
t.BlsMessages[i] = c
|
|
}
|
|
|
|
// t.t.SecpkMessages ([]cid.Cid)
|
|
|
|
maj, extra, err = cbg.CborReadHeader(br)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if extra > 8192 {
|
|
return fmt.Errorf("array too large")
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
if extra > 0 {
|
|
t.SecpkMessages = make([]cid.Cid, extra)
|
|
}
|
|
for i := 0; i < int(extra); i++ {
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
if err != nil {
|
|
return xerrors.Errorf("reading cid field t.SecpkMessages failed: %w", err)
|
|
}
|
|
t.SecpkMessages[i] = c
|
|
}
|
|
|
|
return nil
|
|
}
|