annotate vendor/gopkg.in/yaml.v2/sorter.go @ 68:4b79810863f6 draft

Ready to release 0.6.0 Signed-off-by: Izuru Yakumo <yakumo.izuru@chaotic.ninja>
author yakumo.izuru
date Wed, 13 Sep 2023 10:49:50 +0000
parents 787b5ee0289d
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
66
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
1 package yaml
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
2
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
3 import (
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
4 "reflect"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
5 "unicode"
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
6 )
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
7
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
8 type keyList []reflect.Value
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
9
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
10 func (l keyList) Len() int { return len(l) }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
11 func (l keyList) Swap(i, j int) { l[i], l[j] = l[j], l[i] }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
12 func (l keyList) Less(i, j int) bool {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
13 a := l[i]
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
14 b := l[j]
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
15 ak := a.Kind()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
16 bk := b.Kind()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
17 for (ak == reflect.Interface || ak == reflect.Ptr) && !a.IsNil() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
18 a = a.Elem()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
19 ak = a.Kind()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
20 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
21 for (bk == reflect.Interface || bk == reflect.Ptr) && !b.IsNil() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
22 b = b.Elem()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
23 bk = b.Kind()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
24 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
25 af, aok := keyFloat(a)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
26 bf, bok := keyFloat(b)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
27 if aok && bok {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
28 if af != bf {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
29 return af < bf
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
30 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
31 if ak != bk {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
32 return ak < bk
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
33 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
34 return numLess(a, b)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
35 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
36 if ak != reflect.String || bk != reflect.String {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
37 return ak < bk
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
38 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
39 ar, br := []rune(a.String()), []rune(b.String())
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
40 for i := 0; i < len(ar) && i < len(br); i++ {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
41 if ar[i] == br[i] {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
42 continue
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
43 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
44 al := unicode.IsLetter(ar[i])
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
45 bl := unicode.IsLetter(br[i])
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
46 if al && bl {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
47 return ar[i] < br[i]
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
48 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
49 if al || bl {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
50 return bl
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
51 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
52 var ai, bi int
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
53 var an, bn int64
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
54 if ar[i] == '0' || br[i] == '0' {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
55 for j := i-1; j >= 0 && unicode.IsDigit(ar[j]); j-- {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
56 if ar[j] != '0' {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
57 an = 1
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
58 bn = 1
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
59 break
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
60 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
61 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
62 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
63 for ai = i; ai < len(ar) && unicode.IsDigit(ar[ai]); ai++ {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
64 an = an*10 + int64(ar[ai]-'0')
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
65 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
66 for bi = i; bi < len(br) && unicode.IsDigit(br[bi]); bi++ {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
67 bn = bn*10 + int64(br[bi]-'0')
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
68 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
69 if an != bn {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
70 return an < bn
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
71 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
72 if ai != bi {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
73 return ai < bi
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
74 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
75 return ar[i] < br[i]
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
76 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
77 return len(ar) < len(br)
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
78 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
79
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
80 // keyFloat returns a float value for v if it is a number/bool
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
81 // and whether it is a number/bool or not.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
82 func keyFloat(v reflect.Value) (f float64, ok bool) {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
83 switch v.Kind() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
84 case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
85 return float64(v.Int()), true
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
86 case reflect.Float32, reflect.Float64:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
87 return v.Float(), true
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
88 case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
89 return float64(v.Uint()), true
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
90 case reflect.Bool:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
91 if v.Bool() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
92 return 1, true
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
93 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
94 return 0, true
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
95 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
96 return 0, false
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
97 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
98
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
99 // numLess returns whether a < b.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
100 // a and b must necessarily have the same kind.
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
101 func numLess(a, b reflect.Value) bool {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
102 switch a.Kind() {
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
103 case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
104 return a.Int() < b.Int()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
105 case reflect.Float32, reflect.Float64:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
106 return a.Float() < b.Float()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
107 case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
108 return a.Uint() < b.Uint()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
109 case reflect.Bool:
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
110 return !a.Bool() && b.Bool()
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
111 }
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
112 panic("not a number")
787b5ee0289d Use vendored modules
yakumo.izuru
parents:
diff changeset
113 }