2020-02-05 02:26:42 +00:00
|
|
|
// Code generated by github.com/whyrusleeping/cbor-gen. DO NOT EDIT.
|
|
|
|
|
2020-01-15 20:49:11 +00:00
|
|
|
package sealing
|
|
|
|
|
|
|
|
import (
|
2020-04-06 20:35:29 +00:00
|
|
|
"fmt"
|
2020-01-15 20:49:11 +00:00
|
|
|
"io"
|
2021-02-19 19:11:43 +00:00
|
|
|
"sort"
|
2020-01-15 20:49:11 +00:00
|
|
|
|
2020-09-07 03:49:10 +00:00
|
|
|
abi "github.com/filecoin-project/go-state-types/abi"
|
2021-01-25 10:28:39 +00:00
|
|
|
market "github.com/filecoin-project/specs-actors/actors/builtin/market"
|
2020-08-16 09:42:13 +00:00
|
|
|
miner "github.com/filecoin-project/specs-actors/actors/builtin/miner"
|
2021-02-19 19:11:43 +00:00
|
|
|
cid "github.com/ipfs/go-cid"
|
2020-04-06 20:35:29 +00:00
|
|
|
cbg "github.com/whyrusleeping/cbor-gen"
|
2020-01-15 20:49:11 +00:00
|
|
|
xerrors "golang.org/x/xerrors"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _ = xerrors.Errorf
|
2021-02-19 19:11:43 +00:00
|
|
|
var _ = cid.Undef
|
|
|
|
var _ = sort.Sort
|
2020-01-15 20:49:11 +00:00
|
|
|
|
2020-04-08 14:52:20 +00:00
|
|
|
func (t *Piece) MarshalCBOR(w io.Writer) error {
|
2020-04-06 20:35:29 +00:00
|
|
|
if t == nil {
|
|
|
|
_, err := w.Write(cbg.CborNull)
|
|
|
|
return err
|
|
|
|
}
|
2020-04-07 21:44:33 +00:00
|
|
|
if _, err := w.Write([]byte{162}); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 9)
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
// t.Piece (abi.PieceInfo) (struct)
|
|
|
|
if len("Piece") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Piece\" was too long")
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Piece"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Piece")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
if err := t.Piece.MarshalCBOR(w); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-04-06 20:23:37 +00:00
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
// t.DealInfo (sealing.DealInfo) (struct)
|
|
|
|
if len("DealInfo") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"DealInfo\" was too long")
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("DealInfo"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("DealInfo")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
if err := t.DealInfo.MarshalCBOR(w); err != nil {
|
|
|
|
return err
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
return nil
|
2020-01-15 20:49:11 +00:00
|
|
|
}
|
|
|
|
|
2020-04-08 14:52:20 +00:00
|
|
|
func (t *Piece) UnmarshalCBOR(r io.Reader) error {
|
2020-08-12 02:47:24 +00:00
|
|
|
*t = Piece{}
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
br := cbg.GetPeeker(r)
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 8)
|
2020-04-06 20:35:29 +00:00
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajMap {
|
|
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.MaxLength {
|
2020-04-08 14:52:20 +00:00
|
|
|
return fmt.Errorf("Piece: map struct too large (%d)", extra)
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var name string
|
|
|
|
n := extra
|
|
|
|
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
name = string(sval)
|
|
|
|
}
|
|
|
|
|
|
|
|
switch name {
|
2020-04-07 21:44:33 +00:00
|
|
|
// t.Piece (abi.PieceInfo) (struct)
|
|
|
|
case "Piece":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if err := t.Piece.UnmarshalCBOR(br); err != nil {
|
|
|
|
return xerrors.Errorf("unmarshaling t.Piece: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.DealInfo (sealing.DealInfo) (struct)
|
|
|
|
case "DealInfo":
|
2020-04-06 20:35:29 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
b, err := br.ReadByte()
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-04-07 21:44:33 +00:00
|
|
|
t.DealInfo = new(DealInfo)
|
|
|
|
if err := t.DealInfo.UnmarshalCBOR(br); err != nil {
|
|
|
|
return xerrors.Errorf("unmarshaling t.DealInfo pointer: %w", err)
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-04-07 21:44:33 +00:00
|
|
|
|
|
|
|
default:
|
2021-02-19 19:11:43 +00:00
|
|
|
// Field doesn't exist on this type, so ignore it
|
|
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
2020-04-07 21:44:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
func (t *DealInfo) MarshalCBOR(w io.Writer) error {
|
|
|
|
if t == nil {
|
|
|
|
_, err := w.Write(cbg.CborNull)
|
|
|
|
return err
|
|
|
|
}
|
2021-01-25 10:28:39 +00:00
|
|
|
if _, err := w.Write([]byte{165}); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 9)
|
|
|
|
|
2020-08-27 15:50:37 +00:00
|
|
|
// t.PublishCid (cid.Cid) (struct)
|
|
|
|
if len("PublishCid") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"PublishCid\" was too long")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("PublishCid"))); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := io.WriteString(w, string("PublishCid")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.PublishCid == nil {
|
|
|
|
if _, err := w.Write(cbg.CborNull); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if err := cbg.WriteCidBuf(scratch, w, *t.PublishCid); err != nil {
|
|
|
|
return xerrors.Errorf("failed to write cid field t.PublishCid: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
// t.DealID (abi.DealID) (uint64)
|
|
|
|
if len("DealID") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"DealID\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("DealID"))); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("DealID")); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.DealID)); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-01-25 10:28:39 +00:00
|
|
|
// t.DealProposal (market.DealProposal) (struct)
|
|
|
|
if len("DealProposal") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"DealProposal\" was too long")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("DealProposal"))); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := io.WriteString(w, string("DealProposal")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := t.DealProposal.MarshalCBOR(w); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
// t.DealSchedule (sealing.DealSchedule) (struct)
|
|
|
|
if len("DealSchedule") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"DealSchedule\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("DealSchedule"))); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("DealSchedule")); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := t.DealSchedule.MarshalCBOR(w); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-07-02 20:09:59 +00:00
|
|
|
|
|
|
|
// t.KeepUnsealed (bool) (bool)
|
|
|
|
if len("KeepUnsealed") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"KeepUnsealed\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("KeepUnsealed"))); err != nil {
|
2020-07-02 20:09:59 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("KeepUnsealed")); err != nil {
|
2020-07-02 20:09:59 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := cbg.WriteBool(w, t.KeepUnsealed); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-04-07 21:44:33 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *DealInfo) UnmarshalCBOR(r io.Reader) error {
|
2020-08-12 02:47:24 +00:00
|
|
|
*t = DealInfo{}
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
br := cbg.GetPeeker(r)
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 8)
|
2020-04-07 21:44:33 +00:00
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-07 21:44:33 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajMap {
|
|
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.MaxLength {
|
|
|
|
return fmt.Errorf("DealInfo: map struct too large (%d)", extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
var name string
|
|
|
|
n := extra
|
|
|
|
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-07 21:44:33 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
name = string(sval)
|
|
|
|
}
|
|
|
|
|
|
|
|
switch name {
|
2020-08-27 15:50:37 +00:00
|
|
|
// t.PublishCid (cid.Cid) (struct)
|
|
|
|
case "PublishCid":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
b, err := br.ReadByte()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("failed to read cid field t.PublishCid: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.PublishCid = &c
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.DealID (abi.DealID) (uint64)
|
2020-04-07 21:44:33 +00:00
|
|
|
case "DealID":
|
2020-04-06 20:35:29 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajUnsignedInt {
|
|
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
|
|
}
|
2020-04-07 21:44:33 +00:00
|
|
|
t.DealID = abi.DealID(extra)
|
2020-04-06 20:35:29 +00:00
|
|
|
|
2021-01-25 10:28:39 +00:00
|
|
|
}
|
|
|
|
// t.DealProposal (market.DealProposal) (struct)
|
|
|
|
case "DealProposal":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
b, err := br.ReadByte()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
t.DealProposal = new(market.DealProposal)
|
|
|
|
if err := t.DealProposal.UnmarshalCBOR(br); err != nil {
|
|
|
|
return xerrors.Errorf("unmarshaling t.DealProposal pointer: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
2020-04-07 21:44:33 +00:00
|
|
|
// t.DealSchedule (sealing.DealSchedule) (struct)
|
|
|
|
case "DealSchedule":
|
2020-04-06 20:35:29 +00:00
|
|
|
|
|
|
|
{
|
2020-04-06 20:23:37 +00:00
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
if err := t.DealSchedule.UnmarshalCBOR(br); err != nil {
|
|
|
|
return xerrors.Errorf("unmarshaling t.DealSchedule: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-07-02 20:09:59 +00:00
|
|
|
// t.KeepUnsealed (bool) (bool)
|
|
|
|
case "KeepUnsealed":
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-07-02 20:09:59 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajOther {
|
|
|
|
return fmt.Errorf("booleans must be major type 7")
|
|
|
|
}
|
|
|
|
switch extra {
|
|
|
|
case 20:
|
|
|
|
t.KeepUnsealed = false
|
|
|
|
case 21:
|
|
|
|
t.KeepUnsealed = true
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("booleans are either major type 7, value 20 or 21 (got %d)", extra)
|
|
|
|
}
|
2020-04-07 21:44:33 +00:00
|
|
|
|
|
|
|
default:
|
2021-02-19 19:11:43 +00:00
|
|
|
// Field doesn't exist on this type, so ignore it
|
|
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
2020-04-07 21:44:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
func (t *DealSchedule) MarshalCBOR(w io.Writer) error {
|
|
|
|
if t == nil {
|
|
|
|
_, err := w.Write(cbg.CborNull)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := w.Write([]byte{162}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 9)
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
// t.StartEpoch (abi.ChainEpoch) (int64)
|
|
|
|
if len("StartEpoch") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"StartEpoch\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("StartEpoch"))); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("StartEpoch")); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.StartEpoch >= 0 {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.StartEpoch)); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajNegativeInt, uint64(-t.StartEpoch-1)); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.EndEpoch (abi.ChainEpoch) (int64)
|
|
|
|
if len("EndEpoch") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"EndEpoch\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("EndEpoch"))); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("EndEpoch")); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.EndEpoch >= 0 {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.EndEpoch)); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajNegativeInt, uint64(-t.EndEpoch-1)); err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *DealSchedule) UnmarshalCBOR(r io.Reader) error {
|
2020-08-12 02:47:24 +00:00
|
|
|
*t = DealSchedule{}
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
br := cbg.GetPeeker(r)
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 8)
|
2020-04-07 21:44:33 +00:00
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-07 21:44:33 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajMap {
|
|
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.MaxLength {
|
|
|
|
return fmt.Errorf("DealSchedule: map struct too large (%d)", extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
var name string
|
|
|
|
n := extra
|
|
|
|
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-07 21:44:33 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
name = string(sval)
|
|
|
|
}
|
|
|
|
|
|
|
|
switch name {
|
|
|
|
// t.StartEpoch (abi.ChainEpoch) (int64)
|
|
|
|
case "StartEpoch":
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-07 21:44:33 +00:00
|
|
|
var extraI int64
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
2020-04-07 21:44:33 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
switch maj {
|
|
|
|
case cbg.MajUnsignedInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 positive overflow")
|
|
|
|
}
|
|
|
|
case cbg.MajNegativeInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
|
|
}
|
|
|
|
extraI = -1 - extraI
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
t.StartEpoch = abi.ChainEpoch(extraI)
|
|
|
|
}
|
|
|
|
// t.EndEpoch (abi.ChainEpoch) (int64)
|
|
|
|
case "EndEpoch":
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-07 21:44:33 +00:00
|
|
|
var extraI int64
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
switch maj {
|
|
|
|
case cbg.MajUnsignedInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 positive overflow")
|
|
|
|
}
|
|
|
|
case cbg.MajNegativeInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
|
|
}
|
|
|
|
extraI = -1 - extraI
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
|
|
}
|
2020-04-06 20:35:29 +00:00
|
|
|
|
2020-04-07 21:44:33 +00:00
|
|
|
t.EndEpoch = abi.ChainEpoch(extraI)
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
default:
|
2021-02-19 19:11:43 +00:00
|
|
|
// Field doesn't exist on this type, so ignore it
|
|
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2020-01-15 20:49:11 +00:00
|
|
|
}
|
|
|
|
func (t *SectorInfo) MarshalCBOR(w io.Writer) error {
|
2020-04-06 20:35:29 +00:00
|
|
|
if t == nil {
|
|
|
|
_, err := w.Write(cbg.CborNull)
|
|
|
|
return err
|
|
|
|
}
|
2021-01-12 23:42:01 +00:00
|
|
|
if _, err := w.Write([]byte{184, 25}); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-01-22 02:41:39 +00:00
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 9)
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.State (sealing.SectorState) (string)
|
|
|
|
if len("State") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"State\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("State"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("State")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.State) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field t.State was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len(t.State))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string(t.State)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-06 22:31:33 +00:00
|
|
|
// t.SectorNumber (abi.SectorNumber) (uint64)
|
|
|
|
if len("SectorNumber") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"SectorNumber\" was too long")
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("SectorNumber"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("SectorNumber")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.SectorNumber)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-06-15 13:13:35 +00:00
|
|
|
// t.SectorType (abi.RegisteredSealProof) (int64)
|
2020-04-06 20:35:29 +00:00
|
|
|
if len("SectorType") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"SectorType\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("SectorType"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("SectorType")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.SectorType >= 0 {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.SectorType)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajNegativeInt, uint64(-t.SectorType-1)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-08 14:52:20 +00:00
|
|
|
// t.Pieces ([]sealing.Piece) (slice)
|
|
|
|
if len("Pieces") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Pieces\" was too long")
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Pieces"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Pieces")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-08 14:52:20 +00:00
|
|
|
if len(t.Pieces) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Slice value in field t.Pieces was too long")
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajArray, uint64(len(t.Pieces))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-04-08 14:52:20 +00:00
|
|
|
for _, v := range t.Pieces {
|
2020-04-06 20:35:29 +00:00
|
|
|
if err := v.MarshalCBOR(w); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.TicketValue (abi.SealRandomness) (slice)
|
|
|
|
if len("TicketValue") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"TicketValue\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("TicketValue"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("TicketValue")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.TicketValue) > cbg.ByteArrayMaxLen {
|
|
|
|
return xerrors.Errorf("Byte array in field t.TicketValue was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajByteString, uint64(len(t.TicketValue))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if _, err := w.Write(t.TicketValue[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.TicketEpoch (abi.ChainEpoch) (int64)
|
|
|
|
if len("TicketEpoch") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"TicketEpoch\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("TicketEpoch"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("TicketEpoch")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.TicketEpoch >= 0 {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.TicketEpoch)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajNegativeInt, uint64(-t.TicketEpoch-1)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.PreCommit1Out (storage.PreCommit1Out) (slice)
|
|
|
|
if len("PreCommit1Out") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"PreCommit1Out\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("PreCommit1Out"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("PreCommit1Out")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.PreCommit1Out) > cbg.ByteArrayMaxLen {
|
|
|
|
return xerrors.Errorf("Byte array in field t.PreCommit1Out was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajByteString, uint64(len(t.PreCommit1Out))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if _, err := w.Write(t.PreCommit1Out[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.CommD (cid.Cid) (struct)
|
|
|
|
if len("CommD") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"CommD\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("CommD"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("CommD")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.CommD == nil {
|
|
|
|
if _, err := w.Write(cbg.CborNull); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteCidBuf(scratch, w, *t.CommD); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return xerrors.Errorf("failed to write cid field t.CommD: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.CommR (cid.Cid) (struct)
|
|
|
|
if len("CommR") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"CommR\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("CommR"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("CommR")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.CommR == nil {
|
|
|
|
if _, err := w.Write(cbg.CborNull); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteCidBuf(scratch, w, *t.CommR); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return xerrors.Errorf("failed to write cid field t.CommR: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.Proof ([]uint8) (slice)
|
|
|
|
if len("Proof") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Proof\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Proof"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Proof")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.Proof) > cbg.ByteArrayMaxLen {
|
|
|
|
return xerrors.Errorf("Byte array in field t.Proof was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajByteString, uint64(len(t.Proof))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if _, err := w.Write(t.Proof[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-06-26 15:58:29 +00:00
|
|
|
// t.PreCommitInfo (miner.SectorPreCommitInfo) (struct)
|
|
|
|
if len("PreCommitInfo") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"PreCommitInfo\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("PreCommitInfo"))); err != nil {
|
2020-06-26 15:58:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("PreCommitInfo")); err != nil {
|
2020-06-26 15:58:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := t.PreCommitInfo.MarshalCBOR(w); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-07-01 14:33:59 +00:00
|
|
|
// t.PreCommitDeposit (big.Int) (struct)
|
|
|
|
if len("PreCommitDeposit") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"PreCommitDeposit\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("PreCommitDeposit"))); err != nil {
|
2020-07-01 14:33:59 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("PreCommitDeposit")); err != nil {
|
2020-07-01 14:33:59 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := t.PreCommitDeposit.MarshalCBOR(w); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.PreCommitMessage (cid.Cid) (struct)
|
|
|
|
if len("PreCommitMessage") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"PreCommitMessage\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("PreCommitMessage"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("PreCommitMessage")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.PreCommitMessage == nil {
|
|
|
|
if _, err := w.Write(cbg.CborNull); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteCidBuf(scratch, w, *t.PreCommitMessage); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return xerrors.Errorf("failed to write cid field t.PreCommitMessage: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-02 20:30:40 +00:00
|
|
|
// t.PreCommitTipSet (sealing.TipSetToken) (slice)
|
|
|
|
if len("PreCommitTipSet") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"PreCommitTipSet\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("PreCommitTipSet"))); err != nil {
|
2020-06-02 20:30:40 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("PreCommitTipSet")); err != nil {
|
2020-06-02 20:30:40 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.PreCommitTipSet) > cbg.ByteArrayMaxLen {
|
|
|
|
return xerrors.Errorf("Byte array in field t.PreCommitTipSet was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajByteString, uint64(len(t.PreCommitTipSet))); err != nil {
|
2020-06-02 20:30:40 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if _, err := w.Write(t.PreCommitTipSet[:]); err != nil {
|
2020-06-02 20:30:40 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-06-04 15:29:31 +00:00
|
|
|
// t.PreCommit2Fails (uint64) (uint64)
|
|
|
|
if len("PreCommit2Fails") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"PreCommit2Fails\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("PreCommit2Fails"))); err != nil {
|
2020-06-04 15:29:31 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("PreCommit2Fails")); err != nil {
|
2020-06-04 15:29:31 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.PreCommit2Fails)); err != nil {
|
2020-06-04 15:29:31 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.SeedValue (abi.InteractiveSealRandomness) (slice)
|
|
|
|
if len("SeedValue") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"SeedValue\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("SeedValue"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("SeedValue")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.SeedValue) > cbg.ByteArrayMaxLen {
|
|
|
|
return xerrors.Errorf("Byte array in field t.SeedValue was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajByteString, uint64(len(t.SeedValue))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if _, err := w.Write(t.SeedValue[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.SeedEpoch (abi.ChainEpoch) (int64)
|
|
|
|
if len("SeedEpoch") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"SeedEpoch\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("SeedEpoch"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("SeedEpoch")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.SeedEpoch >= 0 {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.SeedEpoch)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajNegativeInt, uint64(-t.SeedEpoch-1)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.CommitMessage (cid.Cid) (struct)
|
|
|
|
if len("CommitMessage") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"CommitMessage\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("CommitMessage"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("CommitMessage")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.CommitMessage == nil {
|
|
|
|
if _, err := w.Write(cbg.CborNull); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteCidBuf(scratch, w, *t.CommitMessage); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return xerrors.Errorf("failed to write cid field t.CommitMessage: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.InvalidProofs (uint64) (uint64)
|
|
|
|
if len("InvalidProofs") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"InvalidProofs\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("InvalidProofs"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("InvalidProofs")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.InvalidProofs)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.FaultReportMsg (cid.Cid) (struct)
|
|
|
|
if len("FaultReportMsg") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"FaultReportMsg\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("FaultReportMsg"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("FaultReportMsg")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.FaultReportMsg == nil {
|
|
|
|
if _, err := w.Write(cbg.CborNull); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteCidBuf(scratch, w, *t.FaultReportMsg); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return xerrors.Errorf("failed to write cid field t.FaultReportMsg: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-27 19:04:43 +00:00
|
|
|
// t.Return (sealing.ReturnState) (string)
|
|
|
|
if len("Return") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Return\" was too long")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Return"))); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := io.WriteString(w, string("Return")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.Return) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field t.Return was too long")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len(t.Return))); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := io.WriteString(w, string(t.Return)); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-01-12 23:42:01 +00:00
|
|
|
// t.TerminateMessage (cid.Cid) (struct)
|
|
|
|
if len("TerminateMessage") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"TerminateMessage\" was too long")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("TerminateMessage"))); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := io.WriteString(w, string("TerminateMessage")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.TerminateMessage == nil {
|
|
|
|
if _, err := w.Write(cbg.CborNull); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if err := cbg.WriteCidBuf(scratch, w, *t.TerminateMessage); err != nil {
|
|
|
|
return xerrors.Errorf("failed to write cid field t.TerminateMessage: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.TerminatedAt (abi.ChainEpoch) (int64)
|
|
|
|
if len("TerminatedAt") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"TerminatedAt\" was too long")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("TerminatedAt"))); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := io.WriteString(w, string("TerminatedAt")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if t.TerminatedAt >= 0 {
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.TerminatedAt)); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajNegativeInt, uint64(-t.TerminatedAt-1)); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.LastErr (string) (string)
|
|
|
|
if len("LastErr") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"LastErr\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("LastErr"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("LastErr")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.LastErr) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field t.LastErr was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len(t.LastErr))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string(t.LastErr)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.Log ([]sealing.Log) (slice)
|
|
|
|
if len("Log") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Log\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Log"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Log")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.Log) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Slice value in field t.Log was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajArray, uint64(len(t.Log))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
for _, v := range t.Log {
|
|
|
|
if err := v.MarshalCBOR(w); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
2020-01-22 02:41:39 +00:00
|
|
|
return nil
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *SectorInfo) UnmarshalCBOR(r io.Reader) error {
|
2020-08-12 02:47:24 +00:00
|
|
|
*t = SectorInfo{}
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
br := cbg.GetPeeker(r)
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 8)
|
2020-04-06 20:35:29 +00:00
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajMap {
|
|
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.MaxLength {
|
|
|
|
return fmt.Errorf("SectorInfo: map struct too large (%d)", extra)
|
|
|
|
}
|
2020-04-06 20:23:37 +00:00
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
var name string
|
|
|
|
n := extra
|
|
|
|
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
name = string(sval)
|
|
|
|
}
|
|
|
|
|
|
|
|
switch name {
|
|
|
|
// t.State (sealing.SectorState) (string)
|
|
|
|
case "State":
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.State = SectorState(sval)
|
|
|
|
}
|
2020-04-06 22:31:33 +00:00
|
|
|
// t.SectorNumber (abi.SectorNumber) (uint64)
|
|
|
|
case "SectorNumber":
|
2020-04-06 20:35:29 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajUnsignedInt {
|
|
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
|
|
}
|
2020-04-06 22:31:33 +00:00
|
|
|
t.SectorNumber = abi.SectorNumber(extra)
|
2020-04-06 20:35:29 +00:00
|
|
|
|
|
|
|
}
|
2020-06-15 13:13:35 +00:00
|
|
|
// t.SectorType (abi.RegisteredSealProof) (int64)
|
2020-04-06 20:35:29 +00:00
|
|
|
case "SectorType":
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
var extraI int64
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
switch maj {
|
|
|
|
case cbg.MajUnsignedInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 positive overflow")
|
|
|
|
}
|
|
|
|
case cbg.MajNegativeInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
|
|
}
|
|
|
|
extraI = -1 - extraI
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
|
|
}
|
|
|
|
|
2020-06-15 13:13:35 +00:00
|
|
|
t.SectorType = abi.RegisteredSealProof(extraI)
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
2020-04-08 14:52:20 +00:00
|
|
|
// t.Pieces ([]sealing.Piece) (slice)
|
|
|
|
case "Pieces":
|
2020-04-06 20:35:29 +00:00
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.MaxLength {
|
2020-04-08 14:52:20 +00:00
|
|
|
return fmt.Errorf("t.Pieces: array too large (%d)", extra)
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if maj != cbg.MajArray {
|
|
|
|
return fmt.Errorf("expected cbor array")
|
|
|
|
}
|
2020-06-02 20:30:40 +00:00
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
if extra > 0 {
|
2020-04-08 14:52:20 +00:00
|
|
|
t.Pieces = make([]Piece, extra)
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
2020-06-02 20:30:40 +00:00
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
for i := 0; i < int(extra); i++ {
|
|
|
|
|
2020-04-08 14:52:20 +00:00
|
|
|
var v Piece
|
2020-04-06 20:35:29 +00:00
|
|
|
if err := v.UnmarshalCBOR(br); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-08 14:52:20 +00:00
|
|
|
t.Pieces[i] = v
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// t.TicketValue (abi.SealRandomness) (slice)
|
|
|
|
case "TicketValue":
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.ByteArrayMaxLen {
|
|
|
|
return fmt.Errorf("t.TicketValue: byte array too large (%d)", extra)
|
|
|
|
}
|
|
|
|
if maj != cbg.MajByteString {
|
|
|
|
return fmt.Errorf("expected byte array")
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if extra > 0 {
|
|
|
|
t.TicketValue = make([]uint8, extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := io.ReadFull(br, t.TicketValue[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
// t.TicketEpoch (abi.ChainEpoch) (int64)
|
|
|
|
case "TicketEpoch":
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
var extraI int64
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
switch maj {
|
|
|
|
case cbg.MajUnsignedInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 positive overflow")
|
|
|
|
}
|
|
|
|
case cbg.MajNegativeInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
|
|
}
|
|
|
|
extraI = -1 - extraI
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.TicketEpoch = abi.ChainEpoch(extraI)
|
|
|
|
}
|
|
|
|
// t.PreCommit1Out (storage.PreCommit1Out) (slice)
|
|
|
|
case "PreCommit1Out":
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.ByteArrayMaxLen {
|
|
|
|
return fmt.Errorf("t.PreCommit1Out: byte array too large (%d)", extra)
|
|
|
|
}
|
|
|
|
if maj != cbg.MajByteString {
|
|
|
|
return fmt.Errorf("expected byte array")
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if extra > 0 {
|
|
|
|
t.PreCommit1Out = make([]uint8, extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := io.ReadFull(br, t.PreCommit1Out[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
// t.CommD (cid.Cid) (struct)
|
|
|
|
case "CommD":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
b, err := br.ReadByte()
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("failed to read cid field t.CommD: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.CommD = &c
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.CommR (cid.Cid) (struct)
|
|
|
|
case "CommR":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
b, err := br.ReadByte()
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("failed to read cid field t.CommR: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.CommR = &c
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.Proof ([]uint8) (slice)
|
|
|
|
case "Proof":
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.ByteArrayMaxLen {
|
|
|
|
return fmt.Errorf("t.Proof: byte array too large (%d)", extra)
|
|
|
|
}
|
|
|
|
if maj != cbg.MajByteString {
|
|
|
|
return fmt.Errorf("expected byte array")
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if extra > 0 {
|
|
|
|
t.Proof = make([]uint8, extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := io.ReadFull(br, t.Proof[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-06-26 15:58:29 +00:00
|
|
|
// t.PreCommitInfo (miner.SectorPreCommitInfo) (struct)
|
|
|
|
case "PreCommitInfo":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
b, err := br.ReadByte()
|
2020-06-26 15:58:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
2020-06-26 15:58:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
t.PreCommitInfo = new(miner.SectorPreCommitInfo)
|
|
|
|
if err := t.PreCommitInfo.UnmarshalCBOR(br); err != nil {
|
|
|
|
return xerrors.Errorf("unmarshaling t.PreCommitInfo pointer: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-01 14:33:59 +00:00
|
|
|
}
|
|
|
|
// t.PreCommitDeposit (big.Int) (struct)
|
|
|
|
case "PreCommitDeposit":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if err := t.PreCommitDeposit.UnmarshalCBOR(br); err != nil {
|
|
|
|
return xerrors.Errorf("unmarshaling t.PreCommitDeposit: %w", err)
|
|
|
|
}
|
|
|
|
|
2020-06-26 15:58:29 +00:00
|
|
|
}
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.PreCommitMessage (cid.Cid) (struct)
|
|
|
|
case "PreCommitMessage":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
b, err := br.ReadByte()
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("failed to read cid field t.PreCommitMessage: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.PreCommitMessage = &c
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-06-02 20:30:40 +00:00
|
|
|
// t.PreCommitTipSet (sealing.TipSetToken) (slice)
|
|
|
|
case "PreCommitTipSet":
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-06-02 20:30:40 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.ByteArrayMaxLen {
|
|
|
|
return fmt.Errorf("t.PreCommitTipSet: byte array too large (%d)", extra)
|
|
|
|
}
|
|
|
|
if maj != cbg.MajByteString {
|
|
|
|
return fmt.Errorf("expected byte array")
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if extra > 0 {
|
|
|
|
t.PreCommitTipSet = make([]uint8, extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := io.ReadFull(br, t.PreCommitTipSet[:]); err != nil {
|
2020-06-02 20:30:40 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-06-04 15:29:31 +00:00
|
|
|
// t.PreCommit2Fails (uint64) (uint64)
|
|
|
|
case "PreCommit2Fails":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-06-04 15:29:31 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajUnsignedInt {
|
|
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
|
|
}
|
|
|
|
t.PreCommit2Fails = uint64(extra)
|
|
|
|
|
|
|
|
}
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.SeedValue (abi.InteractiveSealRandomness) (slice)
|
|
|
|
case "SeedValue":
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.ByteArrayMaxLen {
|
|
|
|
return fmt.Errorf("t.SeedValue: byte array too large (%d)", extra)
|
|
|
|
}
|
|
|
|
if maj != cbg.MajByteString {
|
|
|
|
return fmt.Errorf("expected byte array")
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
|
|
|
|
if extra > 0 {
|
|
|
|
t.SeedValue = make([]uint8, extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := io.ReadFull(br, t.SeedValue[:]); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
// t.SeedEpoch (abi.ChainEpoch) (int64)
|
|
|
|
case "SeedEpoch":
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
var extraI int64
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
switch maj {
|
|
|
|
case cbg.MajUnsignedInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 positive overflow")
|
|
|
|
}
|
|
|
|
case cbg.MajNegativeInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
|
|
}
|
|
|
|
extraI = -1 - extraI
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.SeedEpoch = abi.ChainEpoch(extraI)
|
|
|
|
}
|
|
|
|
// t.CommitMessage (cid.Cid) (struct)
|
|
|
|
case "CommitMessage":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
b, err := br.ReadByte()
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("failed to read cid field t.CommitMessage: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.CommitMessage = &c
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.InvalidProofs (uint64) (uint64)
|
|
|
|
case "InvalidProofs":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajUnsignedInt {
|
|
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
|
|
}
|
|
|
|
t.InvalidProofs = uint64(extra)
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.FaultReportMsg (cid.Cid) (struct)
|
|
|
|
case "FaultReportMsg":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
b, err := br.ReadByte()
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("failed to read cid field t.FaultReportMsg: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.FaultReportMsg = &c
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-08-27 19:04:43 +00:00
|
|
|
// t.Return (sealing.ReturnState) (string)
|
|
|
|
case "Return":
|
|
|
|
|
|
|
|
{
|
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Return = ReturnState(sval)
|
|
|
|
}
|
2021-01-12 23:42:01 +00:00
|
|
|
// t.TerminateMessage (cid.Cid) (struct)
|
|
|
|
case "TerminateMessage":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
b, err := br.ReadByte()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if b != cbg.CborNull[0] {
|
|
|
|
if err := br.UnreadByte(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := cbg.ReadCid(br)
|
|
|
|
if err != nil {
|
|
|
|
return xerrors.Errorf("failed to read cid field t.TerminateMessage: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.TerminateMessage = &c
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.TerminatedAt (abi.ChainEpoch) (int64)
|
|
|
|
case "TerminatedAt":
|
|
|
|
{
|
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
|
|
|
var extraI int64
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
switch maj {
|
|
|
|
case cbg.MajUnsignedInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 positive overflow")
|
|
|
|
}
|
|
|
|
case cbg.MajNegativeInt:
|
|
|
|
extraI = int64(extra)
|
|
|
|
if extraI < 0 {
|
|
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
|
|
}
|
|
|
|
extraI = -1 - extraI
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
|
|
}
|
|
|
|
|
|
|
|
t.TerminatedAt = abi.ChainEpoch(extraI)
|
|
|
|
}
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.LastErr (string) (string)
|
|
|
|
case "LastErr":
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.LastErr = string(sval)
|
|
|
|
}
|
|
|
|
// t.Log ([]sealing.Log) (slice)
|
|
|
|
case "Log":
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if extra > cbg.MaxLength {
|
2020-04-06 20:35:29 +00:00
|
|
|
return fmt.Errorf("t.Log: array too large (%d)", extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
if maj != cbg.MajArray {
|
|
|
|
return fmt.Errorf("expected cbor array")
|
|
|
|
}
|
2020-06-02 20:30:40 +00:00
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
if extra > 0 {
|
|
|
|
t.Log = make([]Log, extra)
|
|
|
|
}
|
2020-06-02 20:30:40 +00:00
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
for i := 0; i < int(extra); i++ {
|
|
|
|
|
|
|
|
var v Log
|
|
|
|
if err := v.UnmarshalCBOR(br); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Log[i] = v
|
|
|
|
}
|
|
|
|
|
|
|
|
default:
|
2021-02-19 19:11:43 +00:00
|
|
|
// Field doesn't exist on this type, so ignore it
|
|
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2020-01-22 02:41:39 +00:00
|
|
|
}
|
|
|
|
func (t *Log) MarshalCBOR(w io.Writer) error {
|
2020-04-06 20:35:29 +00:00
|
|
|
if t == nil {
|
|
|
|
_, err := w.Write(cbg.CborNull)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := w.Write([]byte{164}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 9)
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
// t.Timestamp (uint64) (uint64)
|
|
|
|
if len("Timestamp") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Timestamp\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Timestamp"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Timestamp")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajUnsignedInt, uint64(t.Timestamp)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.Trace (string) (string)
|
|
|
|
if len("Trace") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Trace\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Trace"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Trace")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.Trace) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field t.Trace was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len(t.Trace))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string(t.Trace)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.Message (string) (string)
|
|
|
|
if len("Message") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Message\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Message"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Message")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.Message) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field t.Message was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len(t.Message))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string(t.Message)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// t.Kind (string) (string)
|
|
|
|
if len("Kind") > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field \"Kind\" was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len("Kind"))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string("Kind")); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(t.Kind) > cbg.MaxLength {
|
|
|
|
return xerrors.Errorf("Value in field t.Kind was too long")
|
|
|
|
}
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
if err := cbg.WriteMajorTypeHeaderBuf(scratch, w, cbg.MajTextString, uint64(len(t.Kind))); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-08-12 02:47:24 +00:00
|
|
|
if _, err := io.WriteString(w, string(t.Kind)); err != nil {
|
2020-04-06 20:35:29 +00:00
|
|
|
return err
|
|
|
|
}
|
2020-01-22 02:41:39 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *Log) UnmarshalCBOR(r io.Reader) error {
|
2020-08-12 02:47:24 +00:00
|
|
|
*t = Log{}
|
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
br := cbg.GetPeeker(r)
|
2020-08-12 02:47:24 +00:00
|
|
|
scratch := make([]byte, 8)
|
2020-04-06 20:35:29 +00:00
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err := cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajMap {
|
|
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
|
|
}
|
|
|
|
|
|
|
|
if extra > cbg.MaxLength {
|
|
|
|
return fmt.Errorf("Log: map struct too large (%d)", extra)
|
|
|
|
}
|
|
|
|
|
|
|
|
var name string
|
|
|
|
n := extra
|
|
|
|
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
name = string(sval)
|
|
|
|
}
|
2020-04-06 20:23:37 +00:00
|
|
|
|
2020-04-06 20:35:29 +00:00
|
|
|
switch name {
|
|
|
|
// t.Timestamp (uint64) (uint64)
|
|
|
|
case "Timestamp":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
2020-08-12 02:47:24 +00:00
|
|
|
maj, extra, err = cbg.CborReadHeaderBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if maj != cbg.MajUnsignedInt {
|
|
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
|
|
}
|
|
|
|
t.Timestamp = uint64(extra)
|
|
|
|
|
|
|
|
}
|
|
|
|
// t.Trace (string) (string)
|
|
|
|
case "Trace":
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Trace = string(sval)
|
|
|
|
}
|
|
|
|
// t.Message (string) (string)
|
|
|
|
case "Message":
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Message = string(sval)
|
|
|
|
}
|
|
|
|
// t.Kind (string) (string)
|
|
|
|
case "Kind":
|
|
|
|
|
|
|
|
{
|
2020-08-12 02:47:24 +00:00
|
|
|
sval, err := cbg.ReadStringBuf(br, scratch)
|
2020-04-06 20:35:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Kind = string(sval)
|
|
|
|
}
|
|
|
|
|
|
|
|
default:
|
2021-02-19 19:11:43 +00:00
|
|
|
// Field doesn't exist on this type, so ignore it
|
|
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
2020-04-06 20:35:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2020-01-15 20:49:11 +00:00
|
|
|
}
|