5733c71c50
We were ignoring quite a few error cases, and had one case where we weren't actually updating state where we wanted to. Unfortunately, if the linter doesn't pass, nobody has any reason to actually check lint failures in CI. There are three remaining XXXs marked in the code for lint.
41 lines
936 B
Go
41 lines
936 B
Go
package validation
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/filecoin-project/lotus/chain/state"
|
|
"github.com/filecoin-project/specs-actors/actors/runtime"
|
|
cbor "github.com/ipfs/go-ipld-cbor"
|
|
|
|
vstate "github.com/filecoin-project/chain-validation/state"
|
|
)
|
|
|
|
type Factories struct {
|
|
*Applier
|
|
}
|
|
|
|
var _ vstate.Factories = &Factories{}
|
|
|
|
func NewFactories() *Factories {
|
|
return &Factories{}
|
|
}
|
|
|
|
func (f *Factories) NewStateAndApplier(syscalls runtime.Syscalls) (vstate.VMWrapper, vstate.Applier) {
|
|
st := NewState()
|
|
return st, NewApplier(st, func(ctx context.Context, cstate *state.StateTree, cst cbor.IpldStore) runtime.Syscalls {
|
|
return syscalls
|
|
})
|
|
}
|
|
|
|
func (f *Factories) NewKeyManager() vstate.KeyManager {
|
|
return newKeyManager()
|
|
}
|
|
|
|
func (f *Factories) NewValidationConfig() vstate.ValidationConfig {
|
|
trackGas := true
|
|
checkExit := true
|
|
checkRet := true
|
|
checkState := true
|
|
return NewConfig(trackGas, checkExit, checkRet, checkState)
|
|
}
|