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(reader io.Reader) (string, error)
- func SetLogger(log interface{})
- func WriteBoolToWriter(writer io.Writer, aBoolean 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(writer 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) Array(args ...string) []string
- 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) List(args ...string) []string
- 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) Slice(args ...string) []string
- 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
- func (cat *Catalog) AddMeta(astID string, meta Meta) bool
- func (cat *Catalog) BuildKnowledgeBase() (*KnowledgeBase, error)
- func (cat *Catalog) Equals(that *Catalog) bool
- func (cat *Catalog) ReadCatalogFromReader(reader io.Reader) error
- func (cat *Catalog) WriteCatalogToWriter(writer io.Writer) error
- 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) GetKeys() []string
- func (ctx *DataContext) GetRuleEntry() *RuleEntry
- func (ctx *DataContext) HasVariableChange() bool
- func (ctx *DataContext) IncrementVariableChangeCount()
- func (ctx *DataContext) IsComplete() bool
- func (ctx *DataContext) IsMapAllowedMissingKeys(key string) 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
- func (ctx *DataContext) SetMissingKeyMaps(keys []string)
- func (ctx *DataContext) SetRuleEntry(re *RuleEntry)
- 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) AssignFromAppend(value reflect.Value, memory *WorkingMemory) error
- func (e *ExpressionAtom) CanAssignFromAppend(dataContext IDataContext) bool
- 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, error)
- 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, error)
- func (lib *KnowledgeLibrary) RemoveRuleEntry(ruleName, name string, version string)
- 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(ctx context.Context, dataContext IDataContext, memory *WorkingMemory) (can bool, err error)
- func (e *RuleEntry) Execute(ctx context.Context, 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 (workingMem *WorkingMemory) AddExpression(exp *Expression) *Expression
- func (workingMem *WorkingMemory) AddExpressionAtom(exp *ExpressionAtom) *ExpressionAtom
- func (workingMem *WorkingMemory) AddVariable(vari *Variable) *Variable
- func (workingMem *WorkingMemory) Clone(cloneTable *pkg.CloneTable) (*WorkingMemory, error)
- func (workingMem *WorkingMemory) DebugContent()
- func (workingMem *WorkingMemory) Equals(that *WorkingMemory) bool
- func (workingMem *WorkingMemory) IndexVariables()
- func (workingMem *WorkingMemory) MakeCatalog(cat *Catalog)
- func (workingMem *WorkingMemory) Reset(name string) bool
- func (workingMem *WorkingMemory) ResetAll() bool
- func (workingMem *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 logger instance twith default fields for grule AstLog = logger.Log.WithFields(astLogFields) )
var ( // GrlLogger is the logger that be used from within the rule engine GRL GrlLogger = logger.Log.WithFields(grlLoggerFields) )
Functions ¶
func ReadBoolFromReader ¶
ReadBoolFromReader reads a simple boolean from writer
func ReadFloatFromReader ¶
ReadFloatFromReader reads a 64bit float from reader
func ReadIntFromReader ¶
ReadIntFromReader read a 64 bit integer from reader.
func ReadStringFromReader ¶
ReadStringFromReader read a string from reader.
func WriteBoolToWriter ¶
WriteBoolToWriter writes a simple boolean into writer
func WriteFloatToWriter ¶
WriteFloatToWriter write a 64bit float into writer
func WriteIntToWriter ¶
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 ¶
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 ¶
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 ¶
ArgumentListMeta meta data for an ArgumentList node
func (*ArgumentListMeta) Equals ¶
func (meta *ArgumentListMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ArgumentListMeta) GetASTType ¶
func (meta *ArgumentListMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ArgumentListMeta) ReadMetaFrom ¶
func (meta *ArgumentListMeta) ReadMetaFrom(reader 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 ¶
func (meta *ArgumentListMeta) WriteMetaTo(writer 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 ¶
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 ¶
func NewArrayMapSelector() *ArrayMapSelector
NewArrayMapSelector create a new array selector graph
func (*ArrayMapSelector) AcceptExpression ¶
func (e *ArrayMapSelector) AcceptExpression(exp *Expression) error
AcceptExpression will accept Expression AST graph node into this node
func (*ArrayMapSelector) Clone ¶
func (e *ArrayMapSelector) Clone(cloneTable *pkg.CloneTable) *ArrayMapSelector
Clone will clone this ArgumentList. The new clone will have an identical structure
func (*ArrayMapSelector) Evaluate ¶
func (e *ArrayMapSelector) Evaluate(dataContext IDataContext, memory *WorkingMemory) (reflect.Value, error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*ArrayMapSelector) GetAstID ¶
func (e *ArrayMapSelector) GetAstID() string
GetAstID get the UUID asigned for this AST graph node
func (*ArrayMapSelector) GetGrlText ¶
func (e *ArrayMapSelector) GetGrlText() string
GetGrlText get the expression syntax related to this graph when it wast constructed
func (*ArrayMapSelector) GetSnapshot ¶
func (e *ArrayMapSelector) GetSnapshot() string
GetSnapshot will create a structure signature or AST graph
func (*ArrayMapSelector) MakeCatalog ¶
func (e *ArrayMapSelector) MakeCatalog(cat *Catalog)
MakeCatalog will create a catalog entry from ArrayMapSelector node.
func (*ArrayMapSelector) SetGrlText ¶
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 ¶
ArrayMapSelectorMeta meta data for an ArrayMapSelector node
func (*ArrayMapSelectorMeta) Equals ¶
func (meta *ArrayMapSelectorMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ArrayMapSelectorMeta) GetASTType ¶
func (meta *ArrayMapSelectorMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ArrayMapSelectorMeta) ReadMetaFrom ¶
func (meta *ArrayMapSelectorMeta) ReadMetaFrom(reader 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 ¶
func (meta *ArrayMapSelectorMeta) WriteMetaTo(writer 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 ¶
type ArrayMapSelectorReceiver interface {
AcceptArrayMapSelector(sel *ArrayMapSelector) error
}
ArrayMapSelectorReceiver must be implemented by all other ast graph that uses map/array selector
type AssigmentMeta ¶
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 ¶
func (meta *AssigmentMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*AssigmentMeta) GetASTType ¶
func (meta *AssigmentMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*AssigmentMeta) ReadMetaFrom ¶
func (meta *AssigmentMeta) ReadMetaFrom(reader 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 ¶
func (meta *AssigmentMeta) WriteMetaTo(writer 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 ¶
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 ¶
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 ¶
type AssignmentReceiver interface {
AcceptAssignment(assignment *Assignment) error
}
AssignmentReceiver must be implemented by all other ast graph that uses an assigment expression
type BooleanLiteral ¶
type BooleanLiteral struct {
Boolean bool
}
BooleanLiteral will hold BooleanLiteral constant AST data
type BooleanLiteralReceiver ¶
type BooleanLiteralReceiver interface {
AcceptBooleanLiteral(fun *BooleanLiteral)
}
BooleanLiteralReceiver should be implemented by AST graph node to receive a BooleanLiteral AST graph node
type BuiltInFunctions ¶
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 ¶
func (gf *BuiltInFunctions) Abs(x float64) float64
Abs is a wrapper function for math.Abs function
func (*BuiltInFunctions) Acos ¶
func (gf *BuiltInFunctions) Acos(x float64) float64
Acos is a wrapper function for math.Acos function
func (*BuiltInFunctions) Acosh ¶
func (gf *BuiltInFunctions) Acosh(x float64) float64
Acosh is a wrapper function for math.Acosh function
func (*BuiltInFunctions) Array ¶ added in v0.1.5
func (gf *BuiltInFunctions) Array(args ...string) []string
func (*BuiltInFunctions) Asin ¶
func (gf *BuiltInFunctions) Asin(x float64) float64
Asin is a wrapper function for math.Asin function
func (*BuiltInFunctions) Asinh ¶
func (gf *BuiltInFunctions) Asinh(x float64) float64
Asinh is a wrapper function for math.Asinh function
func (*BuiltInFunctions) Atan ¶
func (gf *BuiltInFunctions) Atan(x float64) float64
Atan is a wrapper function for math.Atan function
func (*BuiltInFunctions) Atan2 ¶
func (gf *BuiltInFunctions) Atan2(y, x float64) float64
Atan2 is a wrapper function for math.Atan2 function
func (*BuiltInFunctions) Atanh ¶
func (gf *BuiltInFunctions) Atanh(x float64) float64
Atanh is a wrapper function for math.Atanh function
func (*BuiltInFunctions) Cbrt ¶
func (gf *BuiltInFunctions) Cbrt(x float64) float64
Cbrt is a wrapper function for math.Cbrt function
func (*BuiltInFunctions) Ceil ¶
func (gf *BuiltInFunctions) Ceil(x float64) float64
Ceil is a wrapper function for math.Ceil function
func (*BuiltInFunctions) Changed ¶
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 ¶
func (gf *BuiltInFunctions) Complete()
Complete will cause the engine to stop processing further rules in the current cycle.
func (*BuiltInFunctions) Copysign ¶
func (gf *BuiltInFunctions) Copysign(x, y float64) float64
Copysign is a wrapper function for math.Copysign function
func (*BuiltInFunctions) Cos ¶
func (gf *BuiltInFunctions) Cos(x float64) float64
Cos is a wrapper function for math.Cos function
func (*BuiltInFunctions) Cosh ¶
func (gf *BuiltInFunctions) Cosh(x float64) float64
Cosh is a wrapper function for math.Cosh function
func (*BuiltInFunctions) Dim ¶
func (gf *BuiltInFunctions) Dim(x, y float64) float64
Dim is a wrapper function for math.Dim function
func (*BuiltInFunctions) Erf ¶
func (gf *BuiltInFunctions) Erf(x float64) float64
Erf is a wrapper function for math.Erf function
func (*BuiltInFunctions) Erfc ¶
func (gf *BuiltInFunctions) Erfc(x float64) float64
Erfc is a wrapper function for math.Erfc function
func (*BuiltInFunctions) Erfcinv ¶
func (gf *BuiltInFunctions) Erfcinv(x float64) float64
Erfcinv is a wrapper function for math.Erfcinv function
func (*BuiltInFunctions) Erfinv ¶
func (gf *BuiltInFunctions) Erfinv(x float64) float64
Erfinv is a wrapper function for math.Erfinv function
func (*BuiltInFunctions) Exp ¶
func (gf *BuiltInFunctions) Exp(x float64) float64
Exp is a wrapper function for math.Exp function
func (*BuiltInFunctions) Exp2 ¶
func (gf *BuiltInFunctions) Exp2(x float64) float64
Exp2 is a wrapper function for math.Exp2 function
func (*BuiltInFunctions) Expm1 ¶
func (gf *BuiltInFunctions) Expm1(x float64) float64
Expm1 is a wrapper function for math.Expm1 function
func (*BuiltInFunctions) Float64bits ¶
func (gf *BuiltInFunctions) Float64bits(f float64) uint64
Float64bits is a wrapper function for math.Float64bits function
func (*BuiltInFunctions) Float64frombits ¶
func (gf *BuiltInFunctions) Float64frombits(b uint64) float64
Float64frombits is a wrapper function for math.Float64frombits function
func (*BuiltInFunctions) Floor ¶
func (gf *BuiltInFunctions) Floor(x float64) float64
Floor is a wrapper function for math.Floor function
func (*BuiltInFunctions) Forget ¶
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 ¶
func (gf *BuiltInFunctions) Gamma(x float64) float64
Gamma is a wrapper function for math.Gamma function
func (*BuiltInFunctions) GetTimeDay ¶
func (gf *BuiltInFunctions) GetTimeDay(time time.Time) int
GetTimeDay will get the day value of time
func (*BuiltInFunctions) GetTimeHour ¶
func (gf *BuiltInFunctions) GetTimeHour(time time.Time) int
GetTimeHour will get the hour value of time
func (*BuiltInFunctions) GetTimeMinute ¶
func (gf *BuiltInFunctions) GetTimeMinute(time time.Time) int
GetTimeMinute will get the minute value of time
func (*BuiltInFunctions) GetTimeMonth ¶
func (gf *BuiltInFunctions) GetTimeMonth(time time.Time) int
GetTimeMonth will get the month value of time
func (*BuiltInFunctions) GetTimeSecond ¶
func (gf *BuiltInFunctions) GetTimeSecond(time time.Time) int
GetTimeSecond will get the second value of time
func (*BuiltInFunctions) GetTimeYear ¶
func (gf *BuiltInFunctions) GetTimeYear(time time.Time) int
GetTimeYear will get the year value of time
func (*BuiltInFunctions) Hypot ¶
func (gf *BuiltInFunctions) Hypot(p, q float64) float64
Hypot is a wrapper function for math.Hypot function
func (*BuiltInFunctions) Ilogb ¶
func (gf *BuiltInFunctions) Ilogb(x float64) int
Ilogb is a wrapper function for math.Ilogb function
func (*BuiltInFunctions) IsInf ¶
func (gf *BuiltInFunctions) IsInf(f float64, sign int64) bool
IsInf is a wrapper function for math.IsInf function
func (*BuiltInFunctions) IsNaN ¶
func (gf *BuiltInFunctions) IsNaN(f float64) (is bool)
IsNaN is a wrapper function for math.IsNaN function
func (*BuiltInFunctions) IsNil ¶
func (gf *BuiltInFunctions) IsNil(i interface{}) bool
IsNil Enables nill checking on variables.
func (*BuiltInFunctions) IsTimeAfter ¶
func (gf *BuiltInFunctions) IsTimeAfter(time, after time.Time) bool
IsTimeAfter will check if the 1st argument is after the 2nd argument.
func (*BuiltInFunctions) IsTimeBefore ¶
func (gf *BuiltInFunctions) IsTimeBefore(time, before time.Time) bool
IsTimeBefore will check if the 1st argument is before the 2nd argument.
func (*BuiltInFunctions) IsZero ¶
func (gf *BuiltInFunctions) IsZero(i interface{}) bool
IsZero Enable zero checking
func (*BuiltInFunctions) J0 ¶
func (gf *BuiltInFunctions) J0(x float64) float64
J0 is a wrapper function for math.J0 function
func (*BuiltInFunctions) J1 ¶
func (gf *BuiltInFunctions) J1(x float64) float64
J1 is a wrapper function for math.J1 function
func (*BuiltInFunctions) Jn ¶
func (gf *BuiltInFunctions) Jn(n int64, x float64) float64
Jn is a wrapper function for math.Jn function
func (*BuiltInFunctions) Ldexp ¶
func (gf *BuiltInFunctions) Ldexp(frac float64, exp int64) float64
Ldexp is a wrapper function for math.Ldexp function
func (*BuiltInFunctions) List ¶ added in v0.1.5
func (gf *BuiltInFunctions) List(args ...string) []string
List / Array / Slice all do the same thing - take a variadic string set and return a slice
func (*BuiltInFunctions) Log ¶
func (gf *BuiltInFunctions) Log(text string)
Log extension to log.Print
func (*BuiltInFunctions) Log10 ¶
func (gf *BuiltInFunctions) Log10(x float64) float64
Log10 is a wrapper function for math.Log10 function
func (*BuiltInFunctions) Log1p ¶
func (gf *BuiltInFunctions) Log1p(x float64) float64
Log1p is a wrapper function for math.Log1p function
func (*BuiltInFunctions) Log2 ¶
func (gf *BuiltInFunctions) Log2(x float64) float64
Log2 is a wrapper function for math.Log2 function
func (*BuiltInFunctions) LogFormat ¶
func (gf *BuiltInFunctions) LogFormat(format string, i interface{})
LogFormat extension to log.Printf
func (*BuiltInFunctions) Logb ¶
func (gf *BuiltInFunctions) Logb(x float64) float64
Logb is a wrapper function for math.Logb function
func (*BuiltInFunctions) MakeTime ¶
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 ¶
func (gf *BuiltInFunctions) MathLog(x float64) float64
MathLog is a wrapper function for math.MathLog function
func (*BuiltInFunctions) Max ¶
func (gf *BuiltInFunctions) Max(vals ...float64) float64
Max will pick the biggest of value in the arguments
func (*BuiltInFunctions) Min ¶
func (gf *BuiltInFunctions) Min(vals ...float64) float64
Min will pick the smallest of value in the arguments
func (*BuiltInFunctions) Mod ¶
func (gf *BuiltInFunctions) Mod(x, y float64) float64
Mod is a wrapper function for math.Mod function
func (*BuiltInFunctions) NaN ¶
func (gf *BuiltInFunctions) NaN() float64
NaN is a wrapper function for math.NaN function
func (*BuiltInFunctions) Now ¶
func (gf *BuiltInFunctions) Now() time.Time
Now is an extension tn time.Now().
func (*BuiltInFunctions) Pow ¶
func (gf *BuiltInFunctions) Pow(x, y float64) float64
Pow is a wrapper function for math.Pow function
func (*BuiltInFunctions) Pow10 ¶
func (gf *BuiltInFunctions) Pow10(n int64) float64
Pow10 is a wrapper function for math.Pow10 function
func (*BuiltInFunctions) Remainder ¶
func (gf *BuiltInFunctions) Remainder(x, y float64) float64
Remainder is a wrapper function for math.Remainder function
func (*BuiltInFunctions) Retract ¶
func (gf *BuiltInFunctions) Retract(ruleName string)
Retract will retract a rule from next evaluation cycle.
func (*BuiltInFunctions) Round ¶
func (gf *BuiltInFunctions) Round(x float64) float64
Round is a wrapper function for math.Round function
func (*BuiltInFunctions) RoundToEven ¶
func (gf *BuiltInFunctions) RoundToEven(x float64) float64
RoundToEven is a wrapper function for math.RoundToEven function
func (*BuiltInFunctions) Signbit ¶
func (gf *BuiltInFunctions) Signbit(x float64) bool
Signbit is a wrapper function for math.Signbit function
func (*BuiltInFunctions) Sin ¶
func (gf *BuiltInFunctions) Sin(x float64) float64
Sin is a wrapper function for math.Sin function
func (*BuiltInFunctions) Sinh ¶
func (gf *BuiltInFunctions) Sinh(x float64) float64
Sinh is a wrapper function for math.Sinh function
func (*BuiltInFunctions) Slice ¶ added in v0.1.5
func (gf *BuiltInFunctions) Slice(args ...string) []string
func (*BuiltInFunctions) Sqrt ¶
func (gf *BuiltInFunctions) Sqrt(x float64) float64
Sqrt is a wrapper function for math.Sqrt function
func (*BuiltInFunctions) StringContains ¶
func (gf *BuiltInFunctions) StringContains(str, substr string) bool
StringContains extension to strings.Contains
func (*BuiltInFunctions) Tan ¶
func (gf *BuiltInFunctions) Tan(x float64) float64
Tan is a wrapper function for math.Tan function
func (*BuiltInFunctions) Tanh ¶
func (gf *BuiltInFunctions) Tanh(x float64) float64
Tanh is a wrapper function for math.Tanh function
func (*BuiltInFunctions) TimeFormat ¶
func (gf *BuiltInFunctions) TimeFormat(time time.Time, layout string) string
TimeFormat will format a time according to format layout.
func (*BuiltInFunctions) Trunc ¶
func (gf *BuiltInFunctions) Trunc(x float64) float64
Trunc is a wrapper function for math.Trunc function
type Catalog ¶
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 ¶
AddMeta will add AST Node meta information. it will reject duplicated AST ID
func (*Catalog) BuildKnowledgeBase ¶
func (cat *Catalog) BuildKnowledgeBase() (*KnowledgeBase, error)
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 ¶
Equals used for testing purpose, to ensure that two catalog can be compared straight away. The comparison is Deep comparison.
func (*Catalog) ReadCatalogFromReader ¶
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 ¶
func (e *Constant) AcceptBooleanLiteral(fun *BooleanLiteral)
AcceptBooleanLiteral will accept boolean literal
func (*Constant) AcceptFloatLiteral ¶
func (e *Constant) AcceptFloatLiteral(fun *FloatLiteral)
AcceptFloatLiteral will accept float literal
func (*Constant) AcceptIntegerLiteral ¶
func (e *Constant) AcceptIntegerLiteral(fun *IntegerLiteral)
AcceptIntegerLiteral will accept integer literal
func (*Constant) AcceptStringLiteral ¶
func (e *Constant) AcceptStringLiteral(fun *StringLiteral)
AcceptStringLiteral will accept string literal
func (*Constant) Clone ¶
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 ¶
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 ¶
ConstantMeta meta data for an Constant node
func (*ConstantMeta) Equals ¶
func (meta *ConstantMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ConstantMeta) GetASTType ¶
func (meta *ConstantMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ConstantMeta) ReadMetaFrom ¶
func (meta *ConstantMeta) ReadMetaFrom(reader 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 ¶
func (meta *ConstantMeta) WriteMetaTo(writer 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 ¶
func (ctx *DataContext) AddJSON(key string, JSON []byte) error
AddJSON will add struct instance into rule execution context
func (*DataContext) Complete ¶
func (ctx *DataContext) Complete()
Complete marks the DataContext as completed, telling the engine to stop processing rules
func (*DataContext) Get ¶
func (ctx *DataContext) Get(key string) model.ValueNode
Get will extract the struct instance
func (*DataContext) GetKeys ¶
func (ctx *DataContext) GetKeys() []string
func (*DataContext) GetRuleEntry ¶
func (ctx *DataContext) GetRuleEntry() *RuleEntry
func (*DataContext) HasVariableChange ¶
func (ctx *DataContext) HasVariableChange() bool
HasVariableChange returns true if there are variable changes
func (*DataContext) IncrementVariableChangeCount ¶
func (ctx *DataContext) IncrementVariableChangeCount()
IncrementVariableChangeCount will increment the variable change count
func (*DataContext) IsComplete ¶
func (ctx *DataContext) IsComplete() bool
IsComplete checks whether the DataContext has been completed
func (*DataContext) IsMapAllowedMissingKeys ¶ added in v0.1.4
func (ctx *DataContext) IsMapAllowedMissingKeys(key string) bool
func (*DataContext) IsRetracted ¶
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 ¶
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.
func (*DataContext) SetMissingKeyMaps ¶ added in v0.1.4
func (ctx *DataContext) SetMissingKeyMaps(keys []string)
func (*DataContext) SetRuleEntry ¶
func (ctx *DataContext) SetRuleEntry(re *RuleEntry)
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 ¶
func (e *Expression) AcceptExpressionAtom(atom *ExpressionAtom) error
AcceptExpressionAtom will accept ExpressionAtom into this Expression
func (*Expression) Clone ¶
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 ¶
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 ¶
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 ¶
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 ¶
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) AssignFromAppend ¶ added in v0.1.5
func (e *ExpressionAtom) AssignFromAppend(value reflect.Value, memory *WorkingMemory) error
func (*ExpressionAtom) CanAssignFromAppend ¶ added in v0.1.5
func (e *ExpressionAtom) CanAssignFromAppend(dataContext IDataContext) bool
func (*ExpressionAtom) Clone ¶
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 ¶
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 ¶
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 ¶
func (meta *ExpressionAtomMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ExpressionAtomMeta) GetASTType ¶
func (meta *ExpressionAtomMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ExpressionAtomMeta) ReadMetaFrom ¶
func (meta *ExpressionAtomMeta) ReadMetaFrom(reader 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 ¶
func (meta *ExpressionAtomMeta) WriteMetaTo(writer 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 ¶
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 ¶
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 ¶
func (meta *ExpressionMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ExpressionMeta) GetASTType ¶
func (meta *ExpressionMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ExpressionMeta) ReadMetaFrom ¶
func (meta *ExpressionMeta) ReadMetaFrom(reader 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 ¶
func (meta *ExpressionMeta) WriteMetaTo(writer 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 ¶
type FloatLiteral struct {
Float float64
}
FloatLiteral will hold FloatLiteral constant AST data
type FloatLiteralReceiver ¶
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 ¶
func (e *FunctionCall) Clone(cloneTable *pkg.CloneTable) *FunctionCall
Clone will clone this FunctionCall. The new clone will have an identical structure
func (*FunctionCall) EvaluateArgumentList ¶
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 ¶
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 ¶
FunctionCallMeta meta data for an FunctionCall node
func (*FunctionCallMeta) Equals ¶
func (meta *FunctionCallMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*FunctionCallMeta) GetASTType ¶
func (meta *FunctionCallMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*FunctionCallMeta) ReadMetaFrom ¶
func (meta *FunctionCallMeta) ReadMetaFrom(reader 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 ¶
func (meta *FunctionCallMeta) WriteMetaTo(writer 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 ¶
Grl will contains multiple RuleEntries
func (*Grl) ReceiveRuleEntry ¶
ReceiveRuleEntry will make this GRL to accept rule entries created by ANTLR walker
type GrlReceiver ¶
GrlReceiver is interface for objects that should hold a GRL, will be called by ANTLR walker.
type IDataContext ¶
type IDataContext interface { ResetVariableChangeCount() IncrementVariableChangeCount() HasVariableChange() bool Add(key string, obj interface{}) error AddJSON(key string, JSON []byte) error Get(key string) model.ValueNode GetKeys() []string Retract(key string) IsRetracted(key string) bool Complete() IsComplete() bool Retracted() []string Reset() SetMissingKeyMaps(keys []string) IsMapAllowedMissingKeys(key string) bool SetRuleEntry(re *RuleEntry) GetRuleEntry() *RuleEntry }
IDataContext is the interface for the DataContext struct.
func NewDataContext ¶
func NewDataContext() IDataContext
NewDataContext will create a new DataContext instance
type IntegerLiteral ¶
type IntegerLiteral struct {
Integer int64
}
IntegerLiteral will hold IntegerLiteral constant AST data
type IntegerLiteralReceiver ¶
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 ¶
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 ¶
func (e *KnowledgeBase) Clone(cloneTable *pkg.CloneTable) (*KnowledgeBase, error)
Clone will clone this instance of KnowledgeBase and produce another (structure wise) identical instance.
func (*KnowledgeBase) ContainsRuleEntry ¶
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 ¶
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 ¶
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 ¶
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 ¶
func (e *KnowledgeBase) RemoveRuleEntry(name string)
RemoveRuleEntry mark the rule entry as deleted
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 ¶
type KnowledgeLibrary struct {
Library map[string]*KnowledgeBase
}
KnowledgeLibrary is a knowledgebase store.
func NewKnowledgeLibrary ¶
func NewKnowledgeLibrary() *KnowledgeLibrary
NewKnowledgeLibrary create a new instance KnowledgeLibrary
func (*KnowledgeLibrary) GetKnowledgeBase ¶
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 ¶
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 ¶
func (lib *KnowledgeLibrary) NewKnowledgeBaseInstance(name, version string) (*KnowledgeBase, error)
NewKnowledgeBaseInstance will create a new instance based on KnowledgeBase blue print identified by its name and version
func (*KnowledgeLibrary) RemoveRuleEntry ¶
func (lib *KnowledgeLibrary) RemoveRuleEntry(ruleName, name string, version string)
RemoveRuleEntry mark the rule entry as deleted
func (*KnowledgeLibrary) StoreKnowledgeBaseToWriter ¶
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 ¶
type MemberVariableReceiver interface {
AcceptMemberVariable(name string)
}
MemberVariableReceiver should be implemented by AST graph node to receive member Variable information.
type Meta ¶
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 ¶
NodeMeta is a base struct for all ASTNode meta
func (*NodeMeta) GetGrlText ¶
GetGrlText return the node original GRLText, this might not be needed but useful for debuging future GRL issue
func (*NodeMeta) GetSnapshot ¶
GetSnapshot return the NodeSnapshot, this might not needed but could be useful for consistency.
func (*NodeMeta) ReadMetaFrom ¶
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 RuleEntry ¶
type RuleEntry struct { AstID string GrlText string RuleName string RuleDescription string Salience int WhenScope *WhenScope ThenScope *ThenScope Retracted bool Deleted bool //If this is true, it will be ignored while execution and fetching the matching rules }
RuleEntry AST graph node
func (*RuleEntry) AcceptSalience ¶
AcceptSalience will accept salience value
func (*RuleEntry) AcceptThenScope ¶
AcceptThenScope will accept ThenScope AST Graph into this AST Graph
func (*RuleEntry) AcceptWhenScope ¶
AcceptWhenScope will accept WhenScope AST Graph into this AST Graph
func (*RuleEntry) Clone ¶
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(ctx context.Context, dataContext IDataContext, memory *WorkingMemory) (can bool, err error)
Evaluate will evaluate this AST graph for when scope evaluation
func (*RuleEntry) Execute ¶
func (e *RuleEntry) Execute(ctx context.Context, 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 ¶
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 ¶
type RuleEntryMeta struct { NodeMeta RuleName string RuleDescription string Salience int WhenScopeID string ThenScopeID string }
RuleEntryMeta meta data for an RuleEntry node
func (*RuleEntryMeta) Equals ¶
func (meta *RuleEntryMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*RuleEntryMeta) GetASTType ¶
func (meta *RuleEntryMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*RuleEntryMeta) ReadMetaFrom ¶
func (meta *RuleEntryMeta) ReadMetaFrom(reader 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 ¶
func (meta *RuleEntryMeta) WriteMetaTo(writer 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 ¶
RuleEntryReceiver should be implemented by any rule AST object that receive a RuleEntry
type Salience ¶
type Salience struct {
SalienceValue int
}
Salience is a simple AST object that stores salience
func (*Salience) AcceptIntegerLiteral ¶
func (sal *Salience) AcceptIntegerLiteral(lit *IntegerLiteral)
AcceptIntegerLiteral accept the assigned integer
type SalienceReceiver ¶
SalienceReceiver must be implemented by any AST object that stores salience
type StringLiteral ¶
type StringLiteral struct {
String string
}
StringLiteral will hold StringLiteral constant AST data
type StringLiteralReceiver ¶
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 ¶
func (e *ThenExpression) AcceptAssignment(assignment *Assignment) error
AcceptAssignment will accept Assignment AST graph into this Then ast graph
func (*ThenExpression) AcceptExpressionAtom ¶
func (e *ThenExpression) AcceptExpressionAtom(exp *ExpressionAtom) error
AcceptExpressionAtom will accept an AcceptExpressionAtom AST graph into this ast graph
func (*ThenExpression) Clone ¶
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 ¶
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 ¶
func (e *ThenExpressionList) AcceptThenExpression(expr *ThenExpression) error
AcceptThenExpression will accept ThenExpression AST graph into this ExpressionList
func (*ThenExpressionList) Clone ¶
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 ¶
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 ¶
ThenExpressionListMeta meta data for an ThenExpressionList node
func (*ThenExpressionListMeta) Equals ¶
func (meta *ThenExpressionListMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ThenExpressionListMeta) GetASTType ¶
func (meta *ThenExpressionListMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ThenExpressionListMeta) ReadMetaFrom ¶
func (meta *ThenExpressionListMeta) ReadMetaFrom(reader 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 ¶
func (meta *ThenExpressionListMeta) WriteMetaTo(writer 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 ¶
type ThenExpressionListReceiver interface {
AcceptThenExpressionList(list *ThenExpressionList) error
}
ThenExpressionListReceiver must be implemented by any AST object that hold a ThenExpression list AST object
type ThenExpressionMeta ¶
ThenExpressionMeta meta data for an ThenExpression node
func (*ThenExpressionMeta) Equals ¶
func (meta *ThenExpressionMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ThenExpressionMeta) GetASTType ¶
func (meta *ThenExpressionMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ThenExpressionMeta) ReadMetaFrom ¶
func (meta *ThenExpressionMeta) ReadMetaFrom(reader 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 ¶
func (meta *ThenExpressionMeta) WriteMetaTo(writer 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 ¶
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 ¶
func (e *ThenScope) AcceptThenExpressionList(list *ThenExpressionList) error
AcceptThenExpressionList will accept ThenExpressionList graph into this ThenScope
func (*ThenScope) Clone ¶
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 ¶
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 ¶
ThenScopeMeta meta data for an ThenScope node
func (*ThenScopeMeta) Equals ¶
func (meta *ThenScopeMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*ThenScopeMeta) GetASTType ¶
func (meta *ThenScopeMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*ThenScopeMeta) ReadMetaFrom ¶
func (meta *ThenScopeMeta) ReadMetaFrom(reader 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 ¶
func (meta *ThenScopeMeta) WriteMetaTo(writer 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 ¶
ThenScopeReceiver must be implemented by any AST object that will hold a ThenScope
type ValueType ¶
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 ¶
func (e *Variable) AcceptArrayMapSelector(sel *ArrayMapSelector) error
AcceptArrayMapSelector accept an array map selector into this variable graph
func (*Variable) AcceptMemberVariable ¶
AcceptMemberVariable accept a member variable information into this Variable graph
func (*Variable) AcceptVariable ¶
AcceptVariable accept a variable AST graph into this Variable graph
func (*Variable) Assign ¶
func (e *Variable) Assign(newVal reflect.Value, dataContext IDataContext, memory *WorkingMemory) error
Assign will assign the specified value to the variable
func (*Variable) Clone ¶
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 ¶
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 ¶
VariableMeta meta data for an Variable node
func (*VariableMeta) Equals ¶
func (meta *VariableMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*VariableMeta) GetASTType ¶
func (meta *VariableMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*VariableMeta) ReadMetaFrom ¶
func (meta *VariableMeta) ReadMetaFrom(reader 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 ¶
func (meta *VariableMeta) WriteMetaTo(writer 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 ¶
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 ¶
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 ¶
WhenScopeMeta meta data for an WhenScope node
func (*WhenScopeMeta) Equals ¶
func (meta *WhenScopeMeta) Equals(that Meta) bool
Equals basic function to test equality of two MetaNode
func (*WhenScopeMeta) GetASTType ¶
func (meta *WhenScopeMeta) GetASTType() NodeType
GetASTType returns the meta type of this AST Node
func (*WhenScopeMeta) ReadMetaFrom ¶
func (meta *WhenScopeMeta) ReadMetaFrom(reader 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 ¶
func (meta *WhenScopeMeta) WriteMetaTo(writer 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 ¶
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 ¶
func (workingMem *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 ¶
func (workingMem *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 ¶
func (workingMem *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 ¶
func (workingMem *WorkingMemory) Clone(cloneTable *pkg.CloneTable) (*WorkingMemory, error)
Clone will clone this WorkingMemory. The new clone will have an identical structure
func (*WorkingMemory) DebugContent ¶
func (workingMem *WorkingMemory) DebugContent()
DebugContent will shows the working memory mapping content
func (*WorkingMemory) Equals ¶
func (workingMem *WorkingMemory) Equals(that *WorkingMemory) bool
Equals shallowly equals check this Working Memory against other working memory
func (*WorkingMemory) IndexVariables ¶
func (workingMem *WorkingMemory) IndexVariables()
IndexVariables will index all expression and expression atoms that contains a speciffic variable name
func (*WorkingMemory) MakeCatalog ¶
func (workingMem *WorkingMemory) MakeCatalog(cat *Catalog)
MakeCatalog create a catalog entry of this working memory
func (*WorkingMemory) Reset ¶
func (workingMem *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 (workingMem *WorkingMemory) ResetAll() bool
ResetAll sets all expression evaluated status to false. Returns true if any expression was reset, false if otherwise
func (*WorkingMemory) ResetVariable ¶
func (workingMem *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