mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-04 23:35:49 +00:00
*: use slices package for sorting and searching
Signed-off-by: Roman Khimov <roman@nspcc.ru>
This commit is contained in:
parent
6581bd47fc
commit
a1a7e3d708
30 changed files with 158 additions and 181 deletions
|
@ -2,9 +2,10 @@ package query
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"cmp"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"fmt"
|
"fmt"
|
||||||
"sort"
|
"slices"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"text/tabwriter"
|
"text/tabwriter"
|
||||||
|
@ -192,14 +193,18 @@ func queryCandidates(ctx *cli.Context) error {
|
||||||
return cli.Exit(err, 1)
|
return cli.Exit(err, 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
sort.Slice(vals, func(i, j int) bool {
|
slices.SortFunc(vals, func(a, b result.Candidate) int {
|
||||||
if vals[i].Active != vals[j].Active {
|
if a.Active && !b.Active {
|
||||||
return vals[i].Active
|
return 1
|
||||||
}
|
}
|
||||||
if vals[i].Votes != vals[j].Votes {
|
if !a.Active && b.Active {
|
||||||
return vals[i].Votes > vals[j].Votes
|
return -1
|
||||||
}
|
}
|
||||||
return vals[i].PublicKey.Cmp(&vals[j].PublicKey) == -1
|
res := cmp.Compare(a.Votes, b.Votes)
|
||||||
|
if res != 0 {
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
return a.PublicKey.Cmp(&b.PublicKey)
|
||||||
})
|
})
|
||||||
var res []byte
|
var res []byte
|
||||||
res = fmt.Appendf(res, "Key\tVotes\tCommittee\tConsensus\n")
|
res = fmt.Appendf(res, "Key\tVotes\tCommittee\tConsensus\n")
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package compiler
|
package compiler
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"cmp"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
@ -10,7 +11,7 @@ import (
|
||||||
"go/types"
|
"go/types"
|
||||||
"math"
|
"math"
|
||||||
"math/big"
|
"math/big"
|
||||||
"sort"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/encoding/address"
|
"github.com/nspcc-dev/neo-go/pkg/encoding/address"
|
||||||
|
@ -2253,7 +2254,7 @@ func (c *codegen) compile(info *buildInfo, pkg *packages.Package) error {
|
||||||
for _, p := range info.program {
|
for _, p := range info.program {
|
||||||
keys = append(keys, p.Types)
|
keys = append(keys, p.Types)
|
||||||
}
|
}
|
||||||
sort.Slice(keys, func(i, j int) bool { return keys[i].Path() < keys[j].Path() })
|
slices.SortFunc(keys, func(a, b *types.Package) int { return cmp.Compare(a.Path(), b.Path()) })
|
||||||
|
|
||||||
// Generate the code for the program.
|
// Generate the code for the program.
|
||||||
c.ForEachFile(func(f *ast.File, pkg *types.Package) {
|
c.ForEachFile(func(f *ast.File, pkg *types.Package) {
|
||||||
|
@ -2535,9 +2536,7 @@ func removeNOPs(b []byte, nopOffsets []int, sequencePoints map[string][]DebugSeq
|
||||||
|
|
||||||
func calcOffsetCorrection(ip, target int, offsets []int) int {
|
func calcOffsetCorrection(ip, target int, offsets []int) int {
|
||||||
cnt := 0
|
cnt := 0
|
||||||
start := sort.Search(len(offsets), func(i int) bool {
|
start, _ := slices.BinarySearch(offsets, min(ip, target))
|
||||||
return offsets[i] >= ip || offsets[i] >= target
|
|
||||||
})
|
|
||||||
for i := start; i < len(offsets) && (offsets[i] < target || offsets[i] <= ip); i++ {
|
for i := start; i < len(offsets) && (offsets[i] < target || offsets[i] <= ip); i++ {
|
||||||
ind := offsets[i]
|
ind := offsets[i]
|
||||||
if ip <= ind && ind < target || target <= ind && ind < ip {
|
if ip <= ind && ind < target || target <= ind && ind < ip {
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
package config
|
package config
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"cmp"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"maps"
|
"maps"
|
||||||
"slices"
|
"slices"
|
||||||
"sort"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config/netmode"
|
"github.com/nspcc-dev/neo-go/pkg/config/netmode"
|
||||||
|
@ -168,9 +168,7 @@ func (p *ProtocolConfiguration) Validate() error {
|
||||||
|
|
||||||
// sortCheckZero sorts heightNumber array and checks for zero height presence.
|
// sortCheckZero sorts heightNumber array and checks for zero height presence.
|
||||||
func sortCheckZero(arr []heightNumber, field string) error {
|
func sortCheckZero(arr []heightNumber, field string) error {
|
||||||
sort.Slice(arr, func(i, j int) bool {
|
slices.SortFunc(arr, func(a, b heightNumber) int { return cmp.Compare(a.h, b.h) })
|
||||||
return arr[i].h < arr[j].h
|
|
||||||
})
|
|
||||||
if arr[0].h != 0 {
|
if arr[0].h != 0 {
|
||||||
return fmt.Errorf("invalid %s: no height 0 specified", field)
|
return fmt.Errorf("invalid %s: no height 0 specified", field)
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,6 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
"math"
|
||||||
"math/big"
|
"math/big"
|
||||||
"sort"
|
|
||||||
"slices"
|
"slices"
|
||||||
"sync"
|
"sync"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
|
@ -1839,9 +1838,7 @@ func (bc *Blockchain) updateExtensibleWhitelist(height uint32) error {
|
||||||
bc.updateExtensibleList(&newList, stateVals)
|
bc.updateExtensibleList(&newList, stateVals)
|
||||||
}
|
}
|
||||||
|
|
||||||
sort.Slice(newList, func(i, j int) bool {
|
slices.SortFunc(newList, util.Uint160.Compare)
|
||||||
return newList[i].Less(newList[j])
|
|
||||||
})
|
|
||||||
bc.extensible.Store(newList)
|
bc.extensible.Store(newList)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -2786,7 +2783,7 @@ func (bc *Blockchain) PoolTxWithData(t *transaction.Transaction, data any, mp *m
|
||||||
// GetCommittee returns the sorted list of public keys of nodes in committee.
|
// GetCommittee returns the sorted list of public keys of nodes in committee.
|
||||||
func (bc *Blockchain) GetCommittee() (keys.PublicKeys, error) {
|
func (bc *Blockchain) GetCommittee() (keys.PublicKeys, error) {
|
||||||
pubs := bc.contracts.NEO.GetCommitteeMembers(bc.dao)
|
pubs := bc.contracts.NEO.GetCommitteeMembers(bc.dao)
|
||||||
sort.Sort(pubs)
|
slices.SortFunc(pubs, (*keys.PublicKey).Cmp)
|
||||||
return pubs, nil
|
return pubs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math/big"
|
"math/big"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"sort"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
@ -334,7 +334,7 @@ func TestBlockchain_InitializeNeoCache_Bug3424(t *testing.T) {
|
||||||
standBySorted, err := keys.NewPublicKeysFromStrings(e.Chain.GetConfig().StandbyCommittee)
|
standBySorted, err := keys.NewPublicKeysFromStrings(e.Chain.GetConfig().StandbyCommittee)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
standBySorted = standBySorted[:validatorsCount]
|
standBySorted = standBySorted[:validatorsCount]
|
||||||
sort.Sort(standBySorted)
|
slices.SortFunc(standBySorted, (*keys.PublicKey).Cmp)
|
||||||
pubs := e.Chain.ComputeNextBlockValidators()
|
pubs := e.Chain.ComputeNextBlockValidators()
|
||||||
require.Equal(t, standBySorted, keys.PublicKeys(pubs))
|
require.Equal(t, standBySorted, keys.PublicKeys(pubs))
|
||||||
|
|
||||||
|
@ -384,7 +384,7 @@ func TestBlockchain_InitializeNeoCache_Bug3424(t *testing.T) {
|
||||||
for i := range candidates[:validatorsCount] {
|
for i := range candidates[:validatorsCount] {
|
||||||
sortedCandidates[i] = candidates[i].(neotest.SingleSigner).Account().PublicKey()
|
sortedCandidates[i] = candidates[i].(neotest.SingleSigner).Account().PublicKey()
|
||||||
}
|
}
|
||||||
sort.Sort(sortedCandidates)
|
slices.SortFunc(sortedCandidates, (*keys.PublicKey).Cmp)
|
||||||
require.EqualValues(t, sortedCandidates, keys.PublicKeys(pubs))
|
require.EqualValues(t, sortedCandidates, keys.PublicKeys(pubs))
|
||||||
|
|
||||||
// Move to the last block in the epoch and restart the node.
|
// Move to the last block in the epoch and restart the node.
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
package interop
|
package interop
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"cmp"
|
||||||
"context"
|
"context"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"sort"
|
|
||||||
"slices"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -362,12 +362,12 @@ func (c *ContractMD) AddMethod(md *MethodAndPrice, desc *manifest.Method) {
|
||||||
md.MD = desc
|
md.MD = desc
|
||||||
desc.Safe = md.RequiredFlags&(callflag.All^callflag.ReadOnly) == 0
|
desc.Safe = md.RequiredFlags&(callflag.All^callflag.ReadOnly) == 0
|
||||||
|
|
||||||
index := sort.Search(len(c.methods), func(i int) bool {
|
index, _ := slices.BinarySearchFunc(c.methods, *md, func(e, t MethodAndPrice) int {
|
||||||
md := c.methods[i].MD
|
res := cmp.Compare(e.MD.Name, t.MD.Name)
|
||||||
if md.Name != desc.Name {
|
if res != 0 {
|
||||||
return md.Name >= desc.Name
|
return res
|
||||||
}
|
}
|
||||||
return len(md.Parameters) > len(desc.Parameters)
|
return cmp.Compare(len(e.MD.Parameters), len(t.MD.Parameters))
|
||||||
})
|
})
|
||||||
c.methods = slices.Insert(c.methods, index, *md)
|
c.methods = slices.Insert(c.methods, index, *md)
|
||||||
|
|
||||||
|
@ -392,21 +392,18 @@ func (c *HFSpecificContractMD) GetMethodByOffset(offset int) (HFSpecificMethodAn
|
||||||
|
|
||||||
// GetMethod returns method `name` with the specified number of parameters.
|
// GetMethod returns method `name` with the specified number of parameters.
|
||||||
func (c *HFSpecificContractMD) GetMethod(name string, paramCount int) (HFSpecificMethodAndPrice, bool) {
|
func (c *HFSpecificContractMD) GetMethod(name string, paramCount int) (HFSpecificMethodAndPrice, bool) {
|
||||||
index := sort.Search(len(c.Methods), func(i int) bool {
|
index, ok := slices.BinarySearchFunc(c.Methods, HFSpecificMethodAndPrice{}, func(a, _ HFSpecificMethodAndPrice) int {
|
||||||
md := c.Methods[i]
|
res := strings.Compare(a.MD.Name, name)
|
||||||
res := strings.Compare(name, md.MD.Name)
|
if res != 0 {
|
||||||
switch res {
|
return res
|
||||||
case -1, 1:
|
|
||||||
return res == -1
|
|
||||||
default:
|
|
||||||
return paramCount <= len(md.MD.Parameters)
|
|
||||||
}
|
}
|
||||||
|
return cmp.Compare(len(a.MD.Parameters), paramCount)
|
||||||
})
|
})
|
||||||
if index < len(c.Methods) {
|
// Exact match is possible only for specific paramCount, but if we're
|
||||||
md := c.Methods[index]
|
// searching for _some_ method with this name (-1) we're taking the
|
||||||
if md.MD.Name == name && (paramCount == -1 || len(md.MD.Parameters) == paramCount) {
|
// first one.
|
||||||
return md, true
|
if ok || (index < len(c.Methods) && c.Methods[index].MD.Name == name && paramCount == -1) {
|
||||||
}
|
return c.Methods[index], true
|
||||||
}
|
}
|
||||||
return HFSpecificMethodAndPrice{}, false
|
return HFSpecificMethodAndPrice{}, false
|
||||||
}
|
}
|
||||||
|
@ -425,7 +422,7 @@ func (c *ContractMD) AddEvent(md Event) {
|
||||||
|
|
||||||
// Sort sorts interop functions by id.
|
// Sort sorts interop functions by id.
|
||||||
func Sort(fs []Function) {
|
func Sort(fs []Function) {
|
||||||
sort.Slice(fs, func(i, j int) bool { return fs[i].ID < fs[j].ID })
|
slices.SortFunc(fs, func(a, b Function) int { return cmp.Compare(a.ID, b.ID) })
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetContract returns a contract by its hash in the current interop context.
|
// GetContract returns a contract by its hash in the current interop context.
|
||||||
|
@ -435,14 +432,14 @@ func (ic *Context) GetContract(hash util.Uint160) (*state.Contract, error) {
|
||||||
|
|
||||||
// GetFunction returns metadata for interop with the specified id.
|
// GetFunction returns metadata for interop with the specified id.
|
||||||
func (ic *Context) GetFunction(id uint32) *Function {
|
func (ic *Context) GetFunction(id uint32) *Function {
|
||||||
n := sort.Search(len(ic.Functions), func(i int) bool {
|
n, ok := slices.BinarySearchFunc(ic.Functions, Function{}, func(a, _ Function) int {
|
||||||
return ic.Functions[i].ID >= id
|
return cmp.Compare(a.ID, id)
|
||||||
})
|
})
|
||||||
if n < len(ic.Functions) && ic.Functions[n].ID == id {
|
if !ok {
|
||||||
return &ic.Functions[n]
|
|
||||||
}
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
return &ic.Functions[n]
|
||||||
|
}
|
||||||
|
|
||||||
// BaseExecFee represents factor to multiply syscall prices with.
|
// BaseExecFee represents factor to multiply syscall prices with.
|
||||||
func (ic *Context) BaseExecFee() int64 {
|
func (ic *Context) BaseExecFee() int64 {
|
||||||
|
|
|
@ -3,7 +3,7 @@ package mempool
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math/big"
|
"math/big"
|
||||||
"sort"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
@ -116,6 +116,10 @@ func TestOverCapacity(t *testing.T) {
|
||||||
const mempoolSize = 10
|
const mempoolSize = 10
|
||||||
mp := New(mempoolSize, 0, false, nil)
|
mp := New(mempoolSize, 0, false, nil)
|
||||||
|
|
||||||
|
var checkPoolIsSorted = func() {
|
||||||
|
require.True(t, slices.IsSortedFunc(mp.verifiedTxes, func(a, b item) int { return -a.CompareTo(b) }))
|
||||||
|
}
|
||||||
|
|
||||||
for i := 0; i < mempoolSize; i++ {
|
for i := 0; i < mempoolSize; i++ {
|
||||||
tx := transaction.New([]byte{byte(opcode.PUSH1)}, 0)
|
tx := transaction.New([]byte{byte(opcode.PUSH1)}, 0)
|
||||||
tx.Nonce = uint32(i)
|
tx.Nonce = uint32(i)
|
||||||
|
@ -124,7 +128,7 @@ func TestOverCapacity(t *testing.T) {
|
||||||
}
|
}
|
||||||
txcnt := uint32(mempoolSize)
|
txcnt := uint32(mempoolSize)
|
||||||
require.Equal(t, mempoolSize, mp.Count())
|
require.Equal(t, mempoolSize, mp.Count())
|
||||||
require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes)))
|
checkPoolIsSorted()
|
||||||
require.Equal(t, *uint256.NewInt(0), mp.fees[acc].feeSum)
|
require.Equal(t, *uint256.NewInt(0), mp.fees[acc].feeSum)
|
||||||
|
|
||||||
bigScript := make([]byte, 64)
|
bigScript := make([]byte, 64)
|
||||||
|
@ -140,7 +144,7 @@ func TestOverCapacity(t *testing.T) {
|
||||||
// size is ~90, networkFee is 10000 => feePerByte is 119
|
// size is ~90, networkFee is 10000 => feePerByte is 119
|
||||||
require.NoError(t, mp.Add(tx, fs))
|
require.NoError(t, mp.Add(tx, fs))
|
||||||
require.Equal(t, mempoolSize, mp.Count())
|
require.Equal(t, mempoolSize, mp.Count())
|
||||||
require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes)))
|
checkPoolIsSorted()
|
||||||
}
|
}
|
||||||
require.Equal(t, *uint256.NewInt(10 * 10000), mp.fees[acc].feeSum)
|
require.Equal(t, *uint256.NewInt(10 * 10000), mp.fees[acc].feeSum)
|
||||||
|
|
||||||
|
@ -155,7 +159,7 @@ func TestOverCapacity(t *testing.T) {
|
||||||
require.Equal(t, mempoolSize, len(mp.verifiedMap))
|
require.Equal(t, mempoolSize, len(mp.verifiedMap))
|
||||||
require.Equal(t, mempoolSize, len(mp.verifiedTxes))
|
require.Equal(t, mempoolSize, len(mp.verifiedTxes))
|
||||||
require.False(t, mp.containsKey(tx.Hash()))
|
require.False(t, mp.containsKey(tx.Hash()))
|
||||||
require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes)))
|
checkPoolIsSorted()
|
||||||
require.Equal(t, *uint256.NewInt(100000), mp.fees[acc].feeSum)
|
require.Equal(t, *uint256.NewInt(100000), mp.fees[acc].feeSum)
|
||||||
|
|
||||||
// Low net fee, but higher per-byte fee is still a better combination.
|
// Low net fee, but higher per-byte fee is still a better combination.
|
||||||
|
@ -168,7 +172,7 @@ func TestOverCapacity(t *testing.T) {
|
||||||
// => feePerByte is 137 (>119)
|
// => feePerByte is 137 (>119)
|
||||||
require.NoError(t, mp.Add(tx, fs))
|
require.NoError(t, mp.Add(tx, fs))
|
||||||
require.Equal(t, mempoolSize, mp.Count())
|
require.Equal(t, mempoolSize, mp.Count())
|
||||||
require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes)))
|
checkPoolIsSorted()
|
||||||
require.Equal(t, *uint256.NewInt(9*10000 + 7000), mp.fees[acc].feeSum)
|
require.Equal(t, *uint256.NewInt(9*10000 + 7000), mp.fees[acc].feeSum)
|
||||||
|
|
||||||
// High priority always wins over low priority.
|
// High priority always wins over low priority.
|
||||||
|
@ -180,7 +184,7 @@ func TestOverCapacity(t *testing.T) {
|
||||||
txcnt++
|
txcnt++
|
||||||
require.NoError(t, mp.Add(tx, fs))
|
require.NoError(t, mp.Add(tx, fs))
|
||||||
require.Equal(t, mempoolSize, mp.Count())
|
require.Equal(t, mempoolSize, mp.Count())
|
||||||
require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes)))
|
checkPoolIsSorted()
|
||||||
}
|
}
|
||||||
require.Equal(t, *uint256.NewInt(10 * 8000), mp.fees[acc].feeSum)
|
require.Equal(t, *uint256.NewInt(10 * 8000), mp.fees[acc].feeSum)
|
||||||
// Good luck with low priority now.
|
// Good luck with low priority now.
|
||||||
|
@ -190,7 +194,7 @@ func TestOverCapacity(t *testing.T) {
|
||||||
tx.Signers = []transaction.Signer{{Account: acc}}
|
tx.Signers = []transaction.Signer{{Account: acc}}
|
||||||
require.Error(t, mp.Add(tx, fs))
|
require.Error(t, mp.Add(tx, fs))
|
||||||
require.Equal(t, mempoolSize, mp.Count())
|
require.Equal(t, mempoolSize, mp.Count())
|
||||||
require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes)))
|
checkPoolIsSorted()
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetVerified(t *testing.T) {
|
func TestGetVerified(t *testing.T) {
|
||||||
|
|
|
@ -2,7 +2,7 @@ package mpt
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"sort"
|
"slices"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Batch is a batch of storage changes.
|
// Batch is a batch of storage changes.
|
||||||
|
@ -25,8 +25,8 @@ func MapToMPTBatch(m map[string][]byte) Batch {
|
||||||
for k, v := range m {
|
for k, v := range m {
|
||||||
b.kv = append(b.kv, keyValue{strToNibbles(k), v}) // Strip storage prefix.
|
b.kv = append(b.kv, keyValue{strToNibbles(k), v}) // Strip storage prefix.
|
||||||
}
|
}
|
||||||
sort.Slice(b.kv, func(i, j int) bool {
|
slices.SortFunc(b.kv, func(a, b keyValue) int {
|
||||||
return bytes.Compare(b.kv[i].key, b.kv[j].key) < 0
|
return bytes.Compare(a.key, b.key)
|
||||||
})
|
})
|
||||||
return b
|
return b
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
"math"
|
||||||
"math/big"
|
"math/big"
|
||||||
"sort"
|
"slices"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config"
|
"github.com/nspcc-dev/neo-go/pkg/config"
|
||||||
|
@ -397,7 +397,7 @@ func (s *Designate) DesignateAsRole(ic *interop.Context, r noderoles.Role, pubs
|
||||||
if si != nil {
|
if si != nil {
|
||||||
return ErrAlreadyDesignated
|
return ErrAlreadyDesignated
|
||||||
}
|
}
|
||||||
sort.Sort(pubs)
|
slices.SortFunc(pubs, (*keys.PublicKey).Cmp)
|
||||||
nl := NodeList(pubs)
|
nl := NodeList(pubs)
|
||||||
|
|
||||||
err := putConvertibleToDAO(s.ID, ic.DAO, key, &nl)
|
err := putConvertibleToDAO(s.ID, ic.DAO, key, &nl)
|
||||||
|
|
|
@ -9,7 +9,6 @@ import (
|
||||||
"maps"
|
"maps"
|
||||||
"math/big"
|
"math/big"
|
||||||
"slices"
|
"slices"
|
||||||
"sort"
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config"
|
"github.com/nspcc-dev/neo-go/pkg/config"
|
||||||
|
@ -405,7 +404,7 @@ func (n *NEO) updateCache(cache *NeoCache, cvs keysWithVotes, blockHeight uint32
|
||||||
cache.committeeHash = hash.Hash160(script)
|
cache.committeeHash = hash.Hash160(script)
|
||||||
|
|
||||||
nextVals := committee[:n.cfg.GetNumOfCNs(blockHeight+1)].Copy()
|
nextVals := committee[:n.cfg.GetNumOfCNs(blockHeight+1)].Copy()
|
||||||
sort.Sort(nextVals)
|
slices.SortFunc(nextVals, (*keys.PublicKey).Cmp)
|
||||||
cache.nextValidators = nextVals
|
cache.nextValidators = nextVals
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -430,7 +429,7 @@ func (n *NEO) updateCachedNewEpochValues(d *dao.Simple, cache *NeoCache, blockHe
|
||||||
cache.newEpochCommitteeHash = hash.Hash160(script)
|
cache.newEpochCommitteeHash = hash.Hash160(script)
|
||||||
|
|
||||||
nextVals := committee[:numOfCNs].Copy()
|
nextVals := committee[:numOfCNs].Copy()
|
||||||
sort.Sort(nextVals)
|
slices.SortFunc(nextVals, (*keys.PublicKey).Cmp)
|
||||||
cache.newEpochNextValidators = nextVals
|
cache.newEpochNextValidators = nextVals
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1028,23 +1027,23 @@ func (n *NEO) getCandidates(d *dao.Simple, sortByKey bool, maxNum int) ([]keyWit
|
||||||
// sortByKey assumes to sort by serialized key bytes (that's the way keys
|
// sortByKey assumes to sort by serialized key bytes (that's the way keys
|
||||||
// are stored and retrieved from the storage by default). Otherwise, need
|
// are stored and retrieved from the storage by default). Otherwise, need
|
||||||
// to sort using big.Int comparator.
|
// to sort using big.Int comparator.
|
||||||
sort.Slice(arr, func(i, j int) bool {
|
slices.SortFunc(arr, func(a, b keyWithVotes) int {
|
||||||
// The most-voted validators should end up in the front of the list.
|
// The most-voted validators should end up in the front of the list.
|
||||||
cmp := arr[i].Votes.Cmp(arr[j].Votes)
|
cmp := b.Votes.Cmp(a.Votes)
|
||||||
if cmp != 0 {
|
if cmp != 0 {
|
||||||
return cmp > 0
|
return cmp
|
||||||
}
|
}
|
||||||
// Ties are broken with deserialized public keys.
|
// Ties are broken with deserialized public keys.
|
||||||
// Sort by ECPoint's (X, Y) components: compare X first, and then compare Y.
|
// Sort by ECPoint's (X, Y) components: compare X first, and then compare Y.
|
||||||
cmpX := strings.Compare(arr[i].Key[1:], arr[j].Key[1:])
|
cmpX := strings.Compare(a.Key[1:], b.Key[1:])
|
||||||
if cmpX != 0 {
|
if cmpX != 0 {
|
||||||
return cmpX == -1
|
return cmpX
|
||||||
}
|
}
|
||||||
// The case when X components are the same is extremely rare, thus we perform
|
// The case when X components are the same is extremely rare, thus we perform
|
||||||
// key deserialization only if needed. No error can occur.
|
// key deserialization only if needed. No error can occur.
|
||||||
ki, _ := keys.NewPublicKeyFromBytes([]byte(arr[i].Key), elliptic.P256())
|
ka, _ := keys.NewPublicKeyFromBytes([]byte(a.Key), elliptic.P256())
|
||||||
kj, _ := keys.NewPublicKeyFromBytes([]byte(arr[j].Key), elliptic.P256())
|
kb, _ := keys.NewPublicKeyFromBytes([]byte(b.Key), elliptic.P256())
|
||||||
return ki.Y.Cmp(kj.Y) == -1
|
return ka.Y.Cmp(kb.Y)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
return arr, nil
|
return arr, nil
|
||||||
|
@ -1172,7 +1171,7 @@ func (n *NEO) ComputeNextBlockValidators(d *dao.Simple) keys.PublicKeys {
|
||||||
|
|
||||||
func (n *NEO) getCommittee(ic *interop.Context, _ []stackitem.Item) stackitem.Item {
|
func (n *NEO) getCommittee(ic *interop.Context, _ []stackitem.Item) stackitem.Item {
|
||||||
pubs := n.GetCommitteeMembers(ic.DAO)
|
pubs := n.GetCommitteeMembers(ic.DAO)
|
||||||
sort.Sort(pubs)
|
slices.SortFunc(pubs, (*keys.PublicKey).Cmp)
|
||||||
return pubsToArray(pubs)
|
return pubsToArray(pubs)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@ package native_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"math/big"
|
"math/big"
|
||||||
"sort"
|
"slices"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/core/interop/interopnames"
|
"github.com/nspcc-dev/neo-go/pkg/core/interop/interopnames"
|
||||||
|
@ -602,9 +602,7 @@ func TestCryptoLib_KoblitzMultisigVerificationScript(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
}
|
}
|
||||||
// Sort private keys by their public keys.
|
// Sort private keys by their public keys.
|
||||||
sort.Slice(pks, func(i, j int) bool {
|
slices.SortFunc(pks, func(a, b *keys.PrivateKey) int { return a.PublicKey().Cmp(b.PublicKey()) })
|
||||||
return pks[i].PublicKey().Cmp(pks[j].PublicKey()) < 0
|
|
||||||
})
|
|
||||||
|
|
||||||
// Firstly, we need to build the N3 multisig account address based on the users' public keys.
|
// Firstly, we need to build the N3 multisig account address based on the users' public keys.
|
||||||
// Pubs must be sorted, exactly like for the standard CheckMultisig.
|
// Pubs must be sorted, exactly like for the standard CheckMultisig.
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
package native_test
|
package native_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"sort"
|
"slices"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config"
|
"github.com/nspcc-dev/neo-go/pkg/config"
|
||||||
|
@ -157,6 +157,6 @@ func TestDesignate_GenesisRolesExtension(t *testing.T) {
|
||||||
c := e.CommitteeInvoker(e.NativeHash(t, nativenames.Designation))
|
c := e.CommitteeInvoker(e.NativeHash(t, nativenames.Designation))
|
||||||
|
|
||||||
// Check designated node in a separate block.
|
// Check designated node in a separate block.
|
||||||
sort.Sort(pubs)
|
slices.SortFunc(pubs, (*keys.PublicKey).Cmp)
|
||||||
checkNodeRoles(t, c, true, noderoles.StateValidator, e.Chain.BlockHeight()+1, pubs)
|
checkNodeRoles(t, c, true, noderoles.StateValidator, e.Chain.BlockHeight()+1, pubs)
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
"math"
|
||||||
"math/big"
|
"math/big"
|
||||||
"sort"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
@ -204,7 +204,7 @@ func TestNEO_Vote(t *testing.T) {
|
||||||
standBySorted, err := keys.NewPublicKeysFromStrings(e.Chain.GetConfig().StandbyCommittee)
|
standBySorted, err := keys.NewPublicKeysFromStrings(e.Chain.GetConfig().StandbyCommittee)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
standBySorted = standBySorted[:validatorsCount]
|
standBySorted = standBySorted[:validatorsCount]
|
||||||
sort.Sort(standBySorted)
|
slices.SortFunc(standBySorted, (*keys.PublicKey).Cmp)
|
||||||
pubs := e.Chain.ComputeNextBlockValidators()
|
pubs := e.Chain.ComputeNextBlockValidators()
|
||||||
require.Equal(t, standBySorted, keys.PublicKeys(pubs))
|
require.Equal(t, standBySorted, keys.PublicKeys(pubs))
|
||||||
|
|
||||||
|
@ -269,7 +269,7 @@ func TestNEO_Vote(t *testing.T) {
|
||||||
for i := range candidates[:validatorsCount] {
|
for i := range candidates[:validatorsCount] {
|
||||||
sortedCandidates[i] = candidates[i].(neotest.SingleSigner).Account().PublicKey()
|
sortedCandidates[i] = candidates[i].(neotest.SingleSigner).Account().PublicKey()
|
||||||
}
|
}
|
||||||
sort.Sort(sortedCandidates)
|
slices.SortFunc(sortedCandidates, (*keys.PublicKey).Cmp)
|
||||||
require.EqualValues(t, sortedCandidates, keys.PublicKeys(pubs))
|
require.EqualValues(t, sortedCandidates, keys.PublicKeys(pubs))
|
||||||
|
|
||||||
pubs, err = neoCommitteeInvoker.Chain.GetNextBlockValidators()
|
pubs, err = neoCommitteeInvoker.Chain.GetNextBlockValidators()
|
||||||
|
@ -403,7 +403,7 @@ func TestNEO_GetCommitteeAddress(t *testing.T) {
|
||||||
e := neoValidatorInvoker.Executor
|
e := neoValidatorInvoker.Executor
|
||||||
standByCommitteePublicKeys, err := keys.NewPublicKeysFromStrings(e.Chain.GetConfig().StandbyCommittee)
|
standByCommitteePublicKeys, err := keys.NewPublicKeysFromStrings(e.Chain.GetConfig().StandbyCommittee)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
sort.Sort(standByCommitteePublicKeys)
|
slices.SortFunc(standByCommitteePublicKeys, (*keys.PublicKey).Cmp)
|
||||||
expectedCommitteeAddress, err := smartcontract.CreateMajorityMultiSigRedeemScript(standByCommitteePublicKeys)
|
expectedCommitteeAddress, err := smartcontract.CreateMajorityMultiSigRedeemScript(standByCommitteePublicKeys)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
stack, err := neoValidatorInvoker.TestInvoke(t, "getCommitteeAddress")
|
stack, err := neoValidatorInvoker.TestInvoke(t, "getCommitteeAddress")
|
||||||
|
@ -811,8 +811,8 @@ func TestNEO_GetCandidates(t *testing.T) {
|
||||||
})
|
})
|
||||||
neoCommitteeInvoker.Invoke(t, v, "getCandidateVote", pub)
|
neoCommitteeInvoker.Invoke(t, v, "getCandidateVote", pub)
|
||||||
}
|
}
|
||||||
sort.Slice(expected, func(i, j int) bool {
|
slices.SortFunc(expected, func(a, b stackitem.Item) int {
|
||||||
return bytes.Compare(expected[i].Value().([]stackitem.Item)[0].Value().([]byte), expected[j].Value().([]stackitem.Item)[0].Value().([]byte)) < 0
|
return bytes.Compare(a.Value().([]stackitem.Item)[0].Value().([]byte), b.Value().([]stackitem.Item)[0].Value().([]byte))
|
||||||
})
|
})
|
||||||
neoCommitteeInvoker.Invoke(t, stackitem.NewArray(expected), "getCandidates")
|
neoCommitteeInvoker.Invoke(t, stackitem.NewArray(expected), "getCandidates")
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,6 @@ import (
|
||||||
"maps"
|
"maps"
|
||||||
"math/big"
|
"math/big"
|
||||||
"slices"
|
"slices"
|
||||||
"sort"
|
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config"
|
"github.com/nspcc-dev/neo-go/pkg/config"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/core/dao"
|
"github.com/nspcc-dev/neo-go/pkg/core/dao"
|
||||||
|
@ -327,14 +326,7 @@ func (p *Policy) IsBlocked(dao *dao.Simple, hash util.Uint160) bool {
|
||||||
// of the blocked account in the blocked accounts list (or the position it should be
|
// of the blocked account in the blocked accounts list (or the position it should be
|
||||||
// put at).
|
// put at).
|
||||||
func (p *Policy) isBlockedInternal(roCache *PolicyCache, hash util.Uint160) (int, bool) {
|
func (p *Policy) isBlockedInternal(roCache *PolicyCache, hash util.Uint160) (int, bool) {
|
||||||
length := len(roCache.blockedAccounts)
|
return slices.BinarySearchFunc(roCache.blockedAccounts, hash, util.Uint160.Compare)
|
||||||
i := sort.Search(length, func(i int) bool {
|
|
||||||
return !roCache.blockedAccounts[i].Less(hash)
|
|
||||||
})
|
|
||||||
if length != 0 && i != length && roCache.blockedAccounts[i].Equals(hash) {
|
|
||||||
return i, true
|
|
||||||
}
|
|
||||||
return i, false
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Policy) getStoragePrice(ic *interop.Context, _ []stackitem.Item) stackitem.Item {
|
func (p *Policy) getStoragePrice(ic *interop.Context, _ []stackitem.Item) stackitem.Item {
|
||||||
|
|
|
@ -3,7 +3,7 @@ package storage
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
"sort"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
)
|
)
|
||||||
|
@ -230,13 +230,11 @@ func (s *MemCachedStore) prepareSeekMemSnapshot(rng SeekRange) (Store, []KeyValu
|
||||||
// seeking from some point is supported with corresponding `rng` field set.
|
// seeking from some point is supported with corresponding `rng` field set.
|
||||||
func performSeek(ctx context.Context, ps Store, memRes []KeyValueExists, rng SeekRange, cutPrefix bool, f func(k, v []byte) bool) {
|
func performSeek(ctx context.Context, ps Store, memRes []KeyValueExists, rng SeekRange, cutPrefix bool, f func(k, v []byte) bool) {
|
||||||
lPrefix := len(string(rng.Prefix))
|
lPrefix := len(string(rng.Prefix))
|
||||||
less := func(k1, k2 []byte) bool {
|
var cmpFunc = getCmpFunc(rng.Backwards)
|
||||||
res := bytes.Compare(k1, k2)
|
|
||||||
return res != 0 && rng.Backwards == (res > 0)
|
|
||||||
}
|
|
||||||
// Sort memRes items for further comparison with ps items.
|
// Sort memRes items for further comparison with ps items.
|
||||||
sort.Slice(memRes, func(i, j int) bool {
|
slices.SortFunc(memRes, func(a, b KeyValueExists) int {
|
||||||
return less(memRes[i].Key, memRes[j].Key)
|
return cmpFunc(a.Key, b.Key)
|
||||||
})
|
})
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -266,7 +264,7 @@ func performSeek(ctx context.Context, ps Store, memRes []KeyValueExists, rng See
|
||||||
done = true
|
done = true
|
||||||
return false
|
return false
|
||||||
default:
|
default:
|
||||||
var isMem = haveMem && less(kvMem.Key, kvPs.Key)
|
var isMem = haveMem && cmpFunc(kvMem.Key, kvPs.Key) < 0
|
||||||
if isMem {
|
if isMem {
|
||||||
if kvMem.Exists {
|
if kvMem.Exists {
|
||||||
if cutPrefix {
|
if cutPrefix {
|
||||||
|
|
|
@ -3,7 +3,7 @@ package storage
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"sort"
|
"slices"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/internal/random"
|
"github.com/nspcc-dev/neo-go/internal/random"
|
||||||
|
@ -424,8 +424,8 @@ func TestCachedSeekSorting(t *testing.T) {
|
||||||
})
|
})
|
||||||
assert.Equal(t, len(foundKVs), len(lowerKVs)+len(updatedKVs))
|
assert.Equal(t, len(foundKVs), len(lowerKVs)+len(updatedKVs))
|
||||||
expected := append(lowerKVs, updatedKVs...)
|
expected := append(lowerKVs, updatedKVs...)
|
||||||
sort.Slice(expected, func(i, j int) bool {
|
slices.SortFunc(expected, func(a, b KeyValue) int {
|
||||||
return bytes.Compare(expected[i].Key, expected[j].Key) < 0
|
return bytes.Compare(a.Key, b.Key)
|
||||||
})
|
})
|
||||||
require.Equal(t, expected, foundKVs)
|
require.Equal(t, expected, foundKVs)
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@ package storage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"sort"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
)
|
)
|
||||||
|
@ -107,10 +107,7 @@ func (s *MemoryStore) seek(rng SeekRange, f func(k, v []byte) bool, lock func(),
|
||||||
return strings.HasPrefix(key, sPrefix) && (lStart == 0 || strings.Compare(key[lPrefix:], sStart) <= 0)
|
return strings.HasPrefix(key, sPrefix) && (lStart == 0 || strings.Compare(key[lPrefix:], sStart) <= 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
less := func(k1, k2 []byte) bool {
|
var cmpFunc = getCmpFunc(rng.Backwards)
|
||||||
res := bytes.Compare(k1, k2)
|
|
||||||
return res != 0 && rng.Backwards == (res > 0)
|
|
||||||
}
|
|
||||||
|
|
||||||
lock()
|
lock()
|
||||||
m := s.chooseMap(rng.Prefix)
|
m := s.chooseMap(rng.Prefix)
|
||||||
|
@ -123,8 +120,8 @@ func (s *MemoryStore) seek(rng SeekRange, f func(k, v []byte) bool, lock func(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
unlock()
|
unlock()
|
||||||
sort.Slice(memList, func(i, j int) bool {
|
slices.SortFunc(memList, func(a, b KeyValue) int {
|
||||||
return less(memList[i].Key, memList[j].Key)
|
return cmpFunc(a.Key, b.Key)
|
||||||
})
|
})
|
||||||
for _, kv := range memList {
|
for _, kv := range memList {
|
||||||
if !f(kv.Key, kv.Value) {
|
if !f(kv.Key, kv.Value) {
|
||||||
|
@ -133,6 +130,13 @@ func (s *MemoryStore) seek(rng SeekRange, f func(k, v []byte) bool, lock func(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getCmpFunc(backwards bool) func(a, b []byte) int {
|
||||||
|
if !backwards {
|
||||||
|
return bytes.Compare
|
||||||
|
}
|
||||||
|
return func(a, b []byte) int { return -bytes.Compare(a, b) }
|
||||||
|
}
|
||||||
|
|
||||||
// Close implements Store interface and clears up memory. Never returns an
|
// Close implements Store interface and clears up memory. Never returns an
|
||||||
// error.
|
// error.
|
||||||
func (s *MemoryStore) Close() error {
|
func (s *MemoryStore) Close() error {
|
||||||
|
|
|
@ -4,7 +4,7 @@ import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"reflect"
|
"reflect"
|
||||||
"runtime"
|
"runtime"
|
||||||
"sort"
|
"slices"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
@ -49,15 +49,10 @@ func testStoreSeek(t *testing.T, s Store) {
|
||||||
kvs := pushSeekDataSet(t, s)
|
kvs := pushSeekDataSet(t, s)
|
||||||
check := func(t *testing.T, goodprefix, start []byte, goodkvs []KeyValue, backwards bool, cont func(k, v []byte) bool) {
|
check := func(t *testing.T, goodprefix, start []byte, goodkvs []KeyValue, backwards bool, cont func(k, v []byte) bool) {
|
||||||
// Seek result expected to be sorted in an ascending (for forwards seeking) or descending (for backwards seeking) way.
|
// Seek result expected to be sorted in an ascending (for forwards seeking) or descending (for backwards seeking) way.
|
||||||
cmpFunc := func(i, j int) bool {
|
var cmpFunc = getCmpFunc(backwards)
|
||||||
return bytes.Compare(goodkvs[i].Key, goodkvs[j].Key) < 0
|
slices.SortFunc(goodkvs, func(a, b KeyValue) int {
|
||||||
}
|
return cmpFunc(a.Key, b.Key)
|
||||||
if backwards {
|
})
|
||||||
cmpFunc = func(i, j int) bool {
|
|
||||||
return bytes.Compare(goodkvs[i].Key, goodkvs[j].Key) > 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
sort.Slice(goodkvs, cmpFunc)
|
|
||||||
|
|
||||||
rng := SeekRange{
|
rng := SeekRange{
|
||||||
Prefix: goodprefix,
|
Prefix: goodprefix,
|
||||||
|
|
|
@ -2,7 +2,7 @@ package chain
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
"sort"
|
"slices"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -103,12 +103,12 @@ func init() {
|
||||||
standByCommittee[5] = pubs[5].StringCompressed()
|
standByCommittee[5] = pubs[5].StringCompressed()
|
||||||
|
|
||||||
multiValidatorAcc = make([]*wallet.Account, 4)
|
multiValidatorAcc = make([]*wallet.Account, 4)
|
||||||
sort.Sort(pubs[:4])
|
slices.SortFunc(pubs[:4], (*keys.PublicKey).Cmp)
|
||||||
|
|
||||||
sort.Slice(accs[:4], func(i, j int) bool {
|
slices.SortFunc(accs[:4], func(a, b *wallet.Account) int {
|
||||||
p1 := accs[i].PublicKey()
|
pa := a.PublicKey()
|
||||||
p2 := accs[j].PublicKey()
|
pb := b.PublicKey()
|
||||||
return p1.Cmp(p2) == -1
|
return pa.Cmp(pb)
|
||||||
})
|
})
|
||||||
for i := range multiValidatorAcc {
|
for i := range multiValidatorAcc {
|
||||||
multiValidatorAcc[i] = wallet.NewAccountFromPrivateKey(accs[i].PrivateKey())
|
multiValidatorAcc[i] = wallet.NewAccountFromPrivateKey(accs[i].PrivateKey())
|
||||||
|
@ -119,12 +119,12 @@ func init() {
|
||||||
}
|
}
|
||||||
|
|
||||||
multiCommitteeAcc = make([]*wallet.Account, len(committeeWIFs))
|
multiCommitteeAcc = make([]*wallet.Account, len(committeeWIFs))
|
||||||
sort.Sort(pubs)
|
slices.SortFunc(pubs, (*keys.PublicKey).Cmp)
|
||||||
|
|
||||||
sort.Slice(accs, func(i, j int) bool {
|
slices.SortFunc(accs, func(a, b *wallet.Account) int {
|
||||||
p1 := accs[i].PublicKey()
|
pa := a.PublicKey()
|
||||||
p2 := accs[j].PublicKey()
|
pb := b.PublicKey()
|
||||||
return p1.Cmp(p2) == -1
|
return pa.Cmp(pb)
|
||||||
})
|
})
|
||||||
for i := range multiCommitteeAcc {
|
for i := range multiCommitteeAcc {
|
||||||
multiCommitteeAcc[i] = wallet.NewAccountFromPrivateKey(accs[i].PrivateKey())
|
multiCommitteeAcc[i] = wallet.NewAccountFromPrivateKey(accs[i].PrivateKey())
|
||||||
|
|
|
@ -3,7 +3,7 @@ package neotest
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"sort"
|
"slices"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config/netmode"
|
"github.com/nspcc-dev/neo-go/pkg/config/netmode"
|
||||||
|
@ -106,10 +106,10 @@ func NewMultiSigner(accs ...*wallet.Account) MultiSigner {
|
||||||
panic(fmt.Sprintf("verification script requires %d signatures, "+
|
panic(fmt.Sprintf("verification script requires %d signatures, "+
|
||||||
"but only %d accounts were provided", m, len(accs)))
|
"but only %d accounts were provided", m, len(accs)))
|
||||||
}
|
}
|
||||||
sort.Slice(accs, func(i, j int) bool {
|
slices.SortFunc(accs, func(a, b *wallet.Account) int {
|
||||||
p1 := accs[i].PublicKey()
|
pa := a.PublicKey()
|
||||||
p2 := accs[j].PublicKey()
|
pb := b.PublicKey()
|
||||||
return p1.Cmp(p2) == -1
|
return pa.Cmp(pb)
|
||||||
})
|
})
|
||||||
for _, acc := range accs {
|
for _, acc := range accs {
|
||||||
if !bytes.Equal(script, acc.Contract.Script) {
|
if !bytes.Equal(script, acc.Contract.Script) {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
package neotest
|
package neotest
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"sort"
|
"slices"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
||||||
|
@ -31,7 +31,7 @@ func TestMultiSigner(t *testing.T) {
|
||||||
pubs[i] = a.PublicKey()
|
pubs[i] = a.PublicKey()
|
||||||
}
|
}
|
||||||
|
|
||||||
sort.Sort(pubs)
|
slices.SortFunc(pubs, (*keys.PublicKey).Cmp)
|
||||||
m := smartcontract.GetDefaultHonestNodeCount(size)
|
m := smartcontract.GetDefaultHonestNodeCount(size)
|
||||||
for i := range accs {
|
for i := range accs {
|
||||||
require.NoError(t, accs[i].ConvertMultisig(m, pubs))
|
require.NoError(t, accs[i].ConvertMultisig(m, pubs))
|
||||||
|
|
|
@ -11,7 +11,6 @@ import (
|
||||||
"net"
|
"net"
|
||||||
"runtime"
|
"runtime"
|
||||||
"slices"
|
"slices"
|
||||||
"sort"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
"sync"
|
"sync"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
|
@ -1170,10 +1169,8 @@ txloop:
|
||||||
var cbList = s.txCbList.Load()
|
var cbList = s.txCbList.Load()
|
||||||
if cbList != nil {
|
if cbList != nil {
|
||||||
var list = cbList.([]util.Uint256)
|
var list = cbList.([]util.Uint256)
|
||||||
var i = sort.Search(len(list), func(i int) bool {
|
_, found := slices.BinarySearchFunc(list, tx.Hash(), util.Uint256.CompareTo)
|
||||||
return list[i].CompareTo(tx.Hash()) >= 0
|
if found {
|
||||||
})
|
|
||||||
if i < len(list) && list[i].Equals(tx.Hash()) {
|
|
||||||
txCallback(tx)
|
txCallback(tx)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1487,10 +1484,7 @@ func (s *Server) RequestTx(hashes ...util.Uint256) {
|
||||||
}
|
}
|
||||||
|
|
||||||
var sorted = slices.Clone(hashes)
|
var sorted = slices.Clone(hashes)
|
||||||
sort.Slice(sorted, func(i, j int) bool {
|
slices.SortFunc(sorted, util.Uint256.CompareTo)
|
||||||
return sorted[i].CompareTo(sorted[j]) < 0
|
|
||||||
})
|
|
||||||
|
|
||||||
s.txCbList.Store(sorted)
|
s.txCbList.Store(sorted)
|
||||||
|
|
||||||
for i := 0; i <= len(hashes)/payload.MaxHashesCount; i++ {
|
for i := 0; i <= len(hashes)/payload.MaxHashesCount; i++ {
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
package neo_test
|
package neo_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"cmp"
|
||||||
"context"
|
"context"
|
||||||
"math/big"
|
"math/big"
|
||||||
"sort"
|
"slices"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/encoding/address"
|
"github.com/nspcc-dev/neo-go/pkg/encoding/address"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/neorpc/result"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/rpcclient"
|
"github.com/nspcc-dev/neo-go/pkg/rpcclient"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/rpcclient/actor"
|
"github.com/nspcc-dev/neo-go/pkg/rpcclient/actor"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/rpcclient/invoker"
|
"github.com/nspcc-dev/neo-go/pkg/rpcclient/invoker"
|
||||||
|
@ -76,7 +78,7 @@ func ExampleContract() {
|
||||||
cands, _ := neoToken.GetCandidates()
|
cands, _ := neoToken.GetCandidates()
|
||||||
|
|
||||||
// Sort by votes.
|
// Sort by votes.
|
||||||
sort.Slice(cands, func(i, j int) bool { return cands[i].Votes < cands[j].Votes })
|
slices.SortFunc(cands, func(a, b result.Validator) int { return cmp.Compare(a.Votes, b.Votes) })
|
||||||
|
|
||||||
// Get the extended NEO-specific balance data.
|
// Get the extended NEO-specific balance data.
|
||||||
bNeo, _ := neoToken.GetAccountState(a.Sender())
|
bNeo, _ := neoToken.GetAccountState(a.Sender())
|
||||||
|
|
|
@ -10,7 +10,7 @@ import (
|
||||||
"math/big"
|
"math/big"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"sort"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
"testing"
|
"testing"
|
||||||
|
@ -154,7 +154,7 @@ func TestClientRoleManagement(t *testing.T) {
|
||||||
_, err = c.SubmitBlock(*bl)
|
_, err = c.SubmitBlock(*bl)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
sort.Sort(testKeys)
|
slices.SortFunc(testKeys, (*keys.PublicKey).Cmp)
|
||||||
ks, err = rm.GetDesignatedByRole(noderoles.Oracle, height+1)
|
ks, err = rm.GetDesignatedByRole(noderoles.Oracle, height+1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, testKeys, ks)
|
require.Equal(t, testKeys, ks)
|
||||||
|
@ -1458,11 +1458,11 @@ func TestClient_IteratorSessions(t *testing.T) {
|
||||||
for i := 0; i < storageItemsCount; i++ {
|
for i := 0; i < storageItemsCount; i++ {
|
||||||
expected[i] = stackitem.NewBigInteger(big.NewInt(int64(i))).Bytes()
|
expected[i] = stackitem.NewBigInteger(big.NewInt(int64(i))).Bytes()
|
||||||
}
|
}
|
||||||
sort.Slice(expected, func(i, j int) bool {
|
slices.SortFunc(expected, func(a, b []byte) int {
|
||||||
if len(expected[i]) != len(expected[j]) {
|
if len(a) != len(b) {
|
||||||
return len(expected[i]) < len(expected[j])
|
return len(a) - len(b)
|
||||||
}
|
}
|
||||||
return bytes.Compare(expected[i], expected[j]) < 0
|
return bytes.Compare(a, b)
|
||||||
})
|
})
|
||||||
|
|
||||||
prepareSession := func(t *testing.T) (uuid.UUID, uuid.UUID) {
|
prepareSession := func(t *testing.T) (uuid.UUID, uuid.UUID) {
|
||||||
|
@ -1699,11 +1699,11 @@ func TestClient_Iterator_SessionConfigVariations(t *testing.T) {
|
||||||
for i := 0; i < storageItemsCount; i++ {
|
for i := 0; i < storageItemsCount; i++ {
|
||||||
expected[i] = stackitem.NewBigInteger(big.NewInt(int64(i))).Bytes()
|
expected[i] = stackitem.NewBigInteger(big.NewInt(int64(i))).Bytes()
|
||||||
}
|
}
|
||||||
sort.Slice(expected, func(i, j int) bool {
|
slices.SortFunc(expected, func(a, b []byte) int {
|
||||||
if len(expected[i]) != len(expected[j]) {
|
if len(a) != len(b) {
|
||||||
return len(expected[i]) < len(expected[j])
|
return len(a) - len(b)
|
||||||
}
|
}
|
||||||
return bytes.Compare(expected[i], expected[j]) < 0
|
return bytes.Compare(a, b)
|
||||||
})
|
})
|
||||||
checkSessionEnabled(t, c)
|
checkSessionEnabled(t, c)
|
||||||
})
|
})
|
||||||
|
|
|
@ -14,7 +14,7 @@ import (
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"reflect"
|
"reflect"
|
||||||
"sort"
|
"slices"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
|
@ -1174,7 +1174,7 @@ var rpcTestCases = map[string][]rpcTestCase{
|
||||||
params: "[]",
|
params: "[]",
|
||||||
result: func(e *executor) any {
|
result: func(e *executor) any {
|
||||||
expected, _ := e.chain.GetCommittee()
|
expected, _ := e.chain.GetCommittee()
|
||||||
sort.Sort(expected)
|
slices.SortFunc(expected, (*keys.PublicKey).Cmp)
|
||||||
return &expected
|
return &expected
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -3,7 +3,7 @@ package stateroot_test
|
||||||
import (
|
import (
|
||||||
"crypto/elliptic"
|
"crypto/elliptic"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"sort"
|
"slices"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
@ -63,10 +63,10 @@ func newMajorityMultisigWithGAS(t *testing.T, n int) (util.Uint160, keys.PublicK
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
accs[i] = acc
|
accs[i] = acc
|
||||||
}
|
}
|
||||||
sort.Slice(accs, func(i, j int) bool {
|
slices.SortFunc(accs, func(a, b *wallet.Account) int {
|
||||||
pi := accs[i].PublicKey()
|
pa := a.PublicKey()
|
||||||
pj := accs[j].PublicKey()
|
pb := b.PublicKey()
|
||||||
return pi.Cmp(pj) == -1
|
return pa.Cmp(pb)
|
||||||
})
|
})
|
||||||
pubs := make(keys.PublicKeys, n)
|
pubs := make(keys.PublicKeys, n)
|
||||||
for i := range pubs {
|
for i := range pubs {
|
||||||
|
|
|
@ -7,7 +7,6 @@ import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"slices"
|
"slices"
|
||||||
"sort"
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config/netmode"
|
"github.com/nspcc-dev/neo-go/pkg/config/netmode"
|
||||||
|
@ -133,8 +132,8 @@ func (c *ParameterContext) AddSignature(h util.Uint160, ctr *wallet.Contract, pu
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sort.Slice(sigs, func(i, j int) bool {
|
slices.SortFunc(sigs, func(a, b sigWithIndex) int {
|
||||||
return sigs[i].index < sigs[j].index
|
return a.index - b.index
|
||||||
})
|
})
|
||||||
for i := range sigs {
|
for i := range sigs {
|
||||||
item.Parameters[i] = smartcontract.Parameter{
|
item.Parameters[i] = smartcontract.Parameter{
|
||||||
|
|
|
@ -2,7 +2,7 @@ package smartcontract
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"sort"
|
"slices"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/core/interop/interopnames"
|
"github.com/nspcc-dev/neo-go/pkg/core/interop/interopnames"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
||||||
|
@ -26,7 +26,7 @@ func CreateMultiSigRedeemScript(m int, publicKeys keys.PublicKeys) ([]byte, erro
|
||||||
|
|
||||||
buf := io.NewBufBinWriter()
|
buf := io.NewBufBinWriter()
|
||||||
emit.Int(buf.BinWriter, int64(m))
|
emit.Int(buf.BinWriter, int64(m))
|
||||||
sort.Sort(publicKeys)
|
slices.SortFunc(publicKeys, (*keys.PublicKey).Cmp)
|
||||||
for _, pubKey := range publicKeys {
|
for _, pubKey := range publicKeys {
|
||||||
emit.Bytes(buf.BinWriter, pubKey.Bytes())
|
emit.Bytes(buf.BinWriter, pubKey.Bytes())
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,6 @@ package rpcbinding
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"slices"
|
"slices"
|
||||||
"sort"
|
|
||||||
"strings"
|
"strings"
|
||||||
"text/template"
|
"text/template"
|
||||||
"unicode"
|
"unicode"
|
||||||
|
@ -434,9 +433,7 @@ func Generate(cfg binding.Config) error {
|
||||||
for k := range cfg.NamedTypes {
|
for k := range cfg.NamedTypes {
|
||||||
ctr.NamedTypes = append(ctr.NamedTypes, cfg.NamedTypes[k])
|
ctr.NamedTypes = append(ctr.NamedTypes, cfg.NamedTypes[k])
|
||||||
}
|
}
|
||||||
sort.Slice(ctr.NamedTypes, func(i, j int) bool {
|
slices.SortFunc(ctr.NamedTypes, func(a, b binding.ExtendedType) int { return strings.Compare(a.Name, b.Name) })
|
||||||
return strings.Compare(ctr.NamedTypes[i].Name, ctr.NamedTypes[j].Name) < 0
|
|
||||||
})
|
|
||||||
|
|
||||||
// Check resulting named types and events don't have duplicating field names.
|
// Check resulting named types and events don't have duplicating field names.
|
||||||
for _, t := range ctr.NamedTypes {
|
for _, t := range ctr.NamedTypes {
|
||||||
|
|
|
@ -2,6 +2,7 @@ package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"cmp"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
|
@ -10,7 +11,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"sort"
|
"slices"
|
||||||
|
|
||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
)
|
)
|
||||||
|
@ -61,9 +62,7 @@ func (d dump) normalize() {
|
||||||
}
|
}
|
||||||
newStorage = append(newStorage, d[i].Storage[j])
|
newStorage = append(newStorage, d[i].Storage[j])
|
||||||
}
|
}
|
||||||
sort.Slice(newStorage, func(k, l int) bool {
|
slices.SortFunc(newStorage, func(a, b storageOp) int { return cmp.Compare(a.Key, b.Key) })
|
||||||
return newStorage[k].Key < newStorage[l].Key
|
|
||||||
})
|
|
||||||
d[i].Storage = newStorage
|
d[i].Storage = newStorage
|
||||||
}
|
}
|
||||||
// assume that d is already sorted by Block
|
// assume that d is already sorted by Block
|
||||||
|
|
Loading…
Reference in a new issue