2024-05-26 06:19:08 +02:00
|
|
|
// Copyright (c) 2024 Celestino Amoroso (celestino.amoroso@gmail.com).
|
|
|
|
// All rights reserved.
|
|
|
|
|
|
|
|
// operator-range.go
|
|
|
|
package expr
|
|
|
|
|
|
|
|
import "fmt"
|
|
|
|
|
|
|
|
// -------- range term
|
|
|
|
type intPair struct {
|
|
|
|
a, b int
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *intPair) TypeName() string {
|
2024-06-06 05:31:35 +02:00
|
|
|
return TypePair
|
2024-05-26 06:19:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (p *intPair) ToString(opt FmtOpt) string {
|
|
|
|
return fmt.Sprintf("(%d, %d)", p.a, p.b)
|
|
|
|
}
|
|
|
|
|
|
|
|
func isIntPair(v any) bool {
|
|
|
|
_, ok := v.(*intPair)
|
|
|
|
return ok
|
|
|
|
}
|
|
|
|
|
|
|
|
func newRangeTerm(tk *Token) (inst *term) {
|
|
|
|
return &term{
|
|
|
|
tk: *tk,
|
|
|
|
children: make([]*term, 0, 2),
|
|
|
|
position: posInfix,
|
2024-06-19 09:20:02 +02:00
|
|
|
priority: priRange,
|
2024-05-26 06:19:08 +02:00
|
|
|
evalFunc: evalRange,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-09 07:50:06 +02:00
|
|
|
func evalRange(ctx ExprContext, opTerm *term) (v any, err error) {
|
2024-05-26 06:19:08 +02:00
|
|
|
var leftValue, rightValue any
|
|
|
|
|
|
|
|
// if err = self.checkOperands(); err != nil {
|
|
|
|
// return
|
|
|
|
// }
|
2024-07-09 07:50:06 +02:00
|
|
|
if len(opTerm.children) == 0 {
|
2024-05-26 06:19:08 +02:00
|
|
|
leftValue = int64(0)
|
|
|
|
rightValue = int64(-1)
|
2024-07-09 07:50:06 +02:00
|
|
|
} else if len(opTerm.children) == 1 {
|
|
|
|
if leftValue, err = opTerm.children[0].compute(ctx); err != nil {
|
2024-05-26 06:19:08 +02:00
|
|
|
return
|
|
|
|
}
|
2024-06-19 09:20:02 +02:00
|
|
|
rightValue = int64(ConstLastIndex)
|
2024-07-09 07:50:06 +02:00
|
|
|
} else if leftValue, rightValue, err = opTerm.evalInfix(ctx); err != nil {
|
2024-05-26 06:19:08 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
if !(IsInteger(leftValue) && IsInteger(rightValue)) {
|
2024-07-09 07:50:06 +02:00
|
|
|
err = opTerm.errIncompatibleTypes(leftValue, rightValue)
|
2024-05-26 06:19:08 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
startIndex, _ := leftValue.(int64)
|
|
|
|
endIndex, _ := rightValue.(int64)
|
|
|
|
|
|
|
|
v = &intPair{int(startIndex), int(endIndex)}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// init
|
|
|
|
func init() {
|
|
|
|
registerTermConstructor(SymColon, newRangeTerm)
|
|
|
|
}
|