New prefix operators ++ and --
This commit is contained in:
parent
6b3351b324
commit
0f848071c2
@ -1,7 +1,7 @@
|
|||||||
// Copyright (c) 2024 Celestino Amoroso (celestino.amoroso@gmail.com).
|
// Copyright (c) 2024 Celestino Amoroso (celestino.amoroso@gmail.com).
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
|
|
||||||
// operator-post-inc.go
|
// operator-post-inc-dec.go
|
||||||
package expr
|
package expr
|
||||||
|
|
||||||
// -------- post increment term
|
// -------- post increment term
|
69
operator-pre-inc-dec.go
Normal file
69
operator-pre-inc-dec.go
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
// Copyright (c) 2024 Celestino Amoroso (celestino.amoroso@gmail.com).
|
||||||
|
// All rights reserved.
|
||||||
|
|
||||||
|
// operator-pre-inc-dec.go
|
||||||
|
package expr
|
||||||
|
|
||||||
|
// -------- pre increment term
|
||||||
|
|
||||||
|
func newPreIncTerm(tk *Token) *term {
|
||||||
|
return &term{
|
||||||
|
tk: *tk,
|
||||||
|
parent: nil,
|
||||||
|
children: make([]*term, 0, 1),
|
||||||
|
position: posPrefix,
|
||||||
|
priority: priIncDec,
|
||||||
|
evalFunc: evalPreInc,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func evalPreInc(ctx ExprContext, opTerm *term) (v any, err error) {
|
||||||
|
var childValue any
|
||||||
|
if childValue, err = opTerm.evalPrefix(ctx); err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if IsInteger(childValue) && opTerm.children[0].symbol() == SymVariable {
|
||||||
|
i := childValue.(int64) + 1
|
||||||
|
ctx.SetVar(opTerm.children[0].source(), i)
|
||||||
|
v = i
|
||||||
|
} else {
|
||||||
|
err = opTerm.errIncompatibleType(childValue)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// -------- pre decrement term
|
||||||
|
|
||||||
|
func newPreDecTerm(tk *Token) *term {
|
||||||
|
return &term{
|
||||||
|
tk: *tk,
|
||||||
|
parent: nil,
|
||||||
|
children: make([]*term, 0, 1),
|
||||||
|
position: posPrefix,
|
||||||
|
priority: priIncDec,
|
||||||
|
evalFunc: evalPreDec,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func evalPreDec(ctx ExprContext, opTerm *term) (v any, err error) {
|
||||||
|
var childValue any
|
||||||
|
if childValue, err = opTerm.evalPrefix(ctx); err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if IsInteger(childValue) && opTerm.children[0].symbol() == SymVariable {
|
||||||
|
i := childValue.(int64) - 1
|
||||||
|
ctx.SetVar(opTerm.children[0].source(), i)
|
||||||
|
v = i
|
||||||
|
} else {
|
||||||
|
err = opTerm.errIncompatibleType(childValue)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// init
|
||||||
|
func init() {
|
||||||
|
registerTermConstructor(SymPreInc, newPreIncTerm)
|
||||||
|
registerTermConstructor(SymPreDec, newPreDecTerm)
|
||||||
|
}
|
36
parser.go
36
parser.go
@ -409,6 +409,23 @@ func listSubTree(tree *ast, listTerm *term, allowIndeces bool) (root *term, err
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func changePrefix(tk *Token) {
|
||||||
|
switch tk.Sym {
|
||||||
|
case SymMinus:
|
||||||
|
tk.SetSymbol(SymChangeSign)
|
||||||
|
case SymPlus:
|
||||||
|
tk.SetSymbol(SymUnchangeSign)
|
||||||
|
case SymStar:
|
||||||
|
tk.SetSymbol(SymDereference)
|
||||||
|
case SymExclamation:
|
||||||
|
tk.SetSymbol(SymNot)
|
||||||
|
case SymDoublePlus:
|
||||||
|
tk.SetSymbol(SymPreInc)
|
||||||
|
case SymDoubleMinus:
|
||||||
|
tk.SetSymbol(SymPreDec)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (parser *parser) parseGeneral(scanner *scanner, ctx parserContext, termSymbols ...Symbol) (tree *ast, err error) {
|
func (parser *parser) parseGeneral(scanner *scanner, ctx parserContext, termSymbols ...Symbol) (tree *ast, err error) {
|
||||||
var selectorTerm *term = nil
|
var selectorTerm *term = nil
|
||||||
var currentTerm *term = nil
|
var currentTerm *term = nil
|
||||||
@ -437,15 +454,16 @@ func (parser *parser) parseGeneral(scanner *scanner, ctx parserContext, termSymb
|
|||||||
|
|
||||||
//fmt.Println("Token:", tk)
|
//fmt.Println("Token:", tk)
|
||||||
if firstToken {
|
if firstToken {
|
||||||
if tk.Sym == SymMinus {
|
changePrefix(tk)
|
||||||
tk.Sym = SymChangeSign
|
// if tk.Sym == SymMinus {
|
||||||
} else if tk.Sym == SymPlus {
|
// tk.Sym = SymChangeSign
|
||||||
tk.Sym = SymUnchangeSign
|
// } else if tk.Sym == SymPlus {
|
||||||
} else if tk.IsSymbol(SymStar) {
|
// tk.Sym = SymUnchangeSign
|
||||||
tk.SetSymbol(SymDereference)
|
// } else if tk.IsSymbol(SymStar) {
|
||||||
} else if tk.IsSymbol(SymExclamation) {
|
// tk.SetSymbol(SymDereference)
|
||||||
tk.SetSymbol(SymNot)
|
// } else if tk.IsSymbol(SymExclamation) {
|
||||||
}
|
// tk.SetSymbol(SymNot)
|
||||||
|
// }
|
||||||
firstToken = false
|
firstToken = false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,6 +103,8 @@ func init() {
|
|||||||
SymCaretEqual: {"^=", symClassOperator, posInfix}, // 66: '^='
|
SymCaretEqual: {"^=", symClassOperator, posInfix}, // 66: '^='
|
||||||
SymPlusGreater: {"+>", symClassOperator, posInfix}, // 67: '+>'
|
SymPlusGreater: {"+>", symClassOperator, posInfix}, // 67: '+>'
|
||||||
SymLessPlus: {"<+", symClassOperator, posInfix}, // 68: '<+'
|
SymLessPlus: {"<+", symClassOperator, posInfix}, // 68: '<+'
|
||||||
|
SymPreInc: {"++", symClassOperator, posPrefix}, // : '++'
|
||||||
|
SymPreDec: {"--", symClassOperator, posPrefix}, // : '--'
|
||||||
// SymChangeSign
|
// SymChangeSign
|
||||||
// SymUnchangeSign
|
// SymUnchangeSign
|
||||||
// SymIdentifier
|
// SymIdentifier
|
||||||
|
Loading…
Reference in New Issue
Block a user