mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-24 09:24:36 +00:00
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:
parent
7f1690a840
commit
db820cb0dc
1 changed files with 10 additions and 19 deletions
|
@ -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")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue