summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/d5/tengo/objects/map.go
diff options
context:
space:
mode:
authorWim <wim@42.be>2020-01-09 21:52:19 +0100
committerGitHub <noreply@github.com>2020-01-09 21:52:19 +0100
commit9d84d6dd643c4017074e81465671cd9b25f9539a (patch)
tree8a767f91d655a6cf21d476e4fb7aa6fd8a952df8 /vendor/github.com/d5/tengo/objects/map.go
parent0f708daf2d14dcca261ef98cc698a1b1f2a6aa74 (diff)
downloadmatterbridge-msglm-9d84d6dd643c4017074e81465671cd9b25f9539a.tar.gz
matterbridge-msglm-9d84d6dd643c4017074e81465671cd9b25f9539a.tar.bz2
matterbridge-msglm-9d84d6dd643c4017074e81465671cd9b25f9539a.zip
Update to tengo v2 (#976)
Diffstat (limited to 'vendor/github.com/d5/tengo/objects/map.go')
-rw-r--r--vendor/github.com/d5/tengo/objects/map.go118
1 files changed, 0 insertions, 118 deletions
diff --git a/vendor/github.com/d5/tengo/objects/map.go b/vendor/github.com/d5/tengo/objects/map.go
deleted file mode 100644
index 9208872c..00000000
--- a/vendor/github.com/d5/tengo/objects/map.go
+++ /dev/null
@@ -1,118 +0,0 @@
-package objects
-
-import (
- "fmt"
- "strings"
-
- "github.com/d5/tengo/compiler/token"
-)
-
-// Map represents a map of objects.
-type Map struct {
- Value map[string]Object
-}
-
-// TypeName returns the name of the type.
-func (o *Map) TypeName() string {
- return "map"
-}
-
-func (o *Map) String() string {
- var pairs []string
- for k, v := range o.Value {
- pairs = append(pairs, fmt.Sprintf("%s: %s", k, v.String()))
- }
-
- return fmt.Sprintf("{%s}", strings.Join(pairs, ", "))
-}
-
-// BinaryOp returns another object that is the result of
-// a given binary operator and a right-hand side object.
-func (o *Map) BinaryOp(op token.Token, rhs Object) (Object, error) {
- return nil, ErrInvalidOperator
-}
-
-// Copy returns a copy of the type.
-func (o *Map) Copy() Object {
- c := make(map[string]Object)
- for k, v := range o.Value {
- c[k] = v.Copy()
- }
-
- return &Map{Value: c}
-}
-
-// IsFalsy returns true if the value of the type is falsy.
-func (o *Map) IsFalsy() bool {
- return len(o.Value) == 0
-}
-
-// Equals returns true if the value of the type
-// is equal to the value of another object.
-func (o *Map) Equals(x Object) bool {
- var xVal map[string]Object
- switch x := x.(type) {
- case *Map:
- xVal = x.Value
- case *ImmutableMap:
- xVal = x.Value
- default:
- return false
- }
-
- if len(o.Value) != len(xVal) {
- return false
- }
-
- for k, v := range o.Value {
- tv := xVal[k]
- if !v.Equals(tv) {
- return false
- }
- }
-
- return true
-}
-
-// IndexGet returns the value for the given key.
-func (o *Map) IndexGet(index Object) (res Object, err error) {
- strIdx, ok := ToString(index)
- if !ok {
- err = ErrInvalidIndexType
- return
- }
-
- val, ok := o.Value[strIdx]
- if !ok {
- val = UndefinedValue
- }
-
- return val, nil
-}
-
-// IndexSet sets the value for the given key.
-func (o *Map) IndexSet(index, value Object) (err error) {
- strIdx, ok := ToString(index)
- if !ok {
- err = ErrInvalidIndexType
- return
- }
-
- o.Value[strIdx] = value
-
- return nil
-}
-
-// Iterate creates a map iterator.
-func (o *Map) Iterate() Iterator {
- var keys []string
- for k := range o.Value {
- keys = append(keys, k)
- }
-
- return &MapIterator{
- v: o.Value,
- k: keys,
- l: len(keys),
- }
-}