operand-map.go replaced by operand-dict.go

This commit is contained in:
2024-05-19 01:20:04 +02:00
parent 263e419d9a
commit 2b184cf3f2
2 changed files with 65 additions and 34 deletions
+65
View File
@@ -4,6 +4,71 @@
// operand-dict.go
package expr
import (
"fmt"
"reflect"
"strings"
)
type DictType map[any]any
func newDict(dictAny []any) (dict *DictType) {
if dictAny != nil {
d := make(DictType, len(dictAny))
for i, item := range dictAny {
d[i] = item
}
dict = &d
}
return
}
func (dict *DictType) toMultiLine(sb *strings.Builder, indent int) {
first := true
for name, value := range *dict {
if first {
first = false
} else {
sb.WriteByte(',')
sb.WriteByte('\n')
}
sb.WriteString(strings.Repeat("\t", indent+1))
if key, ok := name.(string); ok {
sb.WriteString(key)
} else {
sb.WriteString(fmt.Sprintf("%v", name))
}
sb.WriteString(": ")
if f, ok := value.(Formatter); ok {
sb.WriteString(f.ToString(0))
} else if _, ok = value.(Functor); ok {
sb.WriteString("func(){}")
} else {
sb.WriteString(fmt.Sprintf("%v", value))
}
}
sb.WriteString(strings.Repeat("\t", indent))
sb.WriteString("\n}\n")
}
func (dict *DictType) ToString(opt FmtOpt) string {
var sb strings.Builder
if opt&MultiLine != 0 {
dict.toMultiLine(&sb, 0)
}
return sb.String()
}
func (dict *DictType) hasKey(d map[any]any, target any) (ok bool) {
for key := range *dict {
if ok = reflect.DeepEqual(key, target); ok {
break
}
}
return
}
// -------- dict term
func newDictTerm(args map[any]*term) *term {
return &term{