2014-12-08 05:43:33 -06:00
|
|
|
package whisper
|
|
|
|
|
2015-03-20 18:57:18 -05:00
|
|
|
import (
|
|
|
|
"sort"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
)
|
2014-12-08 05:43:33 -06:00
|
|
|
|
|
|
|
type sortedKeys struct {
|
|
|
|
k []int32
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *sortedKeys) Len() int { return len(self.k) }
|
|
|
|
func (self *sortedKeys) Less(i, j int) bool { return self.k[i] < self.k[j] }
|
|
|
|
func (self *sortedKeys) Swap(i, j int) { self.k[i], self.k[j] = self.k[j], self.k[i] }
|
|
|
|
|
2015-03-20 18:57:18 -05:00
|
|
|
func sortKeys(m map[int32]common.Hash) []int32 {
|
2014-12-08 05:43:33 -06:00
|
|
|
sorted := new(sortedKeys)
|
|
|
|
sorted.k = make([]int32, len(m))
|
|
|
|
i := 0
|
|
|
|
for key, _ := range m {
|
|
|
|
sorted.k[i] = key
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
|
|
|
|
sort.Sort(sorted)
|
|
|
|
|
|
|
|
return sorted.k
|
|
|
|
}
|