本文整理汇总了Golang中github.com/couchbase/query/value.Value.Actual方法的典型用法代码示例。如果您正苦于以下问题:Golang Value.Actual方法的具体用法?Golang Value.Actual怎么用?Golang Value.Actual使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/couchbase/query/value.Value
的用法示例。
在下文中一共展示了Value.Actual方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: Apply
/*
This method removes all the occurences of the second value from the
first array value.
*/
func (this *ArrayRemove) Apply(context Context, first, second value.Value) (value.Value, error) {
if first.Type() == value.MISSING {
return first, nil
}
if first.Type() != value.ARRAY {
return value.NULL_VALUE, nil
}
if second.Type() <= value.NULL {
return first, nil
}
fa := first.Actual().([]interface{})
if len(fa) == 0 {
return first, nil
}
ra := make([]interface{}, 0, len(fa))
for _, f := range fa {
if !second.Equals(value.NewValue(f)).Truth() {
ra = append(ra, f)
}
}
return value.NewValue(ra), nil
}
示例2: Apply
/*
This method takes in two values and returns a value that
corresponds to the first position of the regular expression
pattern (already set or populated using the second value)
in the first string value, or -1 if it isnt found. If the
input type is missing return missing, and if it isnt
string then return null value. Use the FindStringIndex
method in the regexp package to return a two-element slice
of integers defining the location of the leftmost match in
the string of the regular expression as per the Go Docs. Return
the first element of this slice as a value. If a FindStringIndex
returns nil, then the regexp pattern isnt found. Hence return -1.
*/
func (this *RegexpPosition) Apply(context Context, first, second value.Value) (value.Value, error) {
if first.Type() == value.MISSING || second.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else if first.Type() != value.STRING || second.Type() != value.STRING {
return value.NULL_VALUE, nil
}
f := first.Actual().(string)
s := second.Actual().(string)
re := this.re
if re == nil {
var err error
re, err = regexp.Compile(s)
if err != nil {
return nil, err
}
}
loc := re.FindStringIndex(f)
if loc == nil {
return value.NewValue(-1.0), nil
}
return value.NewValue(float64(loc[0])), nil
}
示例3: Apply
/*
Perform either case-sensitive or case-insensitive field lookup.
*/
func (this *Field) Apply(context Context, first, second value.Value) (value.Value, error) {
switch second.Type() {
case value.STRING:
s := second.Actual().(string)
v, ok := first.Field(s)
if !ok && this.caseInsensitive {
s = strings.ToLower(s)
fields := first.Fields()
for f, val := range fields {
if s == strings.ToLower(f) {
return value.NewValue(val), nil
}
}
}
return v, nil
case value.MISSING:
return value.MISSING_VALUE, nil
default:
if first.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else {
return value.NULL_VALUE, nil
}
}
}
示例4: Apply
/*
This method takes in an object, a name and a value
and returns a new object that contains the name /
attribute pair. If the type of input is missing
then return a missing value, and if not an object
return a null value.
If the key is found, an error is thrown
*/
func (this *ObjectAdd) Apply(context Context, first, second, third value.Value) (value.Value, error) {
// First must be an object, or we're out
if first.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else if first.Type() != value.OBJECT {
return value.NULL_VALUE, nil
}
// second must be a non empty string
if second.Type() != value.STRING || second.Actual().(string) == "" {
return first, nil
}
field := second.Actual().(string)
// we don't overwrite
_, exists := first.Field(field)
if exists {
return value.NULL_VALUE, nil
}
// SetField will remove if the attribute is missing, but we don't
// overwrite anyway, so we might just skip now
if third.Type() != value.MISSING {
rv := first.CopyForUpdate()
rv.SetField(field, third)
return rv, nil
}
return first, nil
}
示例5: Apply
/*
Return the neagation of the input value, if the type of input is a number.
For missing return a missing value, and for all other input types return a
null.
*/
func (this *Neg) Apply(context Context, arg value.Value) (value.Value, error) {
if arg.Type() == value.NUMBER {
return value.NewValue(-arg.Actual().(float64)), nil
} else if arg.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else {
return value.NULL_VALUE, nil
}
}
示例6: get
func (this *preparedCache) get(name value.Value) *Prepared {
if name.Type() != value.STRING || !name.Truth() {
return nil
}
this.RLock()
rv := this.prepareds[name.Actual().(string)]
this.RUnlock()
return rv
}
示例7: Apply
/*
This method returns the length of the object. If the type of
input is missing then return a missing value, and if not an
object return a null value. Convert it to a valid Go type.
Cast it to a map from string to interface and return its
length by using the len function by casting it to float64.
*/
func (this *ObjectLength) Apply(context Context, arg value.Value) (value.Value, error) {
if arg.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else if arg.Type() != value.OBJECT {
return value.NULL_VALUE, nil
}
oa := arg.Actual().(map[string]interface{})
return value.NewValue(float64(len(oa))), nil
}
示例8: testArrayInsert_eval
func testArrayInsert_eval(e1, e2, e3 Expression, er value.Value, t *testing.T) {
eai := NewArrayInsert(e1, e2, e3)
rv, err := eai.Evaluate(nil, nil)
if err != nil {
t.Errorf("received error %v", err)
}
if er.Collate(rv) != 0 {
t.Errorf("mismatch received %v expected %v", rv.Actual(), er.Actual())
}
}
示例9: Apply
/*
This method takes in two values and returns a value that
corresponds to the second expressions position in the
first. If the input type is missing return missing, and
if it isnt string then return null value. Use the Index
method defined by the strings package to calculate the
offset position of the second string. Return that value.
*/
func (this *Position) Apply(context Context, first, second value.Value) (value.Value, error) {
if first.Type() == value.MISSING || second.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else if first.Type() != value.STRING || second.Type() != value.STRING {
return value.NULL_VALUE, nil
}
rv := strings.Index(first.Actual().(string), second.Actual().(string))
return value.NewValue(float64(rv)), nil
}
示例10: Apply
/*
This method returns true if he value is an array and contains at least one element.
This is done by checking the length of the array. If the type of input value
is missing then return a missing value, and for all other types return null.
*/
func (this *Exists) Apply(context Context, arg value.Value) (value.Value, error) {
if arg.Type() == value.ARRAY {
a := arg.Actual().([]interface{})
return value.NewValue(len(a) > 0), nil
} else if arg.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else {
return value.NULL_VALUE, nil
}
}
示例11: testObjectRemove
func testObjectRemove(e1, e2 Expression, er value.Value, t *testing.T) {
eop := NewObjectRemove(e1, e2)
rv, err := eop.Evaluate(nil, nil)
if err != nil {
t.Errorf("received error %v", err)
}
if er.Collate(rv) != 0 {
t.Errorf("mismatch received %v expected %v", rv.Actual(), er.Actual())
}
}
示例12: Apply
/*
Evaluate the difference for the first and second input
values to return a value. If both values are numbers, calculate
the difference and return it. If either of the expressions are
missing then return a missing value. For all other cases return
a null value.
*/
func (this *Sub) Apply(context Context, first, second value.Value) (value.Value, error) {
if first.Type() == value.NUMBER && second.Type() == value.NUMBER {
diff := first.Actual().(float64) - second.Actual().(float64)
return value.NewValue(diff), nil
} else if first.Type() == value.MISSING || second.Type() == value.MISSING {
return value.MISSING_VALUE, nil
} else {
return value.NULL_VALUE, nil
}
}
示例13: Apply
/*
It returns the argument itself if type of the input value is Null,
a value below this (N!QL order) or an Array. Otherwise convert the
argument to a valid Go type ang cast it to a slice of interface.
*/
func (this *ToArray) Apply(context Context, arg value.Value) (value.Value, error) {
if arg.Type() <= value.NULL {
return arg, nil
} else if arg.Type() == value.ARRAY {
return arg, nil
} else if arg.Type() == value.BINARY {
return value.NULL_VALUE, nil
}
return value.NewValue([]interface{}{arg.Actual()}), nil
}
示例14: CumulateInitial
/*
Aggregates input data by evaluating operands. For all
values other than Number, return the input value itself. Call
cumulatePart to compute the intermediate aggregate value
and return it.
*/
func (this *Avg) CumulateInitial(item, cumulative value.Value, context Context) (value.Value, error) {
item, e := this.Operand().Evaluate(item, context)
if e != nil {
return nil, e
}
if item.Type() != value.NUMBER {
return cumulative, nil
}
part := value.NewValue(map[string]interface{}{"sum": item.Actual(), "count": 1})
return this.cumulatePart(part, cumulative, context)
}
示例15: Apply
func (this *Base64Decode) Apply(context Context, operand value.Value) (value.Value, error) {
if operand.Type() == value.MISSING {
return operand, nil
} else if operand.Type() != value.STRING {
return value.NULL_VALUE, nil
}
str, err := base64.StdEncoding.DecodeString(operand.Actual().(string))
if err != nil {
return value.NULL_VALUE, nil
} else {
return value.NewValue(str), nil
}
}