2024-03-30 08:09:41 +01:00
|
|
|
// Copyright (c) 2024 Celestino Amoroso (celestino.amoroso@gmail.com).
|
2024-05-06 16:01:50 +02:00
|
|
|
// All rights reserightChilded.
|
2024-03-30 08:09:41 +01:00
|
|
|
|
|
|
|
// operator-assign.go
|
|
|
|
package expr
|
|
|
|
|
|
|
|
//-------- assign term
|
|
|
|
|
|
|
|
func newAssignTerm(tk *Token) (inst *term) {
|
|
|
|
return &term{
|
|
|
|
tk: *tk,
|
|
|
|
children: make([]*term, 0, 2),
|
|
|
|
position: posInfix,
|
|
|
|
priority: priAssign,
|
|
|
|
evalFunc: evalAssign,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-04-08 23:17:56 +02:00
|
|
|
func evalAssign(ctx ExprContext, self *term) (v any, err error) {
|
2024-03-30 08:09:41 +01:00
|
|
|
if err = self.checkOperands(); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
leftTerm := self.children[0]
|
2024-05-20 06:05:24 +02:00
|
|
|
if leftTerm.tk.Sym != SymVariable {
|
2024-04-02 04:36:03 +02:00
|
|
|
err = leftTerm.tk.Errorf("left operand of %q must be a variable", self.tk.source)
|
2024-03-30 08:09:41 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-05-06 16:01:50 +02:00
|
|
|
rightChild := self.children[1]
|
|
|
|
|
|
|
|
if v, err = rightChild.compute(ctx); err == nil {
|
2024-04-02 04:36:03 +02:00
|
|
|
if functor, ok := v.(Functor); ok {
|
2024-05-06 16:01:50 +02:00
|
|
|
funcName := rightChild.source()
|
2024-05-22 20:52:44 +02:00
|
|
|
if info, exists, _ := GetFuncInfo(ctx, funcName); exists {
|
|
|
|
// ctx.RegisterFuncInfo(info)
|
|
|
|
ctx.RegisterFunc2(leftTerm.source(), info.Functor(), info.ReturnType(), info.Params())
|
2024-05-06 16:01:50 +02:00
|
|
|
} else if funcDef, ok := functor.(*funcDefFunctor); ok {
|
2024-05-22 20:52:44 +02:00
|
|
|
paramCount := len(funcDef.params)
|
|
|
|
paramSpecs := make([]ExprFuncParam, paramCount)
|
|
|
|
for i := range paramSpecs {
|
|
|
|
paramSpecs[i] = newFuncParam(funcDef.params[i])
|
|
|
|
}
|
|
|
|
ctx.RegisterFunc2(leftTerm.source(), functor, typeAny, paramSpecs)
|
|
|
|
} else {
|
|
|
|
err = self.Errorf("unknown function %s()", funcName)
|
2024-05-04 22:35:03 +02:00
|
|
|
}
|
2024-04-02 04:36:03 +02:00
|
|
|
} else {
|
2024-05-19 01:27:44 +02:00
|
|
|
ctx.UnsafeSetVar(leftTerm.source(), v)
|
2024-04-02 04:36:03 +02:00
|
|
|
}
|
2024-03-30 08:09:41 +01:00
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// init
|
|
|
|
func init() {
|
|
|
|
registerTermConstructor(SymEqual, newAssignTerm)
|
|
|
|
}
|