two new operators added: '<<' and '>>
This commit is contained in:
parent
f45b2c0a88
commit
353d495c50
66
operator-insert.go
Normal file
66
operator-insert.go
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
// Copyright (c) 2024 Celestino Amoroso (celestino.amoroso@gmail.com).
|
||||||
|
// All rights reserved.
|
||||||
|
|
||||||
|
// operator-insert.go
|
||||||
|
package expr
|
||||||
|
|
||||||
|
|
||||||
|
//-------- insert term
|
||||||
|
|
||||||
|
func newInsertTerm(tk *Token) (inst *term) {
|
||||||
|
return &term{
|
||||||
|
tk: *tk,
|
||||||
|
children: make([]*term, 0, 2),
|
||||||
|
position: posInfix,
|
||||||
|
priority: priSign,
|
||||||
|
evalFunc: evalInsert,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func newAppendTerm(tk *Token) (inst *term) {
|
||||||
|
return &term{
|
||||||
|
tk: *tk,
|
||||||
|
children: make([]*term, 0, 2),
|
||||||
|
position: posInfix,
|
||||||
|
priority: priSign,
|
||||||
|
evalFunc: evalAppend,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func evalInsert(ctx ExprContext, self *term) (v any, err error) {
|
||||||
|
var leftValue, rightValue any
|
||||||
|
|
||||||
|
if leftValue, rightValue, err = self.evalInfix(ctx); err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if isList(rightValue) {
|
||||||
|
list, _ := rightValue.([]any)
|
||||||
|
v = append([]any{leftValue}, list...)
|
||||||
|
} else {
|
||||||
|
err = self.errIncompatibleType(rightValue)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func evalAppend(ctx ExprContext, self *term) (v any, err error) {
|
||||||
|
var leftValue, rightValue any
|
||||||
|
|
||||||
|
if leftValue, rightValue, err = self.evalInfix(ctx); err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if isList(leftValue) {
|
||||||
|
list, _ := leftValue.([]any)
|
||||||
|
v = append(list, rightValue)
|
||||||
|
} else {
|
||||||
|
err = self.errIncompatibleType(leftValue)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// init
|
||||||
|
func init() {
|
||||||
|
registerTermConstructor(SymInsert, newInsertTerm)
|
||||||
|
registerTermConstructor(SymAppend, newAppendTerm)
|
||||||
|
}
|
@ -65,9 +65,7 @@ func evalPlus(ctx ExprContext, self *term) (v any, err error) {
|
|||||||
|
|
||||||
func newMinusTerm(tk *Token) (inst *term) {
|
func newMinusTerm(tk *Token) (inst *term) {
|
||||||
return &term{
|
return &term{
|
||||||
tk: *tk,
|
tk: *tk,
|
||||||
// class: classOperator,
|
|
||||||
// kind: kindUnknown,
|
|
||||||
children: make([]*term, 0, 2),
|
children: make([]*term, 0, 2),
|
||||||
position: posInfix,
|
position: posInfix,
|
||||||
priority: priSum,
|
priority: priSum,
|
||||||
|
@ -219,6 +219,8 @@ func (self *scanner) fetchNextToken() (tk *Token) {
|
|||||||
case '<':
|
case '<':
|
||||||
if next, _ := self.peek(); next == '=' {
|
if next, _ := self.peek(); next == '=' {
|
||||||
tk = self.moveOn(SymLessOrEqual, ch, next)
|
tk = self.moveOn(SymLessOrEqual, ch, next)
|
||||||
|
} else if next == '<' {
|
||||||
|
tk = self.moveOn(SymAppend, ch, next)
|
||||||
} else if next == '>' {
|
} else if next == '>' {
|
||||||
tk = self.moveOn(SymLessGreater, ch, next)
|
tk = self.moveOn(SymLessGreater, ch, next)
|
||||||
} else {
|
} else {
|
||||||
@ -227,6 +229,8 @@ func (self *scanner) fetchNextToken() (tk *Token) {
|
|||||||
case '>':
|
case '>':
|
||||||
if next, _ := self.peek(); next == '=' {
|
if next, _ := self.peek(); next == '=' {
|
||||||
tk = self.moveOn(SymGreaterOrEqual, ch, next)
|
tk = self.moveOn(SymGreaterOrEqual, ch, next)
|
||||||
|
} else if next == '>' {
|
||||||
|
tk = self.moveOn(SymInsert, ch, next)
|
||||||
} else {
|
} else {
|
||||||
tk = self.makeToken(SymGreater, ch)
|
tk = self.makeToken(SymGreater, ch)
|
||||||
}
|
}
|
||||||
|
@ -59,6 +59,8 @@ const (
|
|||||||
SymQuestionEqual // 48: '?='
|
SymQuestionEqual // 48: '?='
|
||||||
SymDoubleAt // 49: '@@'
|
SymDoubleAt // 49: '@@'
|
||||||
SymDoubleColon // 50: '::'
|
SymDoubleColon // 50: '::'
|
||||||
|
SymInsert // 51: '>>'
|
||||||
|
SymAppend // 52: '<<'
|
||||||
SymChangeSign
|
SymChangeSign
|
||||||
SymUnchangeSign
|
SymUnchangeSign
|
||||||
SymIdentifier
|
SymIdentifier
|
||||||
|
Loading…
Reference in New Issue
Block a user