Use abi.MethodNum instead of uint64 for method nums
This commit is contained in:
parent
59431631aa
commit
e1926a06e8
@ -7,6 +7,7 @@ import (
|
|||||||
|
|
||||||
"github.com/ipfs/go-cid"
|
"github.com/ipfs/go-cid"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/go-state-types/abi"
|
||||||
actorstypes "github.com/filecoin-project/go-state-types/actors"
|
actorstypes "github.com/filecoin-project/go-state-types/actors"
|
||||||
"github.com/filecoin-project/go-state-types/builtin"
|
"github.com/filecoin-project/go-state-types/builtin"
|
||||||
account10 "github.com/filecoin-project/go-state-types/builtin/v10/account"
|
account10 "github.com/filecoin-project/go-state-types/builtin/v10/account"
|
||||||
@ -53,14 +54,14 @@ import (
|
|||||||
type RegistryEntry struct {
|
type RegistryEntry struct {
|
||||||
state cbor.Er
|
state cbor.Er
|
||||||
code cid.Cid
|
code cid.Cid
|
||||||
methods map[uint64]builtin.MethodMeta
|
methods map[abi.MethodNum]builtin.MethodMeta
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r RegistryEntry) State() cbor.Er {
|
func (r RegistryEntry) State() cbor.Er {
|
||||||
return r.state
|
return r.state
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r RegistryEntry) Exports() map[uint64]builtin.MethodMeta {
|
func (r RegistryEntry) Exports() map[abi.MethodNum]builtin.MethodMeta {
|
||||||
return r.methods
|
return r.methods
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,10 +73,10 @@ func MakeRegistryLegacy(actors []rtt.VMActor) []RegistryEntry {
|
|||||||
registry := make([]RegistryEntry, 0)
|
registry := make([]RegistryEntry, 0)
|
||||||
|
|
||||||
for _, actor := range actors {
|
for _, actor := range actors {
|
||||||
methodMap := make(map[uint64]builtin.MethodMeta)
|
methodMap := make(map[abi.MethodNum]builtin.MethodMeta)
|
||||||
for methodNum, method := range actor.Exports() {
|
for methodNum, method := range actor.Exports() {
|
||||||
if method != nil {
|
if method != nil {
|
||||||
methodMap[uint64(methodNum)] = makeMethodMeta(method)
|
methodMap[abi.MethodNum(methodNum)] = makeMethodMeta(method)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
registry = append(registry, RegistryEntry{
|
registry = append(registry, RegistryEntry{
|
||||||
|
@ -29,19 +29,20 @@ import (
|
|||||||
"github.com/filecoin-project/go-state-types/cbor"
|
"github.com/filecoin-project/go-state-types/cbor"
|
||||||
rtt "github.com/filecoin-project/go-state-types/rt"
|
rtt "github.com/filecoin-project/go-state-types/rt"
|
||||||
"github.com/filecoin-project/lotus/chain/actors"
|
"github.com/filecoin-project/lotus/chain/actors"
|
||||||
|
"github.com/filecoin-project/go-state-types/abi"
|
||||||
)
|
)
|
||||||
|
|
||||||
type RegistryEntry struct {
|
type RegistryEntry struct {
|
||||||
state cbor.Er
|
state cbor.Er
|
||||||
code cid.Cid
|
code cid.Cid
|
||||||
methods map[uint64]builtin.MethodMeta
|
methods map[abi.MethodNum]builtin.MethodMeta
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r RegistryEntry) State() cbor.Er {
|
func (r RegistryEntry) State() cbor.Er {
|
||||||
return r.state
|
return r.state
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r RegistryEntry) Exports() map[uint64]builtin.MethodMeta {
|
func (r RegistryEntry) Exports() map[abi.MethodNum]builtin.MethodMeta {
|
||||||
return r.methods
|
return r.methods
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -53,10 +54,10 @@ func MakeRegistryLegacy(actors []rtt.VMActor) []RegistryEntry {
|
|||||||
registry := make([]RegistryEntry, 0)
|
registry := make([]RegistryEntry, 0)
|
||||||
|
|
||||||
for _, actor := range actors {
|
for _, actor := range actors {
|
||||||
methodMap := make(map[uint64]builtin.MethodMeta)
|
methodMap := make(map[abi.MethodNum]builtin.MethodMeta)
|
||||||
for methodNum, method := range actor.Exports() {
|
for methodNum, method := range actor.Exports() {
|
||||||
if method != nil {
|
if method != nil {
|
||||||
methodMap[uint64(methodNum)] = makeMethodMeta(method)
|
methodMap[abi.MethodNum(methodNum)] = makeMethodMeta(method)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
registry = append(registry, RegistryEntry{
|
registry = append(registry, RegistryEntry{
|
||||||
|
@ -53,7 +53,7 @@ func ActorsVersionPredicate(ver actorstypes.Version) ActorPredicate {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type invokeFunc func(rt vmr.Runtime, params []byte) ([]byte, aerrors.ActorError)
|
type invokeFunc func(rt vmr.Runtime, params []byte) ([]byte, aerrors.ActorError)
|
||||||
type nativeCode map[uint64]invokeFunc
|
type nativeCode map[abi.MethodNum]invokeFunc
|
||||||
|
|
||||||
type actorInfo struct {
|
type actorInfo struct {
|
||||||
methods nativeCode
|
methods nativeCode
|
||||||
@ -78,10 +78,10 @@ func (ar *ActorRegistry) Invoke(codeCid cid.Cid, rt vmr.Runtime, method abi.Meth
|
|||||||
if err := act.predicate(rt, codeCid); err != nil {
|
if err := act.predicate(rt, codeCid); err != nil {
|
||||||
return nil, aerrors.Newf(exitcode.SysErrorIllegalActor, "unsupported actor: %s", err)
|
return nil, aerrors.Newf(exitcode.SysErrorIllegalActor, "unsupported actor: %s", err)
|
||||||
}
|
}
|
||||||
if act.methods[uint64(method)] == nil {
|
if act.methods[method] == nil {
|
||||||
return nil, aerrors.Newf(exitcode.SysErrInvalidMethod, "no method %d on actor", method)
|
return nil, aerrors.Newf(exitcode.SysErrInvalidMethod, "no method %d on actor", method)
|
||||||
}
|
}
|
||||||
return act.methods[uint64(method)](rt, params)
|
return act.methods[method](rt, params)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -156,7 +156,7 @@ func (ar *ActorRegistry) Register(av actorstypes.Version, pred ActorPredicate, v
|
|||||||
mm.Params = et.In(0)
|
mm.Params = et.In(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
methods[abi.MethodNum(number)] = mm
|
methods[number] = mm
|
||||||
}
|
}
|
||||||
if realCode.Defined() {
|
if realCode.Defined() {
|
||||||
ar.Methods[realCode] = methods
|
ar.Methods[realCode] = methods
|
||||||
@ -185,7 +185,7 @@ func (ar *ActorRegistry) Create(codeCid cid.Cid, rt vmr.Runtime) (*types.Actor,
|
|||||||
}
|
}
|
||||||
|
|
||||||
type invokee interface {
|
type invokee interface {
|
||||||
Exports() map[uint64]builtinst.MethodMeta
|
Exports() map[abi.MethodNum]builtinst.MethodMeta
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*ActorRegistry) transform(instance invokee) (nativeCode, error) {
|
func (*ActorRegistry) transform(instance invokee) (nativeCode, error) {
|
||||||
|
2
go.mod
2
go.mod
@ -43,7 +43,7 @@ require (
|
|||||||
github.com/filecoin-project/go-legs v0.4.4
|
github.com/filecoin-project/go-legs v0.4.4
|
||||||
github.com/filecoin-project/go-padreader v0.0.1
|
github.com/filecoin-project/go-padreader v0.0.1
|
||||||
github.com/filecoin-project/go-paramfetch v0.0.4
|
github.com/filecoin-project/go-paramfetch v0.0.4
|
||||||
github.com/filecoin-project/go-state-types v0.10.0-alpha-3
|
github.com/filecoin-project/go-state-types v0.10.0-alpha-4
|
||||||
github.com/filecoin-project/go-statemachine v1.0.2
|
github.com/filecoin-project/go-statemachine v1.0.2
|
||||||
github.com/filecoin-project/go-statestore v0.2.0
|
github.com/filecoin-project/go-statestore v0.2.0
|
||||||
github.com/filecoin-project/go-storedcounter v0.1.0
|
github.com/filecoin-project/go-storedcounter v0.1.0
|
||||||
|
4
go.sum
4
go.sum
@ -356,8 +356,8 @@ github.com/filecoin-project/go-state-types v0.1.0/go.mod h1:ezYnPf0bNkTsDibL/psS
|
|||||||
github.com/filecoin-project/go-state-types v0.1.6/go.mod h1:UwGVoMsULoCK+bWjEdd/xLCvLAQFBC7EDT477SKml+Q=
|
github.com/filecoin-project/go-state-types v0.1.6/go.mod h1:UwGVoMsULoCK+bWjEdd/xLCvLAQFBC7EDT477SKml+Q=
|
||||||
github.com/filecoin-project/go-state-types v0.1.8/go.mod h1:UwGVoMsULoCK+bWjEdd/xLCvLAQFBC7EDT477SKml+Q=
|
github.com/filecoin-project/go-state-types v0.1.8/go.mod h1:UwGVoMsULoCK+bWjEdd/xLCvLAQFBC7EDT477SKml+Q=
|
||||||
github.com/filecoin-project/go-state-types v0.1.10/go.mod h1:UwGVoMsULoCK+bWjEdd/xLCvLAQFBC7EDT477SKml+Q=
|
github.com/filecoin-project/go-state-types v0.1.10/go.mod h1:UwGVoMsULoCK+bWjEdd/xLCvLAQFBC7EDT477SKml+Q=
|
||||||
github.com/filecoin-project/go-state-types v0.10.0-alpha-3 h1:8iM9uz+rWRbrg1Zet+YlTJN4XEPNqRkqa3zay2pwV7w=
|
github.com/filecoin-project/go-state-types v0.10.0-alpha-4 h1:qFuw0C+ShmpyRTpJIYAB+u11F6fYqI/4vU138EFc3ps=
|
||||||
github.com/filecoin-project/go-state-types v0.10.0-alpha-3/go.mod h1:FPgQE05BFwZxKw/vCuIaIrzfJKo4RPQQMMPGd43dAFI=
|
github.com/filecoin-project/go-state-types v0.10.0-alpha-4/go.mod h1:FPgQE05BFwZxKw/vCuIaIrzfJKo4RPQQMMPGd43dAFI=
|
||||||
github.com/filecoin-project/go-statemachine v0.0.0-20200925024713-05bd7c71fbfe/go.mod h1:FGwQgZAt2Gh5mjlwJUlVB62JeYdo+if0xWxSEfBD9ig=
|
github.com/filecoin-project/go-statemachine v0.0.0-20200925024713-05bd7c71fbfe/go.mod h1:FGwQgZAt2Gh5mjlwJUlVB62JeYdo+if0xWxSEfBD9ig=
|
||||||
github.com/filecoin-project/go-statemachine v1.0.2 h1:421SSWBk8GIoCoWYYTE/d+qCWccgmRH0uXotXRDjUbc=
|
github.com/filecoin-project/go-statemachine v1.0.2 h1:421SSWBk8GIoCoWYYTE/d+qCWccgmRH0uXotXRDjUbc=
|
||||||
github.com/filecoin-project/go-statemachine v1.0.2/go.mod h1:jZdXXiHa61n4NmgWFG4w8tnqgvZVHYbJ3yW7+y8bF54=
|
github.com/filecoin-project/go-statemachine v1.0.2/go.mod h1:jZdXXiHa61n4NmgWFG4w8tnqgvZVHYbJ3yW7+y8bF54=
|
||||||
|
Loading…
Reference in New Issue
Block a user