Documentation ¶
Index ¶
- Constants
- Variables
- func ReadBoolFromReader(r io.Reader) (bool, error)
- func ReadFloatFromReader(r io.Reader) (float64, error)
- func ReadIntFromReader(r io.Reader) (uint64, error)
- func ReadStringFromReader(r io.Reader) (string, error)
- func WriteBoolToWriter(w io.Writer, b bool) error
- func WriteFloatToWriter(w io.Writer, f float64) error
- func WriteFull(w io.Writer, bytes []byte) (int, error)
- func WriteIntToWriter(w io.Writer, i uint64) error
- func WriteStringToWriter(w io.Writer, s string) error
- type ArgumentList
- func (e *ArgumentList) AcceptExpression(exp *Expression) error
- func (e *ArgumentList) Clone(cloneTable *pkg.CloneTable) *ArgumentList
- func (e *ArgumentList) Evaluate(dataContext IDataContext, memory *WorkingMemory) ([]reflect.Value, error)
- func (e *ArgumentList) GetAstID() string
- func (e *ArgumentList) GetGrlText() string
- func (e *ArgumentList) GetSnapshot() string
- func (e *ArgumentList) MakeCatalog(cat *Catalog)
- func (e *ArgumentList) SetGrlText(grlText string)
- type ArgumentListMeta
- type ArgumentListReceiver
- type ArrayMapSelector
- func (e *ArrayMapSelector) AcceptExpression(exp *Expression) error
- func (e *ArrayMapSelector) Clone(cloneTable *pkg.CloneTable) *ArrayMapSelector
- func (e *ArrayMapSelector) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
- func (e *ArrayMapSelector) GetAstID() string
- func (e *ArrayMapSelector) GetGrlText() string
- func (e *ArrayMapSelector) GetSnapshot() string
- func (e *ArrayMapSelector) MakeCatalog(cat *Catalog)
- func (e *ArrayMapSelector) SetGrlText(grlText string)
- type ArrayMapSelectorMeta
- type ArrayMapSelectorReceiver
- type AssigmentMeta
- type Assignment
- func (e *Assignment) AcceptExpression(exp *Expression) error
- func (e *Assignment) AcceptVariable(vari *Variable) error
- func (e *Assignment) Clone(cloneTable *pkg.CloneTable) *Assignment
- func (e *Assignment) Execute(dataContext IDataContext, memory *WorkingMemory) error
- func (e *Assignment) GetAstID() string
- func (e *Assignment) GetGrlText() string
- func (e *Assignment) GetSnapshot() string
- func (e *Assignment) MakeCatalog(cat *Catalog)
- func (e *Assignment) SetGrlText(grlText string)
- type AssignmentReceiver
- type BooleanLiteral
- type BooleanLiteralReceiver
- type BuiltInFunctions
- func (gf *BuiltInFunctions) Abs(x float64) float64
- func (gf *BuiltInFunctions) Acos(x float64) float64
- func (gf *BuiltInFunctions) Acosh(x float64) float64
- func (gf *BuiltInFunctions) Asin(x float64) float64
- func (gf *BuiltInFunctions) Asinh(x float64) float64
- func (gf *BuiltInFunctions) Atan(x float64) float64
- func (gf *BuiltInFunctions) Atan2(y, x float64) float64
- func (gf *BuiltInFunctions) Atanh(x float64) float64
- func (gf *BuiltInFunctions) Cbrt(x float64) float64
- func (gf *BuiltInFunctions) Ceil(x float64) float64
- func (gf *BuiltInFunctions) Changed(variableName string)
- func (gf *BuiltInFunctions) Complete()
- func (gf *BuiltInFunctions) Copysign(x, y float64) float64
- func (gf *BuiltInFunctions) Cos(x float64) float64
- func (gf *BuiltInFunctions) Cosh(x float64) float64
- func (gf *BuiltInFunctions) Dim(x, y float64) float64
- func (gf *BuiltInFunctions) Erf(x float64) float64
- func (gf *BuiltInFunctions) Erfc(x float64) float64
- func (gf *BuiltInFunctions) Erfcinv(x float64) float64
- func (gf *BuiltInFunctions) Erfinv(x float64) float64
- func (gf *BuiltInFunctions) Exp(x float64) float64
- func (gf *BuiltInFunctions) Exp2(x float64) float64
- func (gf *BuiltInFunctions) Expm1(x float64) float64
- func (gf *BuiltInFunctions) Float64bits(f float64) uint64
- func (gf *BuiltInFunctions) Float64frombits(b uint64) float64
- func (gf *BuiltInFunctions) Floor(x float64) float64
- func (gf *BuiltInFunctions) Forget(snippet string)
- func (gf *BuiltInFunctions) Gamma(x float64) float64
- func (gf *BuiltInFunctions) GetTimeDay(time time.Time) int
- func (gf *BuiltInFunctions) GetTimeHour(time time.Time) int
- func (gf *BuiltInFunctions) GetTimeMinute(time time.Time) int
- func (gf *BuiltInFunctions) GetTimeMonth(time time.Time) int
- func (gf *BuiltInFunctions) GetTimeSecond(time time.Time) int
- func (gf *BuiltInFunctions) GetTimeYear(time time.Time) int
- func (gf *BuiltInFunctions) Hypot(p, q float64) float64
- func (gf *BuiltInFunctions) Ilogb(x float64) int
- func (gf *BuiltInFunctions) IsInf(f float64, sign int64) bool
- func (gf *BuiltInFunctions) IsNaN(f float64) (is bool)
- func (gf *BuiltInFunctions) IsNil(i interface{}) bool
- func (gf *BuiltInFunctions) IsTimeAfter(time, after time.Time) bool
- func (gf *BuiltInFunctions) IsTimeBefore(time, before time.Time) bool
- func (gf *BuiltInFunctions) IsZero(i interface{}) bool
- func (gf *BuiltInFunctions) J0(x float64) float64
- func (gf *BuiltInFunctions) J1(x float64) float64
- func (gf *BuiltInFunctions) Jn(n int64, x float64) float64
- func (gf *BuiltInFunctions) Ldexp(frac float64, exp int64) float64
- func (gf *BuiltInFunctions) Log(text string)
- func (gf *BuiltInFunctions) Log10(x float64) float64
- func (gf *BuiltInFunctions) Log1p(x float64) float64
- func (gf *BuiltInFunctions) Log2(x float64) float64
- func (gf *BuiltInFunctions) LogFormat(format string, i interface{})
- func (gf *BuiltInFunctions) Logb(x float64) float64
- func (gf *BuiltInFunctions) MakeTime(year, month, day, hour, minute, second int64) time.Time
- func (gf *BuiltInFunctions) MathLog(x float64) float64
- func (gf *BuiltInFunctions) Max(vals ...float64) float64
- func (gf *BuiltInFunctions) Min(vals ...float64) float64
- func (gf *BuiltInFunctions) Mod(x, y float64) float64
- func (gf *BuiltInFunctions) NaN() float64
- func (gf *BuiltInFunctions) Now() time.Time
- func (gf *BuiltInFunctions) Pow(x, y float64) float64
- func (gf *BuiltInFunctions) Pow10(n int64) float64
- func (gf *BuiltInFunctions) Remainder(x, y float64) float64
- func (gf *BuiltInFunctions) Retract(ruleName string)
- func (gf *BuiltInFunctions) Round(x float64) float64
- func (gf *BuiltInFunctions) RoundToEven(x float64) float64
- func (gf *BuiltInFunctions) Signbit(x float64) bool
- func (gf *BuiltInFunctions) Sin(x float64) float64
- func (gf *BuiltInFunctions) Sinh(x float64) float64
- func (gf *BuiltInFunctions) Sqrt(x float64) float64
- func (gf *BuiltInFunctions) StringContains(str, substr string) bool
- func (gf *BuiltInFunctions) Tan(x float64) float64
- func (gf *BuiltInFunctions) Tanh(x float64) float64
- func (gf *BuiltInFunctions) TimeFormat(time time.Time, layout string) string
- func (gf *BuiltInFunctions) Trunc(x float64) float64
- type Catalog
- type Constant
- func (e *Constant) AcceptBooleanLiteral(fun *BooleanLiteral)
- func (e *Constant) AcceptFloatLiteral(fun *FloatLiteral)
- func (e *Constant) AcceptIntegerLiteral(fun *IntegerLiteral)
- func (e *Constant) AcceptStringLiteral(fun *StringLiteral)
- func (e *Constant) Clone(cloneTable *pkg.CloneTable) *Constant
- func (e *Constant) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
- func (e *Constant) GetAstID() string
- func (e *Constant) GetGrlText() string
- func (e *Constant) GetSnapshot() string
- func (e *Constant) MakeCatalog(cat *Catalog)
- func (e *Constant) SetGrlText(grlText string)
- type ConstantMeta
- type ConstantReceiver
- type DataContext
- func (ctx *DataContext) Add(key string, obj interface{}) error
- func (ctx *DataContext) AddJSON(key string, JSON []byte) error
- func (ctx *DataContext) Complete()
- func (ctx *DataContext) Get(key string) model.ValueNode
- func (ctx *DataContext) HasVariableChange() bool
- func (ctx *DataContext) IncrementVariableChangeCount()
- func (ctx *DataContext) IsComplete() bool
- func (ctx *DataContext) IsRetracted(key string) bool
- func (ctx *DataContext) Reset()
- func (ctx *DataContext) ResetVariableChangeCount()
- func (ctx *DataContext) Retract(key string)
- func (ctx *DataContext) Retracted() []string
- type Expression
- func (e *Expression) AcceptExpression(exp *Expression) error
- func (e *Expression) AcceptExpressionAtom(atom *ExpressionAtom) error
- func (e *Expression) Clone(cloneTable *pkg.CloneTable) *Expression
- func (e *Expression) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
- func (e *Expression) GetAstID() string
- func (e *Expression) GetGrlText() string
- func (e *Expression) GetSnapshot() string
- func (e *Expression) MakeCatalog(cat *Catalog)
- func (e *Expression) SetGrlText(grlText string)
- type ExpressionAtom
- func (e *ExpressionAtom) AcceptArrayMapSelector(sel *ArrayMapSelector) error
- func (e *ExpressionAtom) AcceptConstant(cons *Constant) error
- func (e *ExpressionAtom) AcceptExpressionAtom(ea *ExpressionAtom) error
- func (e *ExpressionAtom) AcceptFunctionCall(fun *FunctionCall) error
- func (e *ExpressionAtom) AcceptMemberVariable(name string)
- func (e *ExpressionAtom) AcceptVariable(vari *Variable) error
- func (e *ExpressionAtom) Clone(cloneTable *pkg.CloneTable) *ExpressionAtom
- func (e *ExpressionAtom) Evaluate(dataContext IDataContext, memory *WorkingMemory) (val reflect.Value, err error)
- func (e *ExpressionAtom) GetAstID() string
- func (e *ExpressionAtom) GetGrlText() string
- func (e *ExpressionAtom) GetSnapshot() string
- func (e *ExpressionAtom) MakeCatalog(cat *Catalog)
- func (e *ExpressionAtom) SetGrlText(grlText string)
- type ExpressionAtomMeta
- type ExpressionAtomReceiver
- type ExpressionMeta
- type ExpressionReceiver
- type FloatLiteral
- type FloatLiteralReceiver
- type FunctionCall
- func (e *FunctionCall) AcceptArgumentList(argList *ArgumentList) error
- func (e *FunctionCall) Clone(cloneTable *pkg.CloneTable) *FunctionCall
- func (e *FunctionCall) EvaluateArgumentList(dataContext IDataContext, memory *WorkingMemory) ([]reflect.Value, error)
- func (e *FunctionCall) GetAstID() string
- func (e *FunctionCall) GetGrlText() string
- func (e *FunctionCall) GetSnapshot() string
- func (e *FunctionCall) MakeCatalog(cat *Catalog)
- func (e *FunctionCall) SetGrlText(grlText string)
- type FunctionCallMeta
- type FunctionCallReceiver
- type Grl
- type GrlReceiver
- type IDataContext
- type IntegerLiteral
- type IntegerLiteralReceiver
- type KnowledgeBase
- func (e *KnowledgeBase) AddRuleEntry(entry *RuleEntry) error
- func (e *KnowledgeBase) Clone(cloneTable *pkg.CloneTable) *KnowledgeBase
- func (e *KnowledgeBase) ContainsRuleEntry(name string) bool
- func (e *KnowledgeBase) GetSnapshot() string
- func (e *KnowledgeBase) InitializeContext(dataCtx IDataContext)
- func (e *KnowledgeBase) IsIdentical(that *KnowledgeBase) bool
- func (e *KnowledgeBase) IsRuleRetracted(ruleName string) bool
- func (e *KnowledgeBase) MakeCatalog() *Catalog
- func (e *KnowledgeBase) RemoveRuleEntry(name string)
- func (e *KnowledgeBase) Reset()
- func (e *KnowledgeBase) RetractRule(ruleName string)
- type KnowledgeLibrary
- func (lib *KnowledgeLibrary) GetKnowledgeBase(name, version string) *KnowledgeBase
- func (lib *KnowledgeLibrary) LoadKnowledgeBaseFromReader(reader io.Reader, overwrite bool) (retKb *KnowledgeBase, retErr error)
- func (lib *KnowledgeLibrary) NewKnowledgeBaseInstance(name, version string) *KnowledgeBase
- func (lib *KnowledgeLibrary) StoreKnowledgeBaseToWriter(writer io.Writer, name, version string) error
- type MemberVariableReceiver
- type Meta
- type Node
- type NodeMeta
- type NodeType
- type RuleEntry
- func (e *RuleEntry) AcceptSalience(salience *Salience) error
- func (e *RuleEntry) AcceptThenScope(thenScope *ThenScope) error
- func (e *RuleEntry) AcceptWhenScope(when *WhenScope) error
- func (e *RuleEntry) Clone(cloneTable *pkg.CloneTable) *RuleEntry
- func (e *RuleEntry) Evaluate(dataContext IDataContext, memory *WorkingMemory) (bool, error)
- func (e *RuleEntry) Execute(dataContext IDataContext, memory *WorkingMemory) (err error)
- func (e *RuleEntry) GetAstID() string
- func (e *RuleEntry) GetGrlText() string
- func (e *RuleEntry) GetSnapshot() string
- func (e *RuleEntry) MakeCatalog(cat *Catalog)
- func (e *RuleEntry) SetGrlText(grlText string)
- type RuleEntryMeta
- type RuleEntryReceiver
- type Salience
- type SalienceReceiver
- type StringLiteral
- type StringLiteralReceiver
- type ThenExpression
- func (e *ThenExpression) AcceptAssignment(assignment *Assignment) error
- func (e *ThenExpression) AcceptExpressionAtom(exp *ExpressionAtom) error
- func (e *ThenExpression) Clone(cloneTable *pkg.CloneTable) *ThenExpression
- func (e *ThenExpression) Execute(dataContext IDataContext, memory *WorkingMemory) error
- func (e *ThenExpression) GetAstID() string
- func (e *ThenExpression) GetGrlText() string
- func (e *ThenExpression) GetSnapshot() string
- func (e *ThenExpression) MakeCatalog(cat *Catalog)
- func (e *ThenExpression) SetGrlText(grlText string)
- type ThenExpressionList
- func (e *ThenExpressionList) AcceptThenExpression(expr *ThenExpression) error
- func (e *ThenExpressionList) Clone(cloneTable *pkg.CloneTable) *ThenExpressionList
- func (e *ThenExpressionList) Execute(dataContext IDataContext, memory *WorkingMemory) error
- func (e *ThenExpressionList) GetAstID() string
- func (e *ThenExpressionList) GetGrlText() string
- func (e *ThenExpressionList) GetSnapshot() string
- func (e *ThenExpressionList) MakeCatalog(cat *Catalog)
- func (e *ThenExpressionList) SetGrlText(grlText string)
- type ThenExpressionListMeta
- type ThenExpressionListReceiver
- type ThenExpressionMeta
- type ThenExpressionReceiver
- type ThenScope
- func (e *ThenScope) AcceptThenExpressionList(list *ThenExpressionList) error
- func (e *ThenScope) Clone(cloneTable *pkg.CloneTable) *ThenScope
- func (e *ThenScope) Execute(dataContext IDataContext, memory *WorkingMemory) error
- func (e *ThenScope) GetAstID() string
- func (e *ThenScope) GetGrlText() string
- func (e *ThenScope) GetSnapshot() string
- func (e *ThenScope) MakeCatalog(cat *Catalog)
- func (e *ThenScope) SetGrlText(grlText string)
- type ThenScopeMeta
- type ThenScopeReceiver
- type ValueType
- type Variable
- func (e *Variable) AcceptArrayMapSelector(sel *ArrayMapSelector) error
- func (e *Variable) AcceptMemberVariable(name string)
- func (e *Variable) AcceptVariable(vari *Variable) error
- func (e *Variable) Assign(newVal reflect.Value, dataContext IDataContext, memory *WorkingMemory) error
- func (e *Variable) Clone(cloneTable *pkg.CloneTable) *Variable
- func (e *Variable) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
- func (e *Variable) GetAstID() string
- func (e *Variable) GetGrlText() string
- func (e *Variable) GetSnapshot() string
- func (e *Variable) MakeCatalog(cat *Catalog)
- func (e *Variable) SetGrlText(grlText string)
- type VariableMeta
- type VariableReceiver
- type WhenScope
- func (e *WhenScope) AcceptExpression(exp *Expression) error
- func (e *WhenScope) Clone(cloneTable *pkg.CloneTable) *WhenScope
- func (e *WhenScope) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
- func (e *WhenScope) GetAstID() string
- func (e *WhenScope) GetGrlText() string
- func (e *WhenScope) GetSnapshot() string
- func (e *WhenScope) MakeCatalog(cat *Catalog)
- func (e *WhenScope) SetGrlText(grlText string)
- type WhenScopeMeta
- type WhenScopeReceiver
- type WorkingMemory
- func (e *WorkingMemory) AddExpression(exp *Expression) *Expression
- func (e *WorkingMemory) AddExpressionAtom(exp *ExpressionAtom) *ExpressionAtom
- func (e *WorkingMemory) AddVariable(vari *Variable) *Variable
- func (e *WorkingMemory) Clone(cloneTable *pkg.CloneTable) *WorkingMemory
- func (e *WorkingMemory) DebugContent()
- func (e *WorkingMemory) Equals(that *WorkingMemory) bool
- func (e *WorkingMemory) IndexVariables()
- func (e *WorkingMemory) MakeCatalog(cat *Catalog)
- func (e *WorkingMemory) Reset(name string) bool
- func (e *WorkingMemory) ResetAll() bool
- func (e *WorkingMemory) ResetVariable(variable *Variable) bool
Constants ¶
const ( // ARGUMENTLIST signature for argument list snapshot ARGUMENTLIST = "AL" // MAPARRAYSELECTOR signature for map array snapshot MAPARRAYSELECTOR = "MAS" // ASSIGMENT signature for assignment snapshot ASSIGMENT = "AS" // CONSTANT signature for constant snapshot CONSTANT = "C" // EXPRESSION signature for expression snapshot EXPRESSION = "E" // EXPRESSIONATOM signature for expression atom snapshot EXPRESSIONATOM = "A" // FUNCTIONCALL signature for function call snapshot FUNCTIONCALL = "F" // RULEENTRY signature for rule entry snapshot RULEENTRY = "R" // THENEXPRESSION signature for then expression snapshot THENEXPRESSION = "TE" // THENEXPRESSIONLIST signature for then expression list snapshot THENEXPRESSIONLIST = "TEL" // THENSCOPE signature for then scope snapshot THENSCOPE = "TS" // WHENSCOPE signature for when scope snapshot WHENSCOPE = "WS" // VARIABLE signature for variable snapshot VARIABLE = "V" )
const ( // OpMul Multiplication operator OpMul int = iota // OpDiv Divisioon operator OpDiv // OpMod Modulus operator OpMod // OpAdd Addition operator OpAdd // OpSub Substraction operator OpSub // OpBitAnd Bitwise And operator OpBitAnd // OpBitOr Bitwise Or operator OpBitOr // OpGT Greater Than operator OpGT // OpLT Lesser Than operator OpLT // OpGTE Greater Than or Equal operator OpGTE // OpLTE Lesser Than or Equal operator OpLTE // OpEq Equals operator OpEq // OpNEq Not Equals operator OpNEq // OpAnd Logical And operator OpAnd // OpOr Logical Or operator OpOr )
const ( // TypeArgumentList meta type of ArgumentList TypeArgumentList NodeType = iota // TypeArrayMapSelector meta type of ArrayMapSelector TypeArrayMapSelector // TypeAssignment meta type of Assigment TypeAssignment // TypeExpression meta type of Expression TypeExpression // TypeConstant meta type of Constant TypeConstant // TypeExpressionAtom meta type of ExpressionAtom TypeExpressionAtom // TypeFunctionCall meta type of FunctionCall TypeFunctionCall // TypeRuleEntry meta type of RuleEntry TypeRuleEntry // TypeThenExpression meta type of ThenExpression TypeThenExpression // TypeThenExpressionList meta type of ThenExpressionList TypeThenExpressionList // TypeThenScope meta type of ThenScope TypeThenScope // TypeVariable meta type of Variable TypeVariable // TypeWhenScope meta type of WhenScope TypeWhenScope // TypeString variable type string label TypeString ValueType = iota // TypeInteger variable type integer label TypeInteger // TypeFloat variable type float label TypeFloat // TypeBoolean variable type boolean label TypeBoolean // Version will be written to the stream and used for compatibility check Version = "1.8" )
Variables ¶
var ( // TotalRead counter to track total byte read TotalRead = uint64(0) // TotalWrite counter to track total bytes written TotalWrite = uint64(0) // ReadCount read counter ReadCount = 0 // WriteCount write counter WriteCount = 0 )
var ( // AstLog is a logrus instance twith default fields for grule AstLog = logger.Log.WithFields(logrus.Fields{ "package": "ast", }) )
var ( // GrlLogger is the logger that be used from within the rule engine GRL GrlLogger = logger.Log.WithFields(logrus.Fields{ "package": "AST", "source": "GRL", }) )
Functions ¶
func ReadBoolFromReader ¶ added in v1.8.4
ReadBoolFromReader reads a simple boolean from writer
func ReadFloatFromReader ¶ added in v1.8.4
ReadFloatFromReader reads a 64bit float from reader
func ReadIntFromReader ¶ added in v1.8.4
ReadIntFromReader read a 64 bit integer from reader.
func ReadStringFromReader ¶ added in v1.8.4
ReadStringFromReader read a string from reader.
func WriteBoolToWriter ¶ added in v1.8.4
WriteBoolToWriter writes a simple boolean into writer
func WriteFloatToWriter ¶ added in v1.8.4
WriteFloatToWriter write a 64bit float into writer
func WriteFull ¶ added in v1.8.4
WriteFull will ensure that a byte array is fully written into writer
func WriteIntToWriter ¶ added in v1.8.4
WriteIntToWriter write a 64 bit integer into writer.
Types ¶
type ArgumentList ¶
type ArgumentList struct { AstID string GrlText string Arguments []*Expression }
ArgumentList stores AST graph for ArgumentList that contains expression.
func NewArgumentList ¶
func NewArgumentList() *ArgumentList
NewArgumentList create a new instance of ArgumentList
func (*ArgumentList) AcceptExpression ¶
func (e *ArgumentList) AcceptExpression(exp *Expression) error
AcceptExpression will accept an expression AST graph into this ast graph
func (*ArgumentList) Clone ¶ added in v1.4.0
func (e *ArgumentList) Clone(cloneTable *pkg.CloneTable) *ArgumentList
Clone will clone this ArgumentList. The new clone will have an identical structure
func (*ArgumentList) Evaluate ¶
func (e *ArgumentList) Evaluate(dataContext IDataContext, memory *WorkingMemory) ([]reflect.Value, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*ArgumentList) GetAstID ¶
func (e *ArgumentList) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*ArgumentList) GetGrlText ¶
func (e *ArgumentList) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*ArgumentList) GetSnapshot ¶
func (e *ArgumentList) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*ArgumentList) MakeCatalog ¶ added in v1.8.4
func (e *ArgumentList) MakeCatalog(cat *Catalog)
MakeCatalog will create a catalog entry from ArgumentList node.
func (*ArgumentList) SetGrlText ¶
func (e *ArgumentList) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ArgumentListMeta ¶ added in v1.8.4
ArgumentListMeta meta data for an ArgumentList node
func (*ArgumentListMeta) Equals ¶ added in v1.8.4
func (meta *ArgumentListMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ArgumentListMeta) GetASTType ¶ added in v1.8.4
func (meta *ArgumentListMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ArgumentListMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ArgumentListMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ArgumentListMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ArgumentListMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ArgumentListReceiver ¶
type ArgumentListReceiver interface {
AcceptArgumentList(argList *ArgumentList) error
}
ArgumentListReceiver will accept an ArgumentList AST graph into this ast graph
type ArrayMapSelector ¶ added in v1.6.0
type ArrayMapSelector struct { AstID string GrlText string Expression *Expression Value reflect.Value }
ArrayMapSelector an array selector graph containing an expression that act ass array or map selector
func NewArrayMapSelector ¶ added in v1.6.0
func NewArrayMapSelector() *ArrayMapSelector
NewArrayMapSelector create a new array selector graph
func (*ArrayMapSelector) AcceptExpression ¶ added in v1.6.0
func (e *ArrayMapSelector) AcceptExpression(exp *Expression) error
AcceptExpression will accept Expression AST graph node into this node
func (*ArrayMapSelector) Clone ¶ added in v1.6.0
func (e *ArrayMapSelector) Clone(cloneTable *pkg.CloneTable) *ArrayMapSelector
Clone will clone this ArgumentList. The new clone will have an identical structure
func (*ArrayMapSelector) Evaluate ¶ added in v1.6.0
func (e *ArrayMapSelector) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*ArrayMapSelector) GetAstID ¶ added in v1.6.0
func (e *ArrayMapSelector) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*ArrayMapSelector) GetGrlText ¶ added in v1.6.0
func (e *ArrayMapSelector) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*ArrayMapSelector) GetSnapshot ¶ added in v1.6.0
func (e *ArrayMapSelector) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*ArrayMapSelector) MakeCatalog ¶ added in v1.8.4
func (e *ArrayMapSelector) MakeCatalog(cat *Catalog)
MakeCatalog will create a catalog entry from ArrayMapSelector node.
func (*ArrayMapSelector) SetGrlText ¶ added in v1.6.0
func (e *ArrayMapSelector) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ArrayMapSelectorMeta ¶ added in v1.8.4
ArrayMapSelectorMeta meta data for an ArrayMapSelector node
func (*ArrayMapSelectorMeta) Equals ¶ added in v1.8.4
func (meta *ArrayMapSelectorMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ArrayMapSelectorMeta) GetASTType ¶ added in v1.8.4
func (meta *ArrayMapSelectorMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ArrayMapSelectorMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ArrayMapSelectorMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ArrayMapSelectorMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ArrayMapSelectorMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ArrayMapSelectorReceiver ¶ added in v1.6.0
type ArrayMapSelectorReceiver interface {
AcceptArrayMapSelector(sel *ArrayMapSelector) error
}
ArrayMapSelectorReceiver must be implemented by all other ast graph that uses map/array selector
type AssigmentMeta ¶ added in v1.8.4
type AssigmentMeta struct { NodeMeta VariableID string ExpressionID string IsAssign bool IsPlusAssign bool IsMinusAssign bool IsDivAssign bool IsMulAssign bool }
AssigmentMeta meta data for an Assigment node
func (*AssigmentMeta) Equals ¶ added in v1.8.4
func (meta *AssigmentMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*AssigmentMeta) GetASTType ¶ added in v1.8.4
func (meta *AssigmentMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*AssigmentMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *AssigmentMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*AssigmentMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *AssigmentMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type Assignment ¶
type Assignment struct { AstID string GrlText string Variable *Variable Expression *Expression IsAssign bool IsPlusAssign bool IsMinusAssign bool IsDivAssign bool IsMulAssign bool }
Assignment ast node to store assigment expression.
func NewAssignment ¶
func NewAssignment() *Assignment
NewAssignment will create new instance of Assignment AST Node
func (*Assignment) AcceptExpression ¶
func (e *Assignment) AcceptExpression(exp *Expression) error
AcceptExpression will accept an Expression AST graph into this ast graph
func (*Assignment) AcceptVariable ¶
func (e *Assignment) AcceptVariable(vari *Variable) error
AcceptVariable will accept an Variable AST graph into this ast graph
func (*Assignment) Clone ¶ added in v1.4.0
func (e *Assignment) Clone(cloneTable *pkg.CloneTable) *Assignment
Clone will clone this Assignment. The new clone will have an identical structure
func (*Assignment) Execute ¶
func (e *Assignment) Execute(dataContext IDataContext, memory *WorkingMemory) error
Execute will execute this graph in the Then scope
func (*Assignment) GetAstID ¶
func (e *Assignment) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*Assignment) GetGrlText ¶
func (e *Assignment) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*Assignment) GetSnapshot ¶
func (e *Assignment) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*Assignment) MakeCatalog ¶ added in v1.8.4
func (e *Assignment) MakeCatalog(cat *Catalog)
MakeCatalog will create a catalog entry from Assignment node.
func (*Assignment) SetGrlText ¶
func (e *Assignment) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type AssignmentReceiver ¶ added in v1.6.0
type AssignmentReceiver interface {
AcceptAssignment(assignment *Assignment) error
}
AssignmentReceiver must be implemented by all other ast graph that uses an assigment expression
type BooleanLiteral ¶ added in v1.7.0
type BooleanLiteral struct {
Boolean bool
}
BooleanLiteral will hold BooleanLiteral constant AST data
type BooleanLiteralReceiver ¶ added in v1.7.0
type BooleanLiteralReceiver interface {
AcceptBooleanLiteral(fun *BooleanLiteral)
}
BooleanLiteralReceiver should be implemented by AST graph node to receive a BooleanLiteral AST graph node
type BuiltInFunctions ¶ added in v1.5.0
type BuiltInFunctions struct { Knowledge *KnowledgeBase WorkingMemory *WorkingMemory DataContext IDataContext }
BuiltInFunctions struct hosts the built-in functions ready to invoke from the rule engine execution.
func (*BuiltInFunctions) Abs ¶ added in v1.8.2
func (gf *BuiltInFunctions) Abs(x float64) float64
Abs is a wrapper function for math.Abs function
func (*BuiltInFunctions) Acos ¶ added in v1.8.2
func (gf *BuiltInFunctions) Acos(x float64) float64
Acos is a wrapper function for math.Acos function
func (*BuiltInFunctions) Acosh ¶ added in v1.8.2
func (gf *BuiltInFunctions) Acosh(x float64) float64
Acosh is a wrapper function for math.Acosh function
func (*BuiltInFunctions) Asin ¶ added in v1.8.2
func (gf *BuiltInFunctions) Asin(x float64) float64
Asin is a wrapper function for math.Asin function
func (*BuiltInFunctions) Asinh ¶ added in v1.8.2
func (gf *BuiltInFunctions) Asinh(x float64) float64
Asinh is a wrapper function for math.Asinh function
func (*BuiltInFunctions) Atan ¶ added in v1.8.2
func (gf *BuiltInFunctions) Atan(x float64) float64
Atan is a wrapper function for math.Atan function
func (*BuiltInFunctions) Atan2 ¶ added in v1.8.2
func (gf *BuiltInFunctions) Atan2(y, x float64) float64
Atan2 is a wrapper function for math.Atan2 function
func (*BuiltInFunctions) Atanh ¶ added in v1.8.2
func (gf *BuiltInFunctions) Atanh(x float64) float64
Atanh is a wrapper function for math.Atanh function
func (*BuiltInFunctions) Cbrt ¶ added in v1.8.2
func (gf *BuiltInFunctions) Cbrt(x float64) float64
Cbrt is a wrapper function for math.Cbrt function
func (*BuiltInFunctions) Ceil ¶ added in v1.8.2
func (gf *BuiltInFunctions) Ceil(x float64) float64
Ceil is a wrapper function for math.Ceil function
func (*BuiltInFunctions) Changed ¶ added in v1.5.0
func (gf *BuiltInFunctions) Changed(variableName string)
Changed is another name for Forget function. This function is retained for backward compatibility reason and will be removed in the future.
func (*BuiltInFunctions) Complete ¶ added in v1.5.0
func (gf *BuiltInFunctions) Complete()
Complete will cause the engine to stop processing further rules in the current cycle.
func (*BuiltInFunctions) Copysign ¶ added in v1.8.2
func (gf *BuiltInFunctions) Copysign(x, y float64) float64
Copysign is a wrapper function for math.Copysign function
func (*BuiltInFunctions) Cos ¶ added in v1.8.2
func (gf *BuiltInFunctions) Cos(x float64) float64
Cos is a wrapper function for math.Cos function
func (*BuiltInFunctions) Cosh ¶ added in v1.8.2
func (gf *BuiltInFunctions) Cosh(x float64) float64
Cosh is a wrapper function for math.Cosh function
func (*BuiltInFunctions) Dim ¶ added in v1.8.2
func (gf *BuiltInFunctions) Dim(x, y float64) float64
Dim is a wrapper function for math.Dim function
func (*BuiltInFunctions) Erf ¶ added in v1.8.2
func (gf *BuiltInFunctions) Erf(x float64) float64
Erf is a wrapper function for math.Erf function
func (*BuiltInFunctions) Erfc ¶ added in v1.8.2
func (gf *BuiltInFunctions) Erfc(x float64) float64
Erfc is a wrapper function for math.Erfc function
func (*BuiltInFunctions) Erfcinv ¶ added in v1.8.2
func (gf *BuiltInFunctions) Erfcinv(x float64) float64
Erfcinv is a wrapper function for math.Erfcinv function
func (*BuiltInFunctions) Erfinv ¶ added in v1.8.2
func (gf *BuiltInFunctions) Erfinv(x float64) float64
Erfinv is a wrapper function for math.Erfinv function
func (*BuiltInFunctions) Exp ¶ added in v1.8.2
func (gf *BuiltInFunctions) Exp(x float64) float64
Exp is a wrapper function for math.Exp function
func (*BuiltInFunctions) Exp2 ¶ added in v1.8.2
func (gf *BuiltInFunctions) Exp2(x float64) float64
Exp2 is a wrapper function for math.Exp2 function
func (*BuiltInFunctions) Expm1 ¶ added in v1.8.2
func (gf *BuiltInFunctions) Expm1(x float64) float64
Expm1 is a wrapper function for math.Expm1 function
func (*BuiltInFunctions) Float64bits ¶ added in v1.8.2
func (gf *BuiltInFunctions) Float64bits(f float64) uint64
Float64bits is a wrapper function for math.Float64bits function
func (*BuiltInFunctions) Float64frombits ¶ added in v1.8.2
func (gf *BuiltInFunctions) Float64frombits(b uint64) float64
Float64frombits is a wrapper function for math.Float64frombits function
func (*BuiltInFunctions) Floor ¶ added in v1.8.2
func (gf *BuiltInFunctions) Floor(x float64) float64
Floor is a wrapper function for math.Floor function
func (*BuiltInFunctions) Forget ¶ added in v1.7.1
func (gf *BuiltInFunctions) Forget(snippet string)
Forget will force Grule's working memory to forget about a variable, or function call, so in the next cycle grue will re-valuate that variable/function instead of just use the value from its working memory. If you change the variable from within grule GRL (using assignment expression, you dont need to call this function on that variable since grule will automaticaly see the change. So only call this function if the variable got changed from your internal struct logic.
func (*BuiltInFunctions) Gamma ¶ added in v1.8.2
func (gf *BuiltInFunctions) Gamma(x float64) float64
Gamma is a wrapper function for math.Gamma function
func (*BuiltInFunctions) GetTimeDay ¶ added in v1.5.0
func (gf *BuiltInFunctions) GetTimeDay(time time.Time) int
GetTimeDay will get the day value of time
func (*BuiltInFunctions) GetTimeHour ¶ added in v1.5.0
func (gf *BuiltInFunctions) GetTimeHour(time time.Time) int
GetTimeHour will get the hour value of time
func (*BuiltInFunctions) GetTimeMinute ¶ added in v1.5.0
func (gf *BuiltInFunctions) GetTimeMinute(time time.Time) int
GetTimeMinute will get the minute value of time
func (*BuiltInFunctions) GetTimeMonth ¶ added in v1.5.0
func (gf *BuiltInFunctions) GetTimeMonth(time time.Time) int
GetTimeMonth will get the month value of time
func (*BuiltInFunctions) GetTimeSecond ¶ added in v1.5.0
func (gf *BuiltInFunctions) GetTimeSecond(time time.Time) int
GetTimeSecond will get the second value of time
func (*BuiltInFunctions) GetTimeYear ¶ added in v1.5.0
func (gf *BuiltInFunctions) GetTimeYear(time time.Time) int
GetTimeYear will get the year value of time
func (*BuiltInFunctions) Hypot ¶ added in v1.8.2
func (gf *BuiltInFunctions) Hypot(p, q float64) float64
Hypot is a wrapper function for math.Hypot function
func (*BuiltInFunctions) Ilogb ¶ added in v1.8.2
func (gf *BuiltInFunctions) Ilogb(x float64) int
Ilogb is a wrapper function for math.Ilogb function
func (*BuiltInFunctions) IsInf ¶ added in v1.8.2
func (gf *BuiltInFunctions) IsInf(f float64, sign int64) bool
IsInf is a wrapper function for math.IsInf function
func (*BuiltInFunctions) IsNaN ¶ added in v1.8.2
func (gf *BuiltInFunctions) IsNaN(f float64) (is bool)
IsNaN is a wrapper function for math.IsNaN function
func (*BuiltInFunctions) IsNil ¶ added in v1.5.0
func (gf *BuiltInFunctions) IsNil(i interface{}) bool
IsNil Enables nill checking on variables.
func (*BuiltInFunctions) IsTimeAfter ¶ added in v1.5.0
func (gf *BuiltInFunctions) IsTimeAfter(time, after time.Time) bool
IsTimeAfter will check if the 1st argument is after the 2nd argument.
func (*BuiltInFunctions) IsTimeBefore ¶ added in v1.5.0
func (gf *BuiltInFunctions) IsTimeBefore(time, before time.Time) bool
IsTimeBefore will check if the 1st argument is before the 2nd argument.
func (*BuiltInFunctions) IsZero ¶ added in v1.5.0
func (gf *BuiltInFunctions) IsZero(i interface{}) bool
IsZero Enable zero checking
func (*BuiltInFunctions) J0 ¶ added in v1.8.2
func (gf *BuiltInFunctions) J0(x float64) float64
J0 is a wrapper function for math.J0 function
func (*BuiltInFunctions) J1 ¶ added in v1.8.2
func (gf *BuiltInFunctions) J1(x float64) float64
J1 is a wrapper function for math.J1 function
func (*BuiltInFunctions) Jn ¶ added in v1.8.2
func (gf *BuiltInFunctions) Jn(n int64, x float64) float64
Jn is a wrapper function for math.Jn function
func (*BuiltInFunctions) Ldexp ¶ added in v1.8.2
func (gf *BuiltInFunctions) Ldexp(frac float64, exp int64) float64
Ldexp is a wrapper function for math.Ldexp function
func (*BuiltInFunctions) Log ¶ added in v1.5.0
func (gf *BuiltInFunctions) Log(text string)
Log extension to log.Print
func (*BuiltInFunctions) Log10 ¶ added in v1.8.2
func (gf *BuiltInFunctions) Log10(x float64) float64
Log10 is a wrapper function for math.Log10 function
func (*BuiltInFunctions) Log1p ¶ added in v1.8.2
func (gf *BuiltInFunctions) Log1p(x float64) float64
Log1p is a wrapper function for math.Log1p function
func (*BuiltInFunctions) Log2 ¶ added in v1.8.2
func (gf *BuiltInFunctions) Log2(x float64) float64
Log2 is a wrapper function for math.Log2 function
func (*BuiltInFunctions) LogFormat ¶ added in v1.5.0
func (gf *BuiltInFunctions) LogFormat(format string, i interface{})
LogFormat extension to log.Printf
func (*BuiltInFunctions) Logb ¶ added in v1.8.2
func (gf *BuiltInFunctions) Logb(x float64) float64
Logb is a wrapper function for math.Logb function
func (*BuiltInFunctions) MakeTime ¶ added in v1.5.0
func (gf *BuiltInFunctions) MakeTime(year, month, day, hour, minute, second int64) time.Time
MakeTime will create a Time struct according to the argument values.
func (*BuiltInFunctions) MathLog ¶ added in v1.8.2
func (gf *BuiltInFunctions) MathLog(x float64) float64
MathLog is a wrapper function for math.MathLog function
func (*BuiltInFunctions) Max ¶ added in v1.8.2
func (gf *BuiltInFunctions) Max(vals ...float64) float64
Max will pick the biggest of value in the arguments
func (*BuiltInFunctions) Min ¶ added in v1.8.2
func (gf *BuiltInFunctions) Min(vals ...float64) float64
Min will pick the smallest of value in the arguments
func (*BuiltInFunctions) Mod ¶ added in v1.8.2
func (gf *BuiltInFunctions) Mod(x, y float64) float64
Mod is a wrapper function for math.Mod function
func (*BuiltInFunctions) NaN ¶ added in v1.8.2
func (gf *BuiltInFunctions) NaN() float64
NaN is a wrapper function for math.NaN function
func (*BuiltInFunctions) Now ¶ added in v1.5.0
func (gf *BuiltInFunctions) Now() time.Time
Now is an extension tn time.Now().
func (*BuiltInFunctions) Pow ¶ added in v1.8.2
func (gf *BuiltInFunctions) Pow(x, y float64) float64
Pow is a wrapper function for math.Pow function
func (*BuiltInFunctions) Pow10 ¶ added in v1.8.2
func (gf *BuiltInFunctions) Pow10(n int64) float64
Pow10 is a wrapper function for math.Pow10 function
func (*BuiltInFunctions) Remainder ¶ added in v1.8.2
func (gf *BuiltInFunctions) Remainder(x, y float64) float64
Remainder is a wrapper function for math.Remainder function
func (*BuiltInFunctions) Retract ¶ added in v1.5.0
func (gf *BuiltInFunctions) Retract(ruleName string)
Retract will retract a rule from next evaluation cycle.
func (*BuiltInFunctions) Round ¶ added in v1.8.2
func (gf *BuiltInFunctions) Round(x float64) float64
Round is a wrapper function for math.Round function
func (*BuiltInFunctions) RoundToEven ¶ added in v1.8.2
func (gf *BuiltInFunctions) RoundToEven(x float64) float64
RoundToEven is a wrapper function for math.RoundToEven function
func (*BuiltInFunctions) Signbit ¶ added in v1.8.2
func (gf *BuiltInFunctions) Signbit(x float64) bool
Signbit is a wrapper function for math.Signbit function
func (*BuiltInFunctions) Sin ¶ added in v1.8.2
func (gf *BuiltInFunctions) Sin(x float64) float64
Sin is a wrapper function for math.Sin function
func (*BuiltInFunctions) Sinh ¶ added in v1.8.2
func (gf *BuiltInFunctions) Sinh(x float64) float64
Sinh is a wrapper function for math.Sinh function
func (*BuiltInFunctions) Sqrt ¶ added in v1.8.2
func (gf *BuiltInFunctions) Sqrt(x float64) float64
Sqrt is a wrapper function for math.Sqrt function
func (*BuiltInFunctions) StringContains ¶ added in v1.5.0
func (gf *BuiltInFunctions) StringContains(str, substr string) bool
StringContains extension to strings.Contains
func (*BuiltInFunctions) Tan ¶ added in v1.8.2
func (gf *BuiltInFunctions) Tan(x float64) float64
Tan is a wrapper function for math.Tan function
func (*BuiltInFunctions) Tanh ¶ added in v1.8.2
func (gf *BuiltInFunctions) Tanh(x float64) float64
Tanh is a wrapper function for math.Tanh function
func (*BuiltInFunctions) TimeFormat ¶ added in v1.5.0
func (gf *BuiltInFunctions) TimeFormat(time time.Time, layout string) string
TimeFormat will format a time according to format layout.
func (*BuiltInFunctions) Trunc ¶ added in v1.8.2
func (gf *BuiltInFunctions) Trunc(x float64) float64
Trunc is a wrapper function for math.Trunc function
type Catalog ¶ added in v1.8.4
type Catalog struct { KnowledgeBaseName string KnowledgeBaseVersion string Data map[string]Meta MemoryName string MemoryVersion string MemoryVariableSnapshotMap map[string]string MemoryExpressionSnapshotMap map[string]string MemoryExpressionAtomSnapshotMap map[string]string MemoryExpressionVariableMap map[string][]string MemoryExpressionAtomVariableMap map[string][]string }
Catalog used to catalog all AST nodes in a KnowledgeBase. All nodes will be saved as their Meta information. which includes relations between AST Node. As RETE algorithm is a prominent aspect of the KnowledgeBase, retaining RETE network is very important. The catalog provides simple recording of Expression, ExpressionAtoms, Variables that capable of supporting the network, enabling the network to be saved and reloaded to/from a stream.
This capability alone supposed to store and load huge ruleset fast without having to read the rule set from their origin GRL which some how a bit expensive due to string parsing and pattern operation by ANTLR4
func (*Catalog) AddMeta ¶ added in v1.8.4
AddMeta will add AST Node meta information. it will reject duplicated AST ID
func (*Catalog) BuildKnowledgeBase ¶ added in v1.8.4
func (cat *Catalog) BuildKnowledgeBase() *KnowledgeBase
BuildKnowledgeBase will rebuild a knowledgebase from this Catalog. the rebuilt KnowledgeBase is identical to the original KnowledgeBase from which this Catalog was built.
func (*Catalog) Equals ¶ added in v1.8.4
Equals used for testing purpose, to ensure that two catalog can be compared straight away. The comparison is Deep comparison.
func (*Catalog) ReadCatalogFromReader ¶ added in v1.8.4
ReadCatalogFromReader would read a byte stream from reader It will replace all values already sets in a catalog. You are responsible for closing the reader stream once its done.
type Constant ¶
type Constant struct { AstID string GrlText string Snapshot string DataContext IDataContext WorkingMemory *WorkingMemory Value reflect.Value IsNil bool }
Constant AST node that stores AST graph for Constants
func (*Constant) AcceptBooleanLiteral ¶ added in v1.7.0
func (e *Constant) AcceptBooleanLiteral(fun *BooleanLiteral)
AcceptBooleanLiteral will accept boolean literal
func (*Constant) AcceptFloatLiteral ¶ added in v1.7.0
func (e *Constant) AcceptFloatLiteral(fun *FloatLiteral)
AcceptFloatLiteral will accept float literal
func (*Constant) AcceptIntegerLiteral ¶ added in v1.7.0
func (e *Constant) AcceptIntegerLiteral(fun *IntegerLiteral)
AcceptIntegerLiteral will accept integer literal
func (*Constant) AcceptStringLiteral ¶ added in v1.7.0
func (e *Constant) AcceptStringLiteral(fun *StringLiteral)
AcceptStringLiteral will accept string literal
func (*Constant) Clone ¶ added in v1.4.0
func (e *Constant) Clone(cloneTable *pkg.CloneTable) *Constant
Clone will clone this Constant. The new clone will have an identical structure
func (*Constant) Evaluate ¶
func (e *Constant) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*Constant) GetGrlText ¶
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*Constant) GetSnapshot ¶
GetSnapshot will create a structure signature or AST graph
func (*Constant) MakeCatalog ¶ added in v1.8.4
MakeCatalog will create a catalog entry from Constant node.
func (*Constant) SetGrlText ¶
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ConstantMeta ¶ added in v1.8.4
ConstantMeta meta data for an Constant node
func (*ConstantMeta) Equals ¶ added in v1.8.4
func (meta *ConstantMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ConstantMeta) GetASTType ¶ added in v1.8.4
func (meta *ConstantMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ConstantMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ConstantMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ConstantMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ConstantMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ConstantReceiver ¶
ConstantReceiver should be implemented by AST Graph node to receive a Constant Graph Node.
type DataContext ¶
type DataContext struct { ObjectStore map[string]model.ValueNode // contains filtered or unexported fields }
DataContext holds all structs instance to be used in rule execution environment.
func (*DataContext) Add ¶
func (ctx *DataContext) Add(key string, obj interface{}) error
Add will add struct instance into rule execution context
func (*DataContext) AddJSON ¶ added in v1.8.0
func (ctx *DataContext) AddJSON(key string, JSON []byte) error
AddJSON will add struct instance into rule execution context
func (*DataContext) Complete ¶ added in v1.5.0
func (ctx *DataContext) Complete()
Complete marks the DataContext as completed, telling the engine to stop processing rules
func (*DataContext) Get ¶ added in v1.6.0
func (ctx *DataContext) Get(key string) model.ValueNode
Get will extract the struct instance
func (*DataContext) HasVariableChange ¶ added in v1.5.0
func (ctx *DataContext) HasVariableChange() bool
HasVariableChange returns true if there are variable changes
func (*DataContext) IncrementVariableChangeCount ¶ added in v1.5.0
func (ctx *DataContext) IncrementVariableChangeCount()
IncrementVariableChangeCount will increment the variable change count
func (*DataContext) IsComplete ¶ added in v1.5.0
func (ctx *DataContext) IsComplete() bool
IsComplete checks whether the DataContext has been completed
func (*DataContext) IsRetracted ¶ added in v1.3.0
func (ctx *DataContext) IsRetracted(key string) bool
IsRetracted checks if a key fact is currently retracted.
func (*DataContext) Reset ¶
func (ctx *DataContext) Reset()
Reset will un-retract all fact, making them available for evaluation and modification.
func (*DataContext) ResetVariableChangeCount ¶ added in v1.5.0
func (ctx *DataContext) ResetVariableChangeCount()
ResetVariableChangeCount will reset the variable change count
func (*DataContext) Retract ¶
func (ctx *DataContext) Retract(key string)
Retract temporary retract a fact from data context, making it unavailable for evaluation or modification.
func (*DataContext) Retracted ¶
func (ctx *DataContext) Retracted() []string
Retracted returns list of retracted key facts.
type Expression ¶
type Expression struct { AstID string GrlText string LeftExpression *Expression RightExpression *Expression SingleExpression *Expression ExpressionAtom *ExpressionAtom Operator int Negated bool Value reflect.Value Evaluated bool }
Expression AST Graph node
func (*Expression) AcceptExpression ¶
func (e *Expression) AcceptExpression(exp *Expression) error
AcceptExpression will accept an Expression AST graph into this ast graph
func (*Expression) AcceptExpressionAtom ¶ added in v1.6.0
func (e *Expression) AcceptExpressionAtom(atom *ExpressionAtom) error
AcceptExpressionAtom will accept ExpressionAtom into this Expression
func (*Expression) Clone ¶ added in v1.4.0
func (e *Expression) Clone(cloneTable *pkg.CloneTable) *Expression
Clone will clone this Expression. The new clone will have an identical structure
func (*Expression) Evaluate ¶
func (e *Expression) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*Expression) GetAstID ¶
func (e *Expression) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*Expression) GetGrlText ¶
func (e *Expression) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*Expression) GetSnapshot ¶
func (e *Expression) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*Expression) MakeCatalog ¶ added in v1.8.4
func (e *Expression) MakeCatalog(cat *Catalog)
MakeCatalog will create a catalog entry from Expression node.
func (*Expression) SetGrlText ¶
func (e *Expression) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ExpressionAtom ¶
type ExpressionAtom struct { AstID string GrlText string VariableName string Constant *Constant FunctionCall *FunctionCall Variable *Variable Negated bool ExpressionAtom *ExpressionAtom ArrayMapSelector *ArrayMapSelector Value reflect.Value ValueNode model.ValueNode Evaluated bool }
ExpressionAtom AST node graph
func NewExpressionAtom ¶
func NewExpressionAtom() *ExpressionAtom
NewExpressionAtom create new instance of ExpressionAtom
func (*ExpressionAtom) AcceptArrayMapSelector ¶ added in v1.7.1
func (e *ExpressionAtom) AcceptArrayMapSelector(sel *ArrayMapSelector) error
AcceptArrayMapSelector accept an array map selector into this variable graph
func (*ExpressionAtom) AcceptConstant ¶
func (e *ExpressionAtom) AcceptConstant(cons *Constant) error
AcceptConstant will accept a Constant AST graph into this ast graph
func (*ExpressionAtom) AcceptExpressionAtom ¶ added in v1.7.0
func (e *ExpressionAtom) AcceptExpressionAtom(ea *ExpressionAtom) error
AcceptExpressionAtom will accept an ExpressionAtom AST graph into this ast graph
func (*ExpressionAtom) AcceptFunctionCall ¶
func (e *ExpressionAtom) AcceptFunctionCall(fun *FunctionCall) error
AcceptFunctionCall will accept an FunctionCall AST graph into this ast graph
func (*ExpressionAtom) AcceptMemberVariable ¶ added in v1.7.0
func (e *ExpressionAtom) AcceptMemberVariable(name string)
AcceptMemberVariable accept a member variable AST graph into this Variable graph
func (*ExpressionAtom) AcceptVariable ¶
func (e *ExpressionAtom) AcceptVariable(vari *Variable) error
AcceptVariable will accept an Variable AST graph into this ast graph
func (*ExpressionAtom) Clone ¶ added in v1.4.0
func (e *ExpressionAtom) Clone(cloneTable *pkg.CloneTable) *ExpressionAtom
Clone will clone this ExpressionAtom. The new clone will have an identical structure
func (*ExpressionAtom) Evaluate ¶
func (e *ExpressionAtom) Evaluate(dataContext IDataContext, memory *WorkingMemory) (val reflect.Value, err error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*ExpressionAtom) GetAstID ¶
func (e *ExpressionAtom) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*ExpressionAtom) GetGrlText ¶
func (e *ExpressionAtom) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*ExpressionAtom) GetSnapshot ¶
func (e *ExpressionAtom) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*ExpressionAtom) MakeCatalog ¶ added in v1.8.4
func (e *ExpressionAtom) MakeCatalog(cat *Catalog)
MakeCatalog will create a catalog entry from ExpressionAtom node.
func (*ExpressionAtom) SetGrlText ¶
func (e *ExpressionAtom) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ExpressionAtomMeta ¶ added in v1.8.4
type ExpressionAtomMeta struct { NodeMeta VariableName string ConstantID string FunctionCallID string VariableID string Negated bool ExpressionAtomID string ArrayMapSelectorID string }
ExpressionAtomMeta meta data for an ExpressionAtom node
func (*ExpressionAtomMeta) Equals ¶ added in v1.8.4
func (meta *ExpressionAtomMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ExpressionAtomMeta) GetASTType ¶ added in v1.8.4
func (meta *ExpressionAtomMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ExpressionAtomMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ExpressionAtomMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ExpressionAtomMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ExpressionAtomMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ExpressionAtomReceiver ¶ added in v1.6.0
type ExpressionAtomReceiver interface {
AcceptExpressionAtom(exp *ExpressionAtom) error
}
ExpressionAtomReceiver contains function to be implemented by other AST graph to receive an ExpressionAtom AST graph
type ExpressionMeta ¶ added in v1.8.4
type ExpressionMeta struct { NodeMeta LeftExpressionID string RightExpressionID string SingleExpressionID string ExpressionAtomID string Operator int Negated bool }
ExpressionMeta meta data for an Expression node
func (*ExpressionMeta) Equals ¶ added in v1.8.4
func (meta *ExpressionMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ExpressionMeta) GetASTType ¶ added in v1.8.4
func (meta *ExpressionMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ExpressionMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ExpressionMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ExpressionMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ExpressionMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ExpressionReceiver ¶
type ExpressionReceiver interface {
AcceptExpression(exp *Expression) error
}
ExpressionReceiver contains function to be implemented by other AST graph to receive an Expression AST graph
type FloatLiteral ¶ added in v1.7.0
type FloatLiteral struct {
Float float64
}
FloatLiteral will hold FloatLiteral constant AST data
type FloatLiteralReceiver ¶ added in v1.7.0
type FloatLiteralReceiver interface {
AcceptFloatLiteral(fun *FloatLiteral)
}
FloatLiteralReceiver should be implemented by AST graph node to receive a FloatLiteral AST graph node
type FunctionCall ¶
type FunctionCall struct { AstID string GrlText string FunctionName string ArgumentList *ArgumentList Value reflect.Value }
FunctionCall AST graph node
func NewFunctionCall ¶
func NewFunctionCall() *FunctionCall
NewFunctionCall creates new instance of FunctionCall
func (*FunctionCall) AcceptArgumentList ¶
func (e *FunctionCall) AcceptArgumentList(argList *ArgumentList) error
AcceptArgumentList will accept an ArgumentList AST graph into this ast graph
func (*FunctionCall) Clone ¶ added in v1.4.0
func (e *FunctionCall) Clone(cloneTable *pkg.CloneTable) *FunctionCall
Clone will clone this FunctionCall. The new clone will have an identical structure
func (*FunctionCall) EvaluateArgumentList ¶ added in v1.6.0
func (e *FunctionCall) EvaluateArgumentList(dataContext IDataContext, memory *WorkingMemory) ([]reflect.Value, error)
EvaluateArgumentList will evaluate all arguments and ensure it can be passed into function.
func (*FunctionCall) GetAstID ¶
func (e *FunctionCall) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*FunctionCall) GetGrlText ¶
func (e *FunctionCall) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*FunctionCall) GetSnapshot ¶
func (e *FunctionCall) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*FunctionCall) MakeCatalog ¶ added in v1.8.4
func (e *FunctionCall) MakeCatalog(cat *Catalog)
MakeCatalog will create a catalog entry from FunctionCall node.
func (*FunctionCall) SetGrlText ¶
func (e *FunctionCall) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type FunctionCallMeta ¶ added in v1.8.4
FunctionCallMeta meta data for an FunctionCall node
func (*FunctionCallMeta) Equals ¶ added in v1.8.4
func (meta *FunctionCallMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*FunctionCallMeta) GetASTType ¶ added in v1.8.4
func (meta *FunctionCallMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*FunctionCallMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *FunctionCallMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*FunctionCallMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *FunctionCallMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type FunctionCallReceiver ¶
type FunctionCallReceiver interface {
AcceptFunctionCall(fun *FunctionCall) error
}
FunctionCallReceiver should be implemented bu AST graph node to receive a FunctionCall AST graph mode
type Grl ¶ added in v1.6.0
Grl will contains multiple RuleEntries
func (*Grl) ReceiveRuleEntry ¶ added in v1.6.0
ReceiveRuleEntry will make this GRL to accept rule entries created by ANTLR walker
type GrlReceiver ¶ added in v1.6.0
GrlReceiver is interface for objects that should hold a GRL, will be called by ANTLR walker.
type IDataContext ¶ added in v1.5.0
type IDataContext interface { ResetVariableChangeCount() IncrementVariableChangeCount() HasVariableChange() bool Add(key string, obj interface{}) error AddJSON(key string, JSON []byte) error Get(key string) model.ValueNode Retract(key string) IsRetracted(key string) bool Complete() IsComplete() bool Retracted() []string Reset() }
IDataContext is the interface for the DataContext struct.
func NewDataContext ¶
func NewDataContext() IDataContext
NewDataContext will create a new DataContext instance
type IntegerLiteral ¶ added in v1.7.0
type IntegerLiteral struct {
Integer int64
}
IntegerLiteral will hold IntegerLiteral constant AST data
type IntegerLiteralReceiver ¶ added in v1.7.0
type IntegerLiteralReceiver interface {
AcceptIntegerLiteral(fun *IntegerLiteral)
}
IntegerLiteralReceiver should be implemented by AST graph node to receive a IntegerLiteral AST graph node
type KnowledgeBase ¶
type KnowledgeBase struct { Name string Version string DataContext IDataContext WorkingMemory *WorkingMemory RuleEntries map[string]*RuleEntry // contains filtered or unexported fields }
KnowledgeBase is a collection of RuleEntries. It has a name and version.
func (*KnowledgeBase) AddRuleEntry ¶ added in v1.2.4
func (e *KnowledgeBase) AddRuleEntry(entry *RuleEntry) error
AddRuleEntry add ruleentry into this knowledge base. return an error if a rule entry with the same name already exist in this knowledge base.
func (*KnowledgeBase) Clone ¶ added in v1.4.0
func (e *KnowledgeBase) Clone(cloneTable *pkg.CloneTable) *KnowledgeBase
Clone will clone this instance of KnowledgeBase and produce another (structure wise) identical instance.
func (*KnowledgeBase) ContainsRuleEntry ¶ added in v1.2.4
func (e *KnowledgeBase) ContainsRuleEntry(name string) bool
ContainsRuleEntry will check if a rule with such name is already exist in this knowledge base.
func (*KnowledgeBase) GetSnapshot ¶ added in v1.6.0
func (e *KnowledgeBase) GetSnapshot() string
GetSnapshot will create this knowledge base signature
func (*KnowledgeBase) InitializeContext ¶
func (e *KnowledgeBase) InitializeContext(dataCtx IDataContext)
InitializeContext will initialize this AST graph with data context and working memory before running rule on them.
func (*KnowledgeBase) IsIdentical ¶ added in v1.6.0
func (e *KnowledgeBase) IsIdentical(that *KnowledgeBase) bool
IsIdentical will validate if two KnoledgeBase is identical. Used to validate if the origin and clone is identical.
func (*KnowledgeBase) IsRuleRetracted ¶
func (e *KnowledgeBase) IsRuleRetracted(ruleName string) bool
IsRuleRetracted will check if a certain rule denoted by its rule name is currently retracted
func (*KnowledgeBase) MakeCatalog ¶ added in v1.8.4
func (e *KnowledgeBase) MakeCatalog() *Catalog
MakeCatalog will create a catalog entry for all AST Nodes under the KnowledgeBase the catalog can be used to save the knowledge base into a Writer, or to rebuild the KnowledgeBase from it. This function also will catalog the WorkingMemory.
func (*KnowledgeBase) RemoveRuleEntry ¶ added in v1.2.4
func (e *KnowledgeBase) RemoveRuleEntry(name string)
RemoveRuleEntry remove the rule entry with specified name from this knowledge base
func (*KnowledgeBase) Reset ¶
func (e *KnowledgeBase) Reset()
Reset will restore all rule in the knowledge
func (*KnowledgeBase) RetractRule ¶
func (e *KnowledgeBase) RetractRule(ruleName string)
RetractRule will retract the selected rule for execution on the next cycle.
type KnowledgeLibrary ¶ added in v1.4.0
type KnowledgeLibrary struct {
Library map[string]*KnowledgeBase
}
KnowledgeLibrary is a knowledgebase store.
func NewKnowledgeLibrary ¶ added in v1.4.0
func NewKnowledgeLibrary() *KnowledgeLibrary
NewKnowledgeLibrary create a new instance KnowledgeLibrary
func (*KnowledgeLibrary) GetKnowledgeBase ¶ added in v1.4.0
func (lib *KnowledgeLibrary) GetKnowledgeBase(name, version string) *KnowledgeBase
GetKnowledgeBase will get the actual KnowledgeBase blue print that will be used to create instances. Although this KnowledgeBase blueprint works, It SHOULD NOT be used directly in the engine. You should obtain KnowledgeBase instance by calling NewKnowledgeBaseInstance
func (*KnowledgeLibrary) LoadKnowledgeBaseFromReader ¶ added in v1.8.4
func (lib *KnowledgeLibrary) LoadKnowledgeBaseFromReader(reader io.Reader, overwrite bool) (retKb *KnowledgeBase, retErr error)
LoadKnowledgeBaseFromReader will load the KnowledgeBase stored using StoreKnowledgeBaseToWriter function be it from file, or anywhere. The reader we needed is a plain io.Reader, thus closing the source stream is your responsibility. This should hopefully speedup loading huge ruleset by storing and reading them without having to parse the GRL.
func (*KnowledgeLibrary) NewKnowledgeBaseInstance ¶ added in v1.4.0
func (lib *KnowledgeLibrary) NewKnowledgeBaseInstance(name, version string) *KnowledgeBase
NewKnowledgeBaseInstance will create a new instance based on KnowledgeBase blue print identified by its name and version
func (*KnowledgeLibrary) StoreKnowledgeBaseToWriter ¶ added in v1.8.4
func (lib *KnowledgeLibrary) StoreKnowledgeBaseToWriter(writer io.Writer, name, version string) error
StoreKnowledgeBaseToWriter will store a KnowledgeBase in binary form once store, the binary stream can be read using LoadKnowledgeBaseFromReader function. This should hopefully speedup loading huge ruleset by storing and reading them without having to parse the GRL.
The stored binary file is greatly increased (easily 10x fold) due to lots of generated keys for AST Nodes that was also saved. To overcome this, the use of archive/zip package for Readers and Writers could cut down the binary size quite a lot.
type MemberVariableReceiver ¶ added in v1.7.0
type MemberVariableReceiver interface {
AcceptMemberVariable(name string)
}
MemberVariableReceiver should be implemented by AST graph node to receive member Variable information.
type Meta ¶ added in v1.8.4
type Meta interface { GetASTType() NodeType GetAstID() string GetGrlText() string GetSnapshot() string WriteMetaTo(writer io.Writer) error ReadMetaFrom(reader io.Reader) error Equals(that Meta) bool }
Meta interface as contract of all AST Node meta information.
type Node ¶
type Node interface { GetAstID() string GetGrlText() string GetSnapshot() string SetGrlText(grlText string) MakeCatalog(cat *Catalog) }
Node defines interface to implement by all AST node models
type NodeMeta ¶ added in v1.8.4
NodeMeta is a base struct for all ASTNode meta
func (*NodeMeta) GetGrlText ¶ added in v1.8.4
GetGrlText return the node original GRLText, this might not be needed but useful for debuging future GRL issue
func (*NodeMeta) GetSnapshot ¶ added in v1.8.4
GetSnapshot return the NodeSnapshot, this might not needed but could be useful for consistency.
func (*NodeMeta) ReadMetaFrom ¶ added in v1.8.4
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
type NodeType ¶ added in v1.8.4
type NodeType int
NodeType is to label a Meta information within catalog
type RuleEntry ¶
type RuleEntry struct { AstID string GrlText string RuleName string RuleDescription string Salience int WhenScope *WhenScope ThenScope *ThenScope Retracted bool }
RuleEntry AST graph node
func (*RuleEntry) AcceptSalience ¶ added in v1.6.0
AcceptSalience will accept salience value
func (*RuleEntry) AcceptThenScope ¶ added in v1.6.0
AcceptThenScope will accept ThenScope AST Graph into this AST Graph
func (*RuleEntry) AcceptWhenScope ¶ added in v1.6.0
AcceptWhenScope will accept WhenScope AST Graph into this AST Graph
func (*RuleEntry) Clone ¶ added in v1.4.0
func (e *RuleEntry) Clone(cloneTable *pkg.CloneTable) *RuleEntry
Clone will clone this RuleEntry. The new clone will have an identical structure
func (*RuleEntry) Evaluate ¶
func (e *RuleEntry) Evaluate(dataContext IDataContext, memory *WorkingMemory) (bool, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*RuleEntry) Execute ¶
func (e *RuleEntry) Execute(dataContext IDataContext, memory *WorkingMemory) (err error)
Execute will execute this graph in the Then scope
func (*RuleEntry) GetGrlText ¶
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*RuleEntry) GetSnapshot ¶
GetSnapshot will create a structure signature or AST graph
func (*RuleEntry) MakeCatalog ¶ added in v1.8.4
MakeCatalog will create a catalog entry from RuleEntry node.
func (*RuleEntry) SetGrlText ¶
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type RuleEntryMeta ¶ added in v1.8.4
type RuleEntryMeta struct { NodeMeta RuleName string RuleDescription string Salience int WhenScopeID string ThenScopeID string }
RuleEntryMeta meta data for an RuleEntry node
func (*RuleEntryMeta) Equals ¶ added in v1.8.4
func (meta *RuleEntryMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*RuleEntryMeta) GetASTType ¶ added in v1.8.4
func (meta *RuleEntryMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*RuleEntryMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *RuleEntryMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*RuleEntryMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *RuleEntryMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type RuleEntryReceiver ¶ added in v1.6.0
RuleEntryReceiver should be implemented by any rule AST object that receive a RuleEntry
type Salience ¶ added in v1.6.0
type Salience struct {
SalienceValue int
}
Salience is a simple AST object that stores salience
func NewSalience ¶ added in v1.6.0
NewSalience create new Salience AST object
func (*Salience) AcceptIntegerLiteral ¶ added in v1.7.0
func (sal *Salience) AcceptIntegerLiteral(lit *IntegerLiteral)
AcceptIntegerLiteral accept the assigned integer
type SalienceReceiver ¶ added in v1.6.0
SalienceReceiver must be implemented by any AST object that stores salience
type StringLiteral ¶ added in v1.7.0
type StringLiteral struct {
String string
}
StringLiteral will hold StringLiteral constant AST data
type StringLiteralReceiver ¶ added in v1.7.0
type StringLiteralReceiver interface {
AcceptStringLiteral(fun *StringLiteral)
}
StringLiteralReceiver should be implemented by AST graph node to receive a StringLiteral AST graph node
type ThenExpression ¶
type ThenExpression struct { AstID string GrlText string Assignment *Assignment ExpressionAtom *ExpressionAtom }
ThenExpression AST graph node
func NewThenExpression ¶
func NewThenExpression() *ThenExpression
NewThenExpression create new instance of ThenExpression
func (*ThenExpression) AcceptAssignment ¶ added in v1.6.0
func (e *ThenExpression) AcceptAssignment(assignment *Assignment) error
AcceptAssignment will accept Assignment AST graph into this Then ast graph
func (*ThenExpression) AcceptExpressionAtom ¶ added in v1.7.1
func (e *ThenExpression) AcceptExpressionAtom(exp *ExpressionAtom) error
AcceptExpressionAtom will accept an AcceptExpressionAtom AST graph into this ast graph
func (*ThenExpression) Clone ¶ added in v1.4.0
func (e *ThenExpression) Clone(cloneTable *pkg.CloneTable) *ThenExpression
Clone will clone this ThenExpression. The new clone will have an identical structure
func (*ThenExpression) Execute ¶
func (e *ThenExpression) Execute(dataContext IDataContext, memory *WorkingMemory) error
Execute will execute this graph in the Then scope
func (*ThenExpression) GetAstID ¶
func (e *ThenExpression) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*ThenExpression) GetGrlText ¶
func (e *ThenExpression) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*ThenExpression) GetSnapshot ¶
func (e *ThenExpression) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*ThenExpression) MakeCatalog ¶ added in v1.8.4
func (e *ThenExpression) MakeCatalog(cat *Catalog)
MakeCatalog create a catalog entry for this AST Node
func (*ThenExpression) SetGrlText ¶
func (e *ThenExpression) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ThenExpressionList ¶
type ThenExpressionList struct { AstID string GrlText string ThenExpressions []*ThenExpression }
ThenExpressionList AST graph node
func NewThenExpressionList ¶
func NewThenExpressionList() *ThenExpressionList
NewThenExpressionList creates new instance of ThenExpressionList
func (*ThenExpressionList) AcceptThenExpression ¶ added in v1.6.0
func (e *ThenExpressionList) AcceptThenExpression(expr *ThenExpression) error
AcceptThenExpression will accept ThenExpression AST graph into this ExpressionList
func (*ThenExpressionList) Clone ¶ added in v1.4.0
func (e *ThenExpressionList) Clone(cloneTable *pkg.CloneTable) *ThenExpressionList
Clone will clone this ThenExpressionList. The new clone will have an identical structure
func (*ThenExpressionList) Execute ¶
func (e *ThenExpressionList) Execute(dataContext IDataContext, memory *WorkingMemory) error
Execute will execute this graph in the Then scope
func (*ThenExpressionList) GetAstID ¶
func (e *ThenExpressionList) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*ThenExpressionList) GetGrlText ¶
func (e *ThenExpressionList) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*ThenExpressionList) GetSnapshot ¶
func (e *ThenExpressionList) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*ThenExpressionList) MakeCatalog ¶ added in v1.8.4
func (e *ThenExpressionList) MakeCatalog(cat *Catalog)
MakeCatalog create a catalog entry for this AST Node
func (*ThenExpressionList) SetGrlText ¶
func (e *ThenExpressionList) SetGrlText(grlText string)
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ThenExpressionListMeta ¶ added in v1.8.4
ThenExpressionListMeta meta data for an ThenExpressionList node
func (*ThenExpressionListMeta) Equals ¶ added in v1.8.4
func (meta *ThenExpressionListMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ThenExpressionListMeta) GetASTType ¶ added in v1.8.4
func (meta *ThenExpressionListMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ThenExpressionListMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ThenExpressionListMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ThenExpressionListMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ThenExpressionListMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ThenExpressionListReceiver ¶ added in v1.6.0
type ThenExpressionListReceiver interface {
AcceptThenExpressionList(list *ThenExpressionList) error
}
ThenExpressionListReceiver must be implemented by any AST object that hold a ThenExpression list AST object
type ThenExpressionMeta ¶ added in v1.8.4
ThenExpressionMeta meta data for an ThenExpression node
func (*ThenExpressionMeta) Equals ¶ added in v1.8.4
func (meta *ThenExpressionMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ThenExpressionMeta) GetASTType ¶ added in v1.8.4
func (meta *ThenExpressionMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ThenExpressionMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ThenExpressionMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ThenExpressionMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ThenExpressionMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ThenExpressionReceiver ¶ added in v1.6.0
type ThenExpressionReceiver interface {
AcceptThenExpression(expr *ThenExpression) error
}
ThenExpressionReceiver must be implemented by any AST object that will store a Then expression
type ThenScope ¶
type ThenScope struct { AstID string GrlText string ThenExpressionList *ThenExpressionList }
ThenScope AST graph node
func NewThenScope ¶
func NewThenScope() *ThenScope
NewThenScope will create new instance of ThenScope
func (*ThenScope) AcceptThenExpressionList ¶ added in v1.6.0
func (e *ThenScope) AcceptThenExpressionList(list *ThenExpressionList) error
AcceptThenExpressionList will accept ThenExpressionList graph into this ThenScope
func (*ThenScope) Clone ¶ added in v1.4.0
func (e *ThenScope) Clone(cloneTable *pkg.CloneTable) *ThenScope
Clone will clone this ThenScope. The new clone will have an identical structure
func (*ThenScope) Execute ¶
func (e *ThenScope) Execute(dataContext IDataContext, memory *WorkingMemory) error
Execute will execute this graph in the Then scope
func (*ThenScope) GetGrlText ¶
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*ThenScope) GetSnapshot ¶
GetSnapshot will create a structure signature or AST graph
func (*ThenScope) MakeCatalog ¶ added in v1.8.4
MakeCatalog create a catalog entry for this AST Node
func (*ThenScope) SetGrlText ¶
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type ThenScopeMeta ¶ added in v1.8.4
ThenScopeMeta meta data for an ThenScope node
func (*ThenScopeMeta) Equals ¶ added in v1.8.4
func (meta *ThenScopeMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ThenScopeMeta) GetASTType ¶ added in v1.8.4
func (meta *ThenScopeMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ThenScopeMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *ThenScopeMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*ThenScopeMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *ThenScopeMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type ThenScopeReceiver ¶ added in v1.6.0
ThenScopeReceiver must be implemented by any AST object that will hold a ThenScope
type ValueType ¶ added in v1.8.4
type ValueType int
ValueType will label the datatype when a constant its saved as binary
type Variable ¶
type Variable struct { AstID string GrlText string Name string Variable *Variable ArrayMapSelector *ArrayMapSelector ValueNode model.ValueNode Value reflect.Value }
Variable AST graph node
func (*Variable) AcceptArrayMapSelector ¶ added in v1.6.0
func (e *Variable) AcceptArrayMapSelector(sel *ArrayMapSelector) error
AcceptArrayMapSelector accept an array map selector into this variable graph
func (*Variable) AcceptMemberVariable ¶ added in v1.7.0
AcceptMemberVariable accept a member variable information into this Variable graph
func (*Variable) AcceptVariable ¶ added in v1.6.0
AcceptVariable accept a variable AST graph into this Variable graph
func (*Variable) Assign ¶ added in v1.6.0
func (e *Variable) Assign(newVal reflect.Value, dataContext IDataContext, memory *WorkingMemory) error
Assign will assign the specified value to the variable
func (*Variable) Clone ¶ added in v1.4.0
func (e *Variable) Clone(cloneTable *pkg.CloneTable) *Variable
Clone will clone this Variable. The new clone will have an identical structure
func (*Variable) Evaluate ¶
func (e *Variable) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*Variable) GetGrlText ¶
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*Variable) GetSnapshot ¶
GetSnapshot will create a structure signature or AST graph
func (*Variable) MakeCatalog ¶ added in v1.8.4
MakeCatalog create a catalog entry for this AST Node
func (*Variable) SetGrlText ¶
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type VariableMeta ¶ added in v1.8.4
VariableMeta meta data for an Variable node
func (*VariableMeta) Equals ¶ added in v1.8.4
func (meta *VariableMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*VariableMeta) GetASTType ¶ added in v1.8.4
func (meta *VariableMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*VariableMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *VariableMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*VariableMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *VariableMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type VariableReceiver ¶
VariableReceiver should be implemented by AST graph node to receive Variable AST graph node
type WhenScope ¶
type WhenScope struct { AstID string GrlText string Expression *Expression }
WhenScope AST graph node
func (*WhenScope) AcceptExpression ¶
func (e *WhenScope) AcceptExpression(exp *Expression) error
AcceptExpression will accept Expression AST graph node into this node
func (*WhenScope) Clone ¶ added in v1.4.0
func (e *WhenScope) Clone(cloneTable *pkg.CloneTable) *WhenScope
Clone will clone this Clone. The new clone will have an identical structure
func (*WhenScope) Evaluate ¶
func (e *WhenScope) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*WhenScope) GetGrlText ¶
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*WhenScope) GetSnapshot ¶
GetSnapshot will create a structure signature or AST graph
func (*WhenScope) MakeCatalog ¶ added in v1.8.4
MakeCatalog create a catalog entry for this AST Node
func (*WhenScope) SetGrlText ¶
SetGrlText set the expression syntax related to this graph when it was constructed. Only ANTLR4 listener should call this function.
type WhenScopeMeta ¶ added in v1.8.4
WhenScopeMeta meta data for an WhenScope node
func (*WhenScopeMeta) Equals ¶ added in v1.8.4
func (meta *WhenScopeMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*WhenScopeMeta) GetASTType ¶ added in v1.8.4
func (meta *WhenScopeMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*WhenScopeMeta) ReadMetaFrom ¶ added in v1.8.4
func (meta *WhenScopeMeta) ReadMetaFrom(r io.Reader) error
ReadMetaFrom write basic AST Node information meta data from reader. One should not use this function directly, unless for testing serialization of single ASTNode.
func (*WhenScopeMeta) WriteMetaTo ¶ added in v1.8.4
func (meta *WhenScopeMeta) WriteMetaTo(w io.Writer) error
WriteMetaTo write basic AST Node information meta data into writer. One should not use this function directly, unless for testing serialization of single ASTNode.
type WhenScopeReceiver ¶ added in v1.6.0
WhenScopeReceiver must be implemented by AST object that stores WhenScope
type WorkingMemory ¶
type WorkingMemory struct { Name string Version string ID string // contains filtered or unexported fields }
WorkingMemory handles states of expression evaluation status
func NewWorkingMemory ¶
func NewWorkingMemory(name, version string) *WorkingMemory
NewWorkingMemory create new instance of WorkingMemory
func (*WorkingMemory) AddExpression ¶ added in v1.6.0
func (e *WorkingMemory) AddExpression(exp *Expression) *Expression
AddExpression will add expression into its map if the expression signature is unique if the expression is already in its map, it will return one from the map.
func (*WorkingMemory) AddExpressionAtom ¶ added in v1.6.0
func (e *WorkingMemory) AddExpressionAtom(exp *ExpressionAtom) *ExpressionAtom
AddExpressionAtom will add expression atom into its map if the expression signature is unique if the expression is already in its map, it will return one from the map.
func (*WorkingMemory) AddVariable ¶ added in v1.6.0
func (e *WorkingMemory) AddVariable(vari *Variable) *Variable
AddVariable will add variable into its map if the expression signature is unique if the expression is already in its map, it will return one from the map.
func (*WorkingMemory) Clone ¶ added in v1.4.0
func (e *WorkingMemory) Clone(cloneTable *pkg.CloneTable) *WorkingMemory
Clone will clone this WorkingMemory. The new clone will have an identical structure
func (*WorkingMemory) DebugContent ¶ added in v1.6.0
func (e *WorkingMemory) DebugContent()
DebugContent will shows the working memory mapping content
func (*WorkingMemory) Equals ¶ added in v1.6.0
func (e *WorkingMemory) Equals(that *WorkingMemory) bool
Equals shallowly equals check this Working Memory against other working memory
func (*WorkingMemory) IndexVariables ¶ added in v1.6.0
func (e *WorkingMemory) IndexVariables()
IndexVariables will index all expression and expression atoms that contains a speciffic variable name
func (*WorkingMemory) MakeCatalog ¶ added in v1.8.4
func (e *WorkingMemory) MakeCatalog(cat *Catalog)
MakeCatalog create a catalog entry of this working memory
func (*WorkingMemory) Reset ¶
func (e *WorkingMemory) Reset(name string) bool
Reset will reset the evaluated status of a specific variable if its contains a variable name in its signature. Returns true if any expression was reset, false if otherwise
func (*WorkingMemory) ResetAll ¶
func (e *WorkingMemory) ResetAll() bool
ResetAll sets all expression evaluated status to false. Returns true if any expression was reset, false if otherwise
func (*WorkingMemory) ResetVariable ¶ added in v1.6.0
func (e *WorkingMemory) ResetVariable(variable *Variable) bool
ResetVariable will reset the evaluated status of a specific expression if its contains a variable name in its signature. Returns true if any expression was reset, false if otherwise
Source Files ¶
- ArgumentList.go
- ArrayMapSelector.go
- Assignment.go
- Ast.go
- BuiltInFunctions.go
- Constant.go
- DataContext.go
- Expression.go
- ExpressionAtom.go
- FunctionCall.go
- Grl.go
- KnowledgeBase.go
- Literal.go
- RuleEntry.go
- Salience.go
- Serializer.go
- ThenExpression.go
- ThenExpressionList.go
- ThenScope.go
- Variable.go
- WhenScope.go
- WorkingMemory.go