manifest: rework method duplicate check

Don't use an additional type, it's inconvenient and this method is not
performance-critical.

Signed-off-by: Roman Khimov <roman@nspcc.ru>
This commit is contained in:
Roman Khimov 2024-08-26 19:50:50 +03:00
parent 7f1690a840
commit db820cb0dc

View file

@ -1,9 +1,10 @@
package manifest package manifest
import ( import (
"cmp"
"errors" "errors"
"fmt" "fmt"
"sort" "slices"
"github.com/nspcc-dev/neo-go/pkg/vm/stackitem" "github.com/nspcc-dev/neo-go/pkg/vm/stackitem"
) )
@ -63,29 +64,19 @@ func (a *ABI) IsValid() error {
} }
} }
if len(a.Methods) > 1 { if len(a.Methods) > 1 {
methods := make([]struct { var methods = slices.Clone(a.Methods)
name string slices.SortFunc(methods, func(a, b Method) int {
params int return cmp.Or(
}, len(a.Methods)) cmp.Compare(a.Name, b.Name),
for i := range methods { cmp.Compare(len(a.Parameters), len(b.Parameters)),
methods[i].name = a.Methods[i].Name )
methods[i].params = len(a.Methods[i].Parameters)
}
sort.Slice(methods, func(i, j int) bool {
if methods[i].name < methods[j].name {
return true
}
if methods[i].name == methods[j].name {
return methods[i].params < methods[j].params
}
return false
}) })
for i := range methods { for i := range methods {
if i == 0 { if i == 0 {
continue continue
} }
if methods[i].name == methods[i-1].name && if methods[i].Name == methods[i-1].Name &&
methods[i].params == methods[i-1].params { len(methods[i].Parameters) == len(methods[i-1].Parameters) {
return errors.New("duplicate method specifications") return errors.New("duplicate method specifications")
} }
} }