Oracle SOABusiness Rules
Oracle SOABusiness Rules
October 2009
Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules, 11g Release 1 (11.1.1)
E10227-02
Copyright © 2005, 2009, Oracle and/or its affiliates. All rights reserved.
Contributors: Qun Chen, Ching Chung, David Clay, Kathryn Gruenefeldt, Gary Hallmark, Phil Varner,
Neal Wyse
This software and related documentation are provided under a license agreement containing restrictions on
use and disclosure and are protected by intellectual property laws. Except as expressly permitted in your
license agreement or allowed by law, you may not use, copy, reproduce, translate, broadcast, modify, license,
transmit, distribute, exhibit, perform, publish, or display any part, in any form, or by any means. Reverse
engineering, disassembly, or decompilation of this software, unless required by law for interoperability, is
prohibited.
The information contained herein is subject to change without notice and is not warranted to be error-free. If
you find any errors, please report them to us in writing.
If this software or related documentation is delivered to the U.S. Government or anyone licensing it on
behalf of the U.S. Government, the following notice is applicable:
U.S. GOVERNMENT RIGHTS Programs, software, databases, and related documentation and technical data
delivered to U.S. Government customers are "commercial computer software" or "commercial technical data"
pursuant to the applicable Federal Acquisition Regulation and agency-specific supplemental regulations. As
such, the use, duplication, disclosure, modification, and adaptation shall be subject to the restrictions and
license terms set forth in the applicable Government contract, and, to the extent applicable by the terms of
the Government contract, the additional rights set forth in FAR 52.227-19, Commercial Computer Software
License (December 2007). Oracle USA, Inc., 500 Oracle Parkway, Redwood City, CA 94065.
This software is developed for general use in a variety of information management applications. It is not
developed or intended for use in any inherently dangerous applications, including applications which may
create a risk of personal injury. If you use this software in dangerous applications, then you shall be
responsible to take all appropriate fail-safe, backup, redundancy, and other measures to ensure the safe use
of this software. Oracle Corporation and its affiliates disclaim any liability for any damages caused by use of
this software in dangerous applications.
Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks
of their respective owners.
This software and documentation may provide access to or information on content, products, and services
from third parties. Oracle Corporation and its affiliates are not responsible for and expressly disclaim all
warranties of any kind with respect to third-party content, products, and services. Oracle Corporation and
its affiliates will not be responsible for any loss, costs, or damages incurred due to your access to or use of
third-party content, products, or services.
Contents
iii
Definitions.................................................................................................................................... 2-9
Variable Definitions.......................................................................................................... 2-10
Rule Definitions ................................................................................................................ 2-12
Class Definitions ............................................................................................................... 2-15
Function Definitions......................................................................................................... 2-20
Fact Class Declarations............................................................................................................ 2-21
Import Statement ..................................................................................................................... 2-25
Include Statement .................................................................................................................... 2-26
Using Expressions.................................................................................................................... 2-27
Boolean Expressions......................................................................................................... 2-28
Numeric Expressions ....................................................................................................... 2-30
String Expressions ............................................................................................................ 2-31
Array Expressions............................................................................................................. 2-32
Fact Set Expressions ......................................................................................................... 2-33
Comparable Expression ................................................................................................... 2-39
Object Expressions............................................................................................................ 2-40
Primary Expressions......................................................................................................... 2-41
Actions and Action Blocks...................................................................................................... 2-45
If Else Action Block........................................................................................................... 2-46
While Action Block ........................................................................................................... 2-47
For Action Block................................................................................................................ 2-48
Try Catch Finally Action Block....................................................................................... 2-49
Synchronized Action Block ............................................................................................. 2-50
Modify Action ................................................................................................................... 2-51
Return Action .................................................................................................................... 2-53
Throw Action..................................................................................................................... 2-54
Assign Action .................................................................................................................... 2-55
Increment or Decrement Expressions ............................................................................ 2-56
Primary Actions ................................................................................................................ 2-57
Rulegroup.................................................................................................................................. 2-58
Built-in Functions..................................................................................................................... 2-60
assert ................................................................................................................................... 2-61
assertTree ........................................................................................................................... 2-63
assertXPath ........................................................................................................................ 2-64
clearRule............................................................................................................................. 2-65
clearRulesetStack .............................................................................................................. 2-66
clearWatchRules, clearWatchActivations, clearWatchFacts, clearWatchFocus, clear-
WatchCompilations, clearWatchAll 2-67
contains .............................................................................................................................. 2-68
getCurrentDate.................................................................................................................. 2-69
getDecisionTrace............................................................................................................... 2-70
getDecisionTraceLevel ..................................................................................................... 2-71
iv
getDecisionTraceLimit ..................................................................................................... 2-72
getEffectiveDate ................................................................................................................ 2-73
getFactsByType ................................................................................................................. 2-74
getRulesetStack ................................................................................................................. 2-75
getRuleSession................................................................................................................... 2-76
getStrategy ......................................................................................................................... 2-77
halt ...................................................................................................................................... 2-78
id.......................................................................................................................................... 2-79
object ................................................................................................................................... 2-80
println ................................................................................................................................. 2-81
popRuleset ......................................................................................................................... 2-82
pushRuleset ....................................................................................................................... 2-83
retract.................................................................................................................................. 2-84
reset..................................................................................................................................... 2-85
run ....................................................................................................................................... 2-86
runUntilHalt ...................................................................................................................... 2-87
setCurrentDate .................................................................................................................. 2-88
setDecisionTraceLevel...................................................................................................... 2-89
setDecisionTraceLimit...................................................................................................... 2-90
setEffectiveDate................................................................................................................. 2-91
setRulesetStack.................................................................................................................. 2-92
setStrategy.......................................................................................................................... 2-93
showActivations ............................................................................................................... 2-94
showFacts........................................................................................................................... 2-95
step ...................................................................................................................................... 2-96
watchRules, watchActivations, watchFacts, watchFocus, watchCompilations ...... 2-97
4 Using a RuleSession
4.1 RuleSession Constructor Properties......................................................................................... 4-2
4.2 RuleSession Methods.................................................................................................................. 4-2
4.3 RL to Java Type Conversion...................................................................................................... 4-2
4.4 Error Handling ............................................................................................................................ 4-3
4.5 RL Class Reflection ..................................................................................................................... 4-3
4.6 XML Navigation.......................................................................................................................... 4-3
4.7 Obtaining Results from a Rule Enabled Program .................................................................. 4-4
4.7.1 Overview of Results Examples .......................................................................................... 4-4
v
4.7.2 Using External Resources to Obtain Results.................................................................... 4-5
4.8 Debugging an RL Stacktrace ..................................................................................................... 4-5
4.9 Using RuleSession Pooling ........................................................................................................ 4-7
4.9.1 How to Create a RuleSession Pool .................................................................................... 4-7
4.9.2 How to Use a RuleSession Pool ......................................................................................... 4-8
4.10 Using RuleSession Options ....................................................................................................... 4-8
4.10.1 Using the CFG_LOGGING System Property .................................................................. 4-8
4.10.2 Using the CFG_DECISION_TRACE_LEVEL Option..................................................... 4-9
4.10.3 Using the CFG_DECISION_TRACE_LIMIT Option ...................................................... 4-9
Index
vi
Preface
Audience
Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules is
intended for application developers and Oracle Application Server administrators
who perform the following tasks:
■ Develop rule enabled applications
■ Debug rule enabled applications
■ Deploy and Administer rule enabled applications.
■ Develop rulesets for those who prefer a technical language environment instead of
the Oracle Business Rules Rule Author graphical environment for rule authoring.
■ Need to use Oracle Business Rules RL Language advanced features that are not
available in the Oracle Business Rules Rule Author environment.
To use this document, you need to be familiar with the Java programming language.
Documentation Accessibility
Our goal is to make Oracle products, services, and supporting documentation
accessible to all users, including users that are disabled. To that end, our
documentation includes features that make information available to users of assistive
technology. This documentation is available in HTML format, and contains markup to
facilitate access by the disabled community. Accessibility standards will continue to
evolve over time, and Oracle is actively engaged with other market-leading
technology vendors to address technical obstacles so that our documentation can be
accessible to all of our customers. For more information, visit the Oracle Accessibility
Program Web site at http://www.oracle.com/accessibility/.
vii
otherwise empty line; however, some screen readers may not always read a line of text
that consists solely of a bracket or brace.
Related Documents
Printed documentation is available for sale in the Oracle Store at
http://oraclestore.oracle.com/
If you already have a username and password for OTN, then you can go directly to the
documentation section of the OTN Web site at
http://www.oracle.com/technology/documentation/index.html
Conventions
This section describes the conventions used in the text and code examples of this
documentation set. It describes:
■ Conventions in Text
■ RL Language Backus-Naur Form Grammar Rules
Conventions in Text
Convention Meaning
boldface Boldface type indicates graphical user interface elements associated
with an action, or terms defined in text or the glossary.
italic Italic type indicates book titles, emphasis, or placeholder variables for
which you supply particular values.
monospace Monospace type indicates commands within a paragraph, URLs, code
in examples, text that appears on the screen, or text that you enter.
viii
RL Language Backus-Naur Form Grammar Rules
Each RL Language command in the guide is shown in a format description that
consists of a variant of Backus-Naur Form (BNF) that includes the symbols and
conventions in the following table.
Symbol or
Convention Meaning
[] Brackets enclose optional items.
{} Braces enclose items only one of which is required.
| A vertical bar separates alternatives within brackets or braces.
* A star indicates that an element can be repeated.
delimiters Delimiters other than brackets, braces, vertical bars, stars, and ellipses
must be entered as shown.
boldface Words appearing in boldface are keywords. They must be typed as
shown.
(Keywords are case-sensitive in some, but not all, operating systems.)
Words that are not in boldface are placeholders for which you must
substitute a name or value
underline When on the left side of a production ( ::= ) indicates a definition for a
non-terminal symbol.
underline When found on the right side of a production, ::= , a link, which is a
non-terminal symbol, links to the definition for the non-terminal
symbol.
italic text Semantic information about non-terminals, such as the required data
type for an expression or a descriptive tag used in following discussion,
is in italics.
ix
x
1
1 Rules Programming Concepts
This chapter introduces Oracle Business Rules RL Language (RL Language) concepts.
This chapter includes the following sections:
■ Section 1.1, "Starting the Oracle Business Rules RL Language Command-Line"
■ Section 1.2, "Introducing Rules and Rulesets"
■ Section 1.3, "Introducing Facts and RL Language Classes"
■ Section 1.4, "Understanding and Controlling Rule Firing"
■ Section 1.5, "Using Effective Dates"
■ Section 1.6, "Integrating RL Language Programs with Java Programs"
■ Section 1.7, "Using Decision Tracing"
■ Section 1.8, "Building a Coin Counter Rules Program"
See Also:
■ Chapter 3, "Using the Command-line Interface" for more details
and for a list of command-line options
■ Chapter 4, "Using a RuleSession" for details on Oracle Business
Rules RuleSession API
1-2 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Introducing Facts and RL Language Classes
Example 1–3 shows the complete rule, written in RL Language (the rule includes a rule
condition and a rule action).
The Oracle Rules Engine activates a rule whenever there is a combination of facts that
makes the rule’s conditional expression true. In some respects, a rule condition is like a
query over the available facts in the Oracle Rules Engine, and for every row that
returns from the query, the rule activates.
1-4 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Introducing Facts and RL Language Classes
Example 1–6 shows the goldDiscount rule uses the RL fact GoldCustomer to infer
that if a customer spent $500 within the past 3 months, then the customer is eligible for
a 10% discount.
Example 1–7 shows the declaration for the GoldCustomer RL class (this assumes that
you also have the Customer class available in the classpath).
When you work with Java classes, using the import statement lets you omit the
package name (see Example 1–8).
See Also:
■ "Fact Class Declarations" on page 2-21
■ "Import Statement" on page 2-25
1-6 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Understanding and Controlling Rule Firing
Figure 1–1 RuleSession with Working Memory and the Agenda Containing Activations
The run, runUntilHalt, and step functions execute the activations on the agenda, that
is, these commands fire the rules (use the step command to fire a specified number of
activations).
Rules fire when the Oracle Rules Engine removes activations, by popping the
activations off the agenda and performing the rule's actions.
The Oracle Rules Engine may remove activations without firing a rule if the rule
conditions are no longer satisfied. For example, if the facts change or the rule is cleared
then activations may be removed without firing. Further, the Oracle Rules Engine
removes activations from the agenda when the facts referenced in a fact set row are
modified or the facts are retracted, such that they no longer match a rule condition
(and this can also happen in cases where new facts are asserted, when the ! operator
applies).
Note the following concerning rule activations:
1. Activations are created, and thus rules fire only when facts are asserted, modified,
or retracted (otherwise, the rules would fire continuously).
2. If a rule asserts a fact that is mentioned in the rule condition, and the rule
condition is still true, then a new activation is added back to the agenda and the
rule fires again (in this case the rule would fire continuously). This behavior is
often a bug.
3. The actions associated with a rule firing can change the set of activations on the
agenda, by modifying facts, asserting facts, or retracting facts, and this can change
the next rule to fire.
4. Rules fire sequentially, not in parallel.
You can use showFacts to show the current facts in working memory. Example 1–10
shows that the Oracle Rules Engine asserts the initial-fact, f-0 (the Oracle Rules
Engine uses this fact internally).
Use retract to remove facts from working memory, as shown in Example 1–11. When
watchFacts is enabled, the Oracle Rules Engine prints <== when a fact is retracted.
1-8 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Understanding and Controlling Rule Firing
Note: Activations may be removed from the agenda before they are
fired if their associated facts no longer make the condition true.
When activations are on the agenda, the Oracle Rules Engine fires rules when run,
runUntilHalt, or step executes. The Oracle Rules Engine sequentially selects a rule
activation from all of the activations on the agenda, using the following ordering
algorithm:
1. The Oracle Rules Engine selects all the rule activations for the focus ruleset, that is
the ruleset at the top of the ruleset stack (see the pushRuleset and setRulesetStack
built-in functions).
2. Within the set of activations associated with the focus ruleset, rule priority
specifies the firing order, with the higher priority rule activations selected to be
fired ahead of lower priority rule activations (the default priority level is 0).
3. Within the set of rule activations of the same priority, within the focus ruleset, the
most recently added rule activation is the next rule to fire. However, note that in
some cases multiple activations may be added to the agenda at the same time, the
ordering for such activations is not defined.
4. When all of the rule activations in the current focus fire, the Oracle Rules Engine
pops the ruleset stack, and the process returns to Step 1, with the current focus.
If a set of rules named R1 must all fire before any rule in a second set of rules named
R2, then you have two choices:
■ Use a single ruleset and set the priority of the rules in R1 higher than the priority
of rules in R2.
■ Use two rulesets R1 and R2, and push R2 and then R1 on the ruleset stack.
Generally, using two rulesets with the ruleset stack is more flexible than using a single
ruleset and setting the priority to control when rules fire. For example if some rule R in
R1 must trigger a rule in R2 before all rules in R1 fire, a return in R pops the ruleset
stack and allows rules in R2 to fire.
If execution must alternate between two sets of rules, for example, rules to produce
facts and rules to consume facts, it is easier to alternate flow with different rulesets
than by using different priorities.
Example 1–14 shows that the priority of the keepGaryOut rule is set to high, this is
higher than the priority of the sayHello rule (the default priority is 0). If the
activations of both rules are on the agenda, the higher priority rule fires first. Notice
that just before calling run, sayHello has two activations on the agenda. Because
keepGaryOut fires first, it retracts the enterRoom(who: "Gary") fact, which
removes the corresponding sayHello activation, resulting in only one sayHello
firing.
The rule shown in Example 1–14 illustrates two additional RL Language features.
1. The fact operator, also known as a fact set pattern, uses the optional var
keyword to define a variable, in this case the variable g, that is bound to the
matching facts.
2. You can remove facts in working memory using the retract function.
1-10 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Effective Dates
RL> run();
Fire 1 main.keepGaryOut f-4
<== f-4 main.enterRoom(who: "Gary")
<== Activation: main.sayHello : f-4
Fire 2 main.sayHello f-5
Hello Mary
RL>
Example 1–15 shows the sayHello rule that includes a condition that matches the
asserted enterRoom fact; this match adds an activation to the agenda. Example 1–15
demonstrates the following RL Language programming features.
1. The Oracle Rules Engine matches facts against the rule conditions
(fact-set-conditions) of all rules as the state of working memory changes. Thus, it
does not matter whether facts are asserted before the rule is defined, or after.
2. The run function processes any activations on the agenda. No activations on the
agenda are processed before calling run.
In Oracle Business Rules RL Language, the effective start and end dates and the active
property are only applied to rules (and do not apply for rulesets). The effective start
and end date properties of a rule can be specified in the rule.
For example,
rule myrule2 {
active = true;
effectiveDateForm = Rule.EDFORM_DATETIME:
effectiveStartDate = JavaDate.fromDateTimeString("2008-11-01");
effectiveEndDate = JavaDate.fromDateTimeString("2008-11-16");
if (fact Foo)
{
.
.
}
If you use the RuleSession Java API, you can access the effective start and end
date.
r.setActive(false);
See Also: "Working with Rules SDK Decision Point API" in the
Oracle Business Rules User's Guide
1-12 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Integrating RL Language Programs with Java Programs
Where BeanPath is the classpath component to any supplied Java Bean classes.
1-14 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Decision Tracing
The RL Language environment provides multiple rule sessions. Each rule session can
be used by multiple threads, but rules are fired by a single thread at a time.
Each rule RuleSession has its own copy of facts and rules. To create a fact from a Java
Object, use a call such as:
rs.callFunctionWithArgument("assert", Object;);
included in the Javadoc. For more information, see Oracle Business Rules Java API
Reference.
1-16 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Decision Tracing
The decision trace level may be set by invoking the setDecisionTraceLevel function.
You can also configure the initial trace level in a RuleSession or in a RuleSessionPool
by including the RuleSession.CFG_DECISION_TRACE_LEVEL initialization
parameter and specifying a level in the configuration Map passed to the RuleSession
or RuleSessionPool constructor. This sets the decision trace level at the time a
RuleSession is created.
You can invoke the setDecisionTraceLevel function on a RuleSession or a
RuleSessionPool object after initialization. When you invoke reset(), this function
returns the decision trace level to the configured value (if the level was changed
during rule execution). Thus, the reset() function resets the decision trace limit to
the value set during initialization of a RuleSession or a RuleSessionPool. In these cases,
reset() restores the values established using the initialization parameters.
Note: These reset() semantics for a RuleSession are only valid for
a RuleSession initialized with either or both of the CFG_DECISION_
TRACE_LIMIT and the CFG_DECISION_TRACE_LEVEL initialization
parameters (or that is obtained from a RuleSessionPool when the pool
is created with either or both of the CFG_DECISION_TRACE_LIMIT
and the CFG_DECISION_TRACE_LEVEL initialization parameters.
The size of a trace is limited by limiting the number of entries in a decision trace. This
necessary to avoid infinite rule fire loops, due to a possible bug in the rules, from
creating a trace that consumes all available heap in the JVM. Set the trace limit with
the setDecisionTraceLimit function. The limit may also be configured in a RuleSession
(or RuleSessionPool) by including the RuleSession.CFG_DECISION_TRACE_
LIMIT initialization parameter with the desired limit in the configuration Map passed
to the RuleSession or RuleSessionPool constructor.
For rules applications that use runUntilHalt, it is the responsibility of the application
to invoke getDecisionTrace before the trace limit is hit.
The decision trace provides structure to the trace data so that it can be manipulated
programmatically. However, the trace by itself can be cumbersome to analyze. A trace
analysis class (oracle.rules.rl.extensions.trace.TraceAnalysis)
analyzes a decision trace and facilitates exploration of the trace. Use this class to
construct the state of working memory, the agenda, and the ruleset stack from the
trace.
The TraceAnalysis API supports the following:
■ Obtain a list of fact types that appear in the trace.
■ Obtain a list of names of the rules that fired in the trace.
■ Obtain a list of the last fact traces for each instance of a specific fact type.
■ Obtain the last fact trace for a specific fact identified by its fact ID.
■ Obtain all of the fact traces for a fact identified by its fact ID.
■ For a fact trace, if the fact trace was created by a rule action, get the rule trace that
rule firing in which the action executed.
■ For a rule trace, get the list of fact traces for each fact that matched and resulted in
the rule firing.
■ Get the next or previous trace. Exploration of the trace is typically not an iteration
over the trace. For example, obtaining a rule trace from a fact trace is essentially
jumping to that rule trace. The traces near the rule trace can be explored directly.
■ Obtain a list of rule traces for a rule identified by its name.
■ Obtain the rule engine state for a trace entry. The rule engine state reflects the state
of the rule engine after the activity that generated the trace. This API enables
inspecting the rule engine state at the time of each trace. This API is most useful
with development level tracing. With production level tracing, only the facts in
working memory can be tracked and they will not include any fact contents.
Example 1–21 shows a code sample that uses the decision trace analysis API.
1.7.3 Decision Trace Samples for Production and Development Level Tracing
Example 1–22 shows a sample production level trace document.
1-18 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Decision Tracing
<timestamp>1248975549890</timestamp>
<rule-name>OrderDiscount.goldCustomer</rule-name>
<token-time>0</token-time>
<sequence-number>1</sequence-number>
</trace-entries>
<trace-entries xsi:type="rule-trace" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<timestamp>1248975549893</timestamp>
<rule-name>OrderDiscount.goldCustomerDiscount</rule-name>
<token-time>0</token-time>
<sequence-number>2</sequence-number>
</trace-entries>
<trace-entries xsi:type="rule-trace" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<timestamp>1248975549894</timestamp>
<rule-name>OrderDiscount.applyDiscount</rule-name>
<token-time>0</token-time>
<sequence-number>3</sequence-number>
</trace-entries>
</decision-trace>
<rule-name>OrderDiscount.goldCustomer</rule-name>
<token-time>2</token-time>
<fact-ids>1</fact-ids>
<operation>add</operation>
</trace-entries>
<trace-entries xsi:type="fact-trace" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<timestamp>1248975491025</timestamp>
<fact-id>2</fact-id>
<operation>assert</operation>
<fact-type>com.example.Order</fact-type>
<object-type>com.example.Order</object-type>
<fact-object>
<properties>
<name>customerName</name>
<value>
<string>OneLtd</string>
</value>
</properties>
<properties>
<name>discount</name>
<value>
<string>0.0</string>
</value>
</properties>
<properties>
<name>grossAmount</name>
<value>
<string>400.0</string>
</value>
</properties>
<properties>
<name>netAmount</name>
<value>
<string>0.0</string>
</value>
</properties>
<properties>
<name>number</name>
<value>
<string>1001</string>
</value>
</properties>
</fact-object>
</trace-entries>
<trace-entries xsi:type="activation-trace"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<timestamp>1248975491035</timestamp>
<rule-name>OrderDiscount.goldCustomerDiscount</rule-name>
<token-time>5</token-time>
<fact-ids>2</fact-ids>
<fact-ids>1</fact-ids>
<operation>add</operation>
</trace-entries>
<trace-entries xsi:type="rule-trace" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<timestamp>1248975491036</timestamp>
<rule-name>OrderDiscount.goldCustomerDiscount</rule-name>
<token-time>5</token-time>
<fact-ids>2</fact-ids>
<fact-ids>1</fact-ids>
<sequence-number>2</sequence-number>
1-20 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Building a Coin Counter Rules Program
</trace-entries>
...
<trace-entries xsi:type="rule-trace" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<timestamp>1248975491036</timestamp>
<rule-name>OrderDiscount.applyDiscount</rule-name>
<token-time>7</token-time>
<fact-ids>2</fact-ids>
<sequence-number>3</sequence-number>
</trace-entries>
...
<trace-entries xsi:type="ruleset-stack-trace"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<timestamp>1248975491037</timestamp>
<operation>pop</operation>
<ruleset-name>OrderDiscount</ruleset-name>
</trace-entries>
</decision-trace>
Example 1–24 shows the debugging functions that show the count coins sample facts,
activations, and rules for the coin counter. All facts are asserted, and activations for all
solutions are placed on the agenda. Notice that the facts are matched to the rule
condition as they are generated by populate_facts, and that find_solution
prints the matches.
In Example 1–25, the keyword final in front of a global variable definition such as
coinCount and totalAmount marks that variable as a constant, as in Java. You can
reference constants in rule conditions, but you cannot reference variables in rule
conditions.
In RL Language, you must initialize all variables. The initialization expression for a
final variable is evaluated once when the variable is defined. The initialization
expression for a non-final variable is evaluated when the variable is defined, and again
each time the reset function is called. Because the reset function retracts all facts
from working memory, it is good practice to assert initial facts in a global variable
initialization expression, so that the facts are re-asserted when reset is called.
Example 1–25 illustrates how to use global variable initialization expressions. The
initialized global variable is initialized with the populate_facts function. This
function is re-executed whenever reset is called. The populate_facts function has
a while loop nested within a for loop. The for loop iterates over an array of coin
denomination Strings. For each denomination, the while loop asserts a fact that
expresses a count and a total that does not exceed the total amount of $1.50. For
example, for half dollars:
coin(denomination "half-dollar", count:0, amount:0)
coin(denomination "half-dollar", count:1, amount:50)
coin(denomination "half-dollar", count:2, amount:100)
coin(denomination "half-dollar", count:3, amount:150)
With such facts in working memory, the rule find_solution matches against each
denomination with a condition that requires that the counts sum to coinCount and
the amounts sum to totalAmt. The run function fires the find_solutions
activations.
1-22 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Building a Coin Counter Rules Program
}
return true;
}
boolean initialized = populate_facts();
rule find_solution
{
if(fact coin(denomination: "penny") p
&& fact coin(denomination: "nickel") n
&& fact coin(denomination: "dime") d
&& fact coin(denomination: "quarter") q
&& fact coin(denomination: "half-dollar") h
&& p.count + n.count + d.count + q.count + h.count == coinCount
&& p.amount + n.amount + d.amount + q.amount + h.amount == totalAmt)
{
println("Solution:"
+ " pennies=" + p.count
+ " nickels=" + n.count
+ " dimes=" + d.count
+ " quarters=" + q.count
+ " half-dollars=" + h.count
);
}
}
run();
1-24 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
2
2 Rule Language Reference
This chapter contains a detailed and complete reference to the Oracle Business Rules
RL Language (RL Language) syntax, semantics, and built-in functions.
Grammar rules define the RL Language. Each grammar rule defines a non-terminal
symbol on the left of the ::= symbol in terms of one or more non-terminal and
terminal symbols on the right of the ::= symbol.
Reserved Words
aggregate, boolean, break, byte, catch, char, class, constant, continue, double, else,
exists, extends, fact, factpath, false, final, finally, float, for, function, hide, if, import,
include, instanceof, int, long, modify, new, null, property, public, query, return,
returns, rule, rulegroup, ruleset, short, supports, synchronized, throw, true, try,
while, var
Ruleset
Format
ruleset ::= named-ruleset | unnamed-ruleset
named-ruleset ::= ruleset ruleset-name { unnamed-ruleset }
unnamed-ruleset ::= ( import | include | named-ruleset | definition | action | fact-class | rulegroup)*
ruleset-name ::= identifier
Usage Notes
A named-ruleset creates or adds definitions to the specified ruleset named
ruleset-name.
An unnamed-ruleset adds definitions to the default ruleset named main.
Rulesets may be nested, that is they may contain or include other rulesets. Nesting
does not affect ruleset naming, but it does affect ruleset visibility in a way similar to
Java import's affect on package visibility.
You can execute a ruleset using the RL Language command-line, or using the Java
RuleSession API.
A named-ruleset ruleset-name must be unique within a RuleSession.
Examples
Example 2–1 contains two definitions, enterRoom and sayHello, and two actions
(assert and run).
The rule shown in Example 2–1 will not fire until:
1. An enterRoom fact is asserted.
2. The run function executes, which pushes the rule's containing ruleset, hello onto
the ruleset stack.
In Example 2–2, if ruleset R2 is nested in ruleset R1, the name R2 must be unique
within the rule session. R2 is not named relative to R1. For example, the class C2
defined in R2 is globally named R2.C2, not R1.R2.C2. If R2 is nested in R1, a public
2-2 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Ruleset
class C1 defined in R1 may be referenced in R2 using either the full name R1.C1 or the
short name C1 (assuming R2 does not also define C1).
Types
RL Language is a strongly typed language. Each variable and value has a specified
type.
Format
type ::= simple-type [ [ ] ]
simple-type ::= primitive | object-type
primitive ::= boolean | numeric
numeric ::= int | double | float | long | short | byte | char
object-type ::= class-definition-name | Java-class-name
class-definition-name ::= qname
Java-class-name ::= qname
Type Conversion
There are several ways that a value can be converted from one type to another:
1. Conversion from any type to String using the String concatenation operator + .
2. Implicitly from context. For example, by adding an int to a double first converts
the int to a double and then adds the 2 doubles.
3. Casting between 2 numeric types.
4. Casting between 2 classes related by inheritance.
5. Invoking a function or method that performs the conversion. For example,
toString.
Table 2–1 summarizes the implicit conversions for various types. Rows indicate how
the type in the From column may be implicitly converted, as shown in the list of types
shown in the To column.
2-4 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Types
Table 2–2 summarizes the allowed cast conversions for various types where a cast can
be used to convert a primitive with more bits to a primitive with fewer bits, without
throwing an exception.
The type conversions shown in Table 2–2 require an explicit cast operator. For
example,
int i = 1;
short s = (short)i;
When you use a cast to convert a primitive with more bits, to a primitive with fewer
bits, the RL Language discards extra, high order, bits without throwing an exception.
For example,
short s = -134;
byte b = (byte)s;
println("s = " + s + ", b = " + b);
prints: s = -134, b = 122
Primitive Types
A primitive type may be any of the following
■ An int, which is a 32 bit integer. Literal values are scanned by
java.lang.Integer.parseInt
■ A long. Literal values are scanned by java.lang.Long.parseLong
■ A short. Literal values are scanned by java.lang.Short.parseShort
■ A byte. Literal values are scanned by java.lang.Byte.parseByte
■ A char.
■ A double. Literal values are scanned by java.lang.Double.parseDouble
Object Types
An object type may be:
■ A java Object, identified by the qualified name, qname, of its class. For example,
java.lang.String.
■ An RL Language Object, identified by the qualified name, qname of its class. For
example, ruleset1.Class1.
String Types
RL Language uses Java strings, where:
■ Strings are instances of the class java.lang.String.
■ A string literal is delimited by double quotes ("string").
Use \" to include the double quote character in a string.
■ Strings may be concatenated using the + operator as follows:
– If any operand of a + operator is a String then the remaining operands are
converted to String and the operands are concatenated.
– An Object is converted to a String using its toString method.
– An instance of an RL Language class is converted to a String using a built-in
conversion.
Array Types
Square brackets [] denote arrays. An array in RL Language has the same syntax and
semantics as a Java 1-dimensional array.
2-6 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Identifiers
Identifiers
RL Language supports both the Java and the XML variant of identifiers and
namespace packages. To use the XML variant, the identifier must be enclosed in back
quotes.
Format
identifier ::= java-identifier | xml-identifier
java-identifier ::= valid-Java-identifier
xml-identifier ::= `valid-xml-identifier or URI `
Where:
valid-Java-identifier is: a legal Java identifier, for example, JLd_0.
valid-xml-identifier is: a legal XML identifier, for example x-1.
URI is: a legal Uniform Resource Identifier, for example, http://www.oracle.com/rules
Usage Notes
An xml-identifier can contain characters that are illegal Java identifier characters, for
example, ':' and '-'. The JAXB specification defines a standard mapping of XML
identifiers to Java identifiers, and includes preserving the Java conventions of
capitalization. The JAXB specification also defines a standard mapping from the
schema target namespace URI to a Java package name, and a mapping from
anonymous types to Java static nested classes.
Examples
RL Language supports both the Java and the XML variant of identifiers and
namespaces or packages. Enclose an identifier in back quotes to use the XML variant,
as shown in Example 2–3.
You can use the back quote notation anywhere an identifier or package name is legal
in RL Language. To use the XML variant of identifiers in String arguments to
assertXPath, back quotes are not needed.
Example 2–3 Sample Mapping for XML Identifiers Using Back Quotes
`http://www.mycompany.com/po.xsd` -> com.mycompany.po
`my-attribute` -> myAttribute
`Items/item` -> Items$ItemType
Literals
Table 2–3 summarizes the RL Language literals. The literals are the same as Java
literals.
2-8 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Definitions
Definitions
When a definition within a ruleset is executed, it is checked for correctness and then
saved for use later in the rule session.
Format
definition ::= variable | rule | rl-class-definition | function
name ::= identifier
qname ::= [ ruleset-or-packagename. ]name
ruleset-or-packagename ::= qname
Usage Notes
Every definition has a unique name within its containing ruleset, and thus a unique
qualified name, qname, within the rule session.
Variables defined at the ruleset level are global. Global variables are visible to all
expressions contained in the ruleset using the name of the variable and visible to
expressions in other rulesets using the variable qname. Functions and public classes
may also be referenced from other rulesets using the respective qname.
Java classes and their methods and properties also have qnames.
Example
The qname of the class definition in Example 2–4 is hello.enterRoom.
Variable Definitions
Format
variable ::= [ final ] ( numeric name = numeric-expression
| boolean name = boolean-expression
| type [ ] name = array-expression | null
| object-type name = object-expression | null )
);
Usage Notes
The type of the array initialized with the array-expression must be the same as the
type specified for the array elements.
A variable can have a primitive type, a Java class name, or an RL Language class
name, and may be an array of elements of the same type.
The type of the object-expression must be the same as the object-type of the variable
being declared. A class instance or array may be initialized to null.
Variables may be local or global in scope. The initialization expression is required.
Local variables may not be final.
Global Variables
Variables immediately enclosed in a ruleset, that is, in a definition, are global to a rule
session in scope. The initialization expression for a final global variable is executed
when the global variable is defined.
The initialization expression for a non-final global variable is executed both:
■ When the global variable is defined.
■ Each time the reset function is called.
Global variables declared as final may not be modified after they are initialized.
Global variables referenced in a rule condition (fact-set-condition) must be final.
Examples
Example 2–5 shows that the reset function performs initialization for the non-final
global variable i. Thus, this example prints 0, not 1.
Be careful when initializing global variables with functions that have side effects. If
you do not want the side effects repeated when calling reset, you should declare the
2-10 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Definitions
variable final. For example, Example 2–6 prints "once" twice and Example 2–7 prints
"once" once.
Example 2–6 Initializing a Global Variable with Side Effects with Reset
RL> clear;
RL> function once() returns int
{
println("once");
return 1;
}
RL> int i = once();
once
RL> reset();
once
RL>
Example 2–7 Initializing a Final Global Variable to Avoid Side Effects with Reset
RL> clear;
RL> function once() returns int
{
println("once");
return 1;
}
RL> final int i = once();
once
RL> reset();
RL>
Rule Definitions
The Oracle Rules Engine matches facts against the fact-set-conditions of all rules in the
rule session to build the agenda of rules to execute. A fact set row is a combination of
facts that makes the conditions of a rule true. An activation is a fact set row paired
with a reference to the action-block of the rule. The agenda is the list of all activations
in the rules session. The Oracle Rules Engine matches facts and rules when the state of
working memory changes, typically when a fact is asserted or retracted.
The run, runUntilHalt, and step functions execute activations. Activations are
removed from the agenda after they are executed, or if the facts referenced in their fact
set row are modified or retracted such that they no longer match the rule's condition.
Activations are executed in order of the ruleset stack. You can manage the ruleset stack
with the getRulesetStack, clearRulesetStack, pushRuleset, and popRuleset functions.
In order for a rule to fire, three things must occur:
1. An activation of that rule must be on the agenda.
2. The containing ruleset must be at the top of the ruleset stack.
3. You must invoke run, runUntilHalt, or step.
The fact set produced in a fact-set-condition is available to the rule actions. For each
row in the fact set, the action-block is activated as follows:
■ The rule’s action-block is scheduled for execution at the specified rule priority.
■ References from the action-block to the matched facts are bound to the current
row.
■ If a matched fact is retracted before the action-block is executed, the dependent
activations are destroyed (removed from the agenda).
Format
rule ::= rule rule-name { property* fact-set-condition action-block }
rule-name ::= name
property ::= priority | autofocus | logical | active
priority ::= priority = numeric-expression
autofocus ::= autofocus = boolean-literal
logical ::= logical = ( boolean-literal | positive-integer-literal )
active ::= active = boolean-literal
effectiveDateForm ::= effectiveDateForm = an int restricted to one of values defined in
oracle.rules.rl.Rule: EDFORM_DATE, EDFORM_DATETIME, or EDFORM_TIME
effectiveStartDate ::= effectiveStartDate = expression of type java.util.Calendar
effectiveEndDate ::= effectiveEndDate = expression of type java.util.Calendar
Where:
positive-integer-literal is: an integer literal that is > 0
2-12 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Definitions
Usage Notes
The priority property specifies the priority for a rule. Within a set of activations of
rules from the same ruleset, activations are executed in priority order (see "Ordering
Rule Firing" on page 1-9). When rules have different priorities, the rules with a higher
priority are activated before those with a lower priority. The default priority is 0.
Within a set of activations of rules of the same priority, the most recently added
activations are executed first, but this behavior can be changed (see the getStrategy
and setStrategy functions).
A rule with the autofocus property equal to true automatically pushes its containing
ruleset onto the ruleset stack whenever it is activated.
A rule with the logical property makes all facts asserted by the rule's action block
dependent on some or all facts matched by the rule's condition. An integer value of n
for the logical property makes the dependency on the first n top-level &&ed fact set
expressions in the rule's condition. A boolean value of true for the logical property
makes the dependency on the fact set expression of the condition. Anytime a fact
referenced in a row of the fact set changes such that the rule's logical conditions no
longer apply, the facts asserted by the activation associated with that fact set row are
automatically retracted. A rule with the logical property enabled makes all facts that
are asserted by an action block in the rule dependent on facts matched in the rule
condition. Anytime a fact referenced in the rule condition changes, such that the rule's
conditions no longer apply, the facts asserted by the rule condition are automatically
retracted.
The active property defaults to true.
effectiveStartDate date defaults to null.
effectiveEndDate date default to null.
effectiveDateForm defaults to Rule.EDFORM_DATETIME
Examples
Example 2–8 shows a rule with the inference, Socrates is mortal, which depends on the
fact, Socrates is a man.
RL> retract(socrates);
<== f-1 main.Man (name : "Socrates")
<== f-2 main.Mortal (name : "Socrates")
RL> showFacts();
f-0 initial-fact()
Example 2–9 shows that it is possible for the same fact to be asserted by multiple rules,
or to be asserted by a top-level ruleset action or function. Such a fact will not be
automatically retracted unless all asserters have logical clauses that call for automatic
retraction. A fact that is asserted by a top level action or function will never be
automatically retracted.
Note that the fact that Socrates is mortal is not retracted, because it was asserted by a
top level action that is not dependent on the fact that Socrates is a man.
2-14 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Definitions
Class Definitions
All referenced classes must be defined with an RL Language class definition or must
be on the Java classpath (Java classes must be imported).
Both RL Language classes and Java classes can support xpath using the supports
keyword, with a supplied xpath.
Format
rl-class-definition ::= [ public ] [ final ] class name [ extends ] [ supports ] { type-property* }
type-property ::= [ public ] type name [ = expression ] ;
extends ::= extends qname extended-class-name
extended-class-name ::= qname
Usage Notes
The type of the optional initialization expression must be the same as the type of the
property or implicitly convertible to that type.
A public class is visible from all rulesets. A non-public class is visible only in the
containing ruleset.
A final class cannot be extended.
The extended class must be a defined RL Language class not an imported Java class.
Each property may have an optional initializer. The initializer is evaluated when the
class is instantiated by new. If an initial value is also passed to new, the value passed to
new overwrites the value computed by the initializer in the class definition.
A public property is visible from all rulesets. A non-public property is visible only
within its containing ruleset.
Examples
In RL Language, the type of an property may be the name of the containing class
definition (see Example 2–10). RL Language, unlike Java, does not support forward
references to class definitions (see Example 2–11).
Example 2–10 Class Definition with Type of Property with Name of Containing Class
class C0 {
C0 next;
}
Example 2–11 Class Definitions with Forward References are Not Allowed
class C1 {
C2 c2; // causes an UndefinedException
}
class C2 {
C1 c1;
}
xpath Support
Note: xpath support has been deprecated. For more information, see
assertTree.
Format
supports ::= supports xpath
xpath ::= first-step next-step*
first-step ::= ( . | /* | [ // ] ( identifier | * ) ) predicate*
predicate ::= [ identifier xrelop literal ]
next-step ::= ( / | // ) ( identifier | * ) predicate*
xrelop ::= eq | lt | gt | le | ge | ne | == | < | > | <= | >= | !=
literal ::= integer-literal | decimal-literal | double-literal | string-literal | true | false | dateTime-literal
| date-literal | time-literal
integer-literal ::= [-] d+
d ::= 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9
decimal-literal ::= [-] ( . d+ | d+ . d*)
double-literal ::= [-] ( . d+ | d+ [ . d* ] ) ( e | E ) [+ | -] d+
string-literal ::= " char* " | ' char* '
dateTime-literal ::= local-date T time-literal
date-literal ::= local-date [ time-zone ]
time-zone ::= Z | ( + | - ) d d : d d
local-date ::= d d d d - d d - d d
time-literal ::= d d : d d : d d [. d+] [ time-zone ]
Usage Notes
RL Language xpath support was designed to work with classes that conform to the
Java XML Binding (JAXB) 1.0 standard. All JAXB elements from the given root to the
elements selected by the xpath, inclusive, are asserted. Additional XLink facts are
asserted to aid in writing rules about the parent-child relationships among the asserted
elements.
If a JAXB element is retracted or re-asserted, using assert, then all of its children, and
XLinks, are retracted. Instead of re-asserting, use assertXPath again.
Note that RL Language Xpath is not a proper subset of W3C Xpath 2.0. Note the
following differences:
2-16 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Definitions
■ The lt and <, gt and >, are synonymous in RL Language but different in W3C.
■ Date literals must use xs:date() and other constructors in W3C.
■ Constructors are not supported in RL Language, and literals, other than string
literals, must not be quoted in RL Language.
Examples
Table 2–4 shows the xpath selection options for use with the built-in assertXPath
function. In the descriptions, select means that the element is asserted as a fact, and the
selected property of the XLink whose element property refers to the asserted element
is true. The ancestors of a selected element, up to and including the root element, are
always asserted, but not necessarily selected.
Example 2–12 instantiates an RL Language class called Person to build a family tree, as
follows:
First Generation Second Generation Third Generation
Ida
Mary
Fred
John
Rachel
Sally
Evan
Example 2–12 uses the assertXPath function twice, with two xpaths:
//kids[male==true]
//kids[male==false]
Example 2–14 shows that when you retract an element that was asserted with
assertXPath, all its descendents are retracted as well.
The result is:
f-0 initial-fact()
2-18 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Definitions
Example 2–15 prints all pairs of ancestors. First, the family tree is asserted.
Example 2–16 shows the output of a run of the code from Example 2–15.
Function Definitions
Format
function ::= function name parameters [ returns type ] action-block
parameters ::= ( [ type identifier ( , type identifier )* ] )
Usage Notes
The action-block may invoke the function being defined. However, the action-block
may not contain a forward reference to a function that has not already been defined
(see Example 2–17 and Example 2–18).
Functions may be overloaded. For example, the built-in println function is overloaded.
Examples
2-20 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Fact Class Declarations
Format
fact-class ::= fact class class-name [ supports ] ( fact-class-body | ; )
class-name ::= qname
fact-class-body ::= { [ hidden-properties | properties ]}
hidden-properties ::= hide property * ; | ( hide property ( ( name , )* name | * ) ; )+
properties ::= property * ; | ( property ( ( name , )* name | * ) ; )+
Usage Notes
The fact-class-body is optional in a fact-class declaration. The default fact-class-body
is:
{ property *; }
Either the property or hide property keywords can be used in a body, but not
both.
If hide property is used with a list of property names, then those property names
are hidden and not available for use in RL Language.
If hide property is used with the wildcard "*", then no properties other than those
exposed by a superclass or superinterface are available for use in RL Language.
If property is used with a list of property names, then those properties are exposed
and available for use in RL Language. If property is used with the wildcard *, then all
properties other than those hidden by a superclass or superinterface are available for
use in RL Language.
A HiddenPropertyException will be thrown if a superclass exposes a property
that its subclass hides or if a subclass exposes a property that its superclass hides.
Examples
Suppose a Java class Vehicle has subclasses Car and Truck. The rule shown in
Example 2–19, matchVehicle, generates a TypeCheckException wrapping a
FactClassException because the subclasses are referenced before the superclass.
Wrapping is used instead of subclassing for both FactClassException and
MultipleInheritanceException because in some fact contexts, these exceptions
are not thrown until runtime and then are wrapped by a RLRuntimeException.
Example 2–19 matchVehicle Rule with Subclasses Referenced Before the Superclass
assert(new Car()); // fact context for Car
assert(new Truck()); // fact context for Truck
rule matchVehicle {
if (fact Vehicle v) { // fact context for Vehicle - too late!
if (v instanceof Car) {
println("car");
} else {
println("truck");
}
}
} // generates a TypeCheckException wrapping a FactClassException
In Example 2–20, the matchVehicle rule is the first reference to the superclass, so no
exception is thrown.
In Example 2–21, a fact class declaration is the first reference to the superclass, so no
exception is thrown.
Example 2–21 matchVehicle Rule with Fact Class Declaration with Reference to
Superclass First
clear;
fact class Vehicle;
assert(new Car());
assert(new Truck());
rule matchVehicle {
if (fact Vehicle v) {
if (v instanceof Car) {
println("car");
} else {
println("truck");
}
}
2-22 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Fact Class Declarations
}
run(); // prints "truck" then "car"
Facts do not support multiple inheritance. Consider the Java classes and interfaces
shown in Example 2–22.
Example 2–24 illustrates an exception that occurs at runtime when the Oracle Rules
Engine attempts to assert the rx8 object and discovers its true type is SportsCar, not
Object. To avoid the MultipleInheritanceException, you must choose
whether to use Sporty or Car in a fact class context. You cannot use both.
</sequence>
</complexType>
</schema>
JAXB generates:
interface T {
List getB(); // List has TImpl objects
}
interface A extends T;
class AImpl implements A extends TImpl;
class TImpl implements T;
2-24 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Import Statement
Import Statement
An import statement makes it possible to omit the package name qualification when
referencing Java classes.
Format
import ::= import ( Java-class-name | Java-package-name.* ) ;
Java-package-name ::= qname
Usage Notes
Import commands can be placed inside a ruleset, implying that the scope of the import
is the ruleset where the import is located, but the import actually applies globally. For
example, in the following code if the imports were scoped to the rulesets, then the
PrintWriter reference in r2 would not compile.
class X { }
ruleset rl {
import java.io.*;
rule A {
if ( fact X ) {
@ PrintWriter pw = null;
}
}
}
ruleset r2 {
rule B {
if ( fact X ) {
@ PrintWriter pw = null;
}
}
}
Include Statement
Format
include ::= include URL ;
Where:
URL is: A legal Uniform Resource Locator.
Usage Notes
The file: and http: schemes are supported.
Example
include file:example.rl;
2-26 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
Using Expressions
Expressions in RL Language use familiar Java syntax (with minor variations as noted).
For example,
(a + 1) * (b - 2)
Format
expression ::= boolean-expression
| numeric-expression
| string-expression
| array-expression
| fact-set-expression
| object-expression
| comparable-expression
Boolean Expressions
Format
boolean-expression ::= boolean-assignment
| boolean-expression ? boolean-expression : boolean-expression
| boolean-expression || boolean-expression
| boolean-expression && boolean-expression
| numeric-expression equal-op numeric-expression
| object-expression equal-op object-expression
| boolean-expression equal-op boolean-expression
| object-expression instanceof type-name
| numeric-expression relop numeric-expression
| string-expression relop string-expression
| ! boolean-expression
| boolean-primary-expression
equal-op ::= == | !=
relop ::= < | > | <= | >=
type-name ::= qname
Usage Notes
For strings, < is Unicode UCS2 code point order.
For objects,!= does not test for inequality of object references, but rather is the
negation of the equals methods.
Thus, the statement:
if (object1 != object2){}
RL Language, unlike Java, does not support testing for equality of object references.
Example
Example 2–26 shows use of a boolean expression in RL Language.
2-28 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
Numeric Expressions
Format
numeric-expression ::= numeric-assignment
| boolean-expression ? numeric-expression : numeric-expression
| numeric-expression( + | - ) numeric-expression
| numeric-expression ( * | / | % ) numeric-expression
| numeric-expression ** numeric-expression
| ( numeric-cast ) numeric-expression
| ( + | - ) numeric-expression
| ( ++ | -- ) numeric-primary-expression
| numeric-primary-expression [ ++ | -- ]
Usage Notes
Table 2–5 shows the precedence order, from highest to lowest, for a
numeric-expression.
2-30 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
String Expressions
Format
string-expression ::= string-assignment
| boolean-expression ? string-expression : string-expression
| string-expression + expression
| expression + string-expression
| string-primary-expression
|
string-assignment ::= string-target-expression ( = | += ) string-expression
Example
Example 2–27 shows use of a string expression in RL Language. The example prints "1
2.0 true {1,2}"
Array Expressions
RL Language arrays behave just like Java arrays, but are limited to one dimension. The
base type of an array is the type of the members of the array. All members must be of
the same type. An array element may contain an array but only if the containing array
is of type Object[].
Format
array-expression ::= array-assignment
| boolean-expression ? array-expression : array-expression
| ( array-cast ) ( array-expression | object-expression )
| array-primary-expression
array-assignment ::= array-target-expression = array-expression
array-cast ::= type
Usage Notes
The type of an array-cast must be an array type.
2-32 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
Format
fact-set-condition ::= if fact-set-expression
fact-set-expression ::= fact-set-expression || fact-set-expression
| fact-set-expression && fact-set-expression
| fact-set-expression && boolean-expression
| ! fact-set-expression
| exists fact-set-expression
| fact-set-pattern
| (fact-set-expression)
| aggregate
aggregate-function ::=
average ( numeric-expression )
| sum ( numeric-expression )
| minimum ( comparable-expression )
| maximum ( comparable-expression )
| count ()
| collection ( object-expression )
| user-defined ( expression type Tin )
user-defined ::= qname
Usage Notes
A fact-set-expression can limit the facts it returns using either a simple-expression as a
constraint in a fact-set-pattern or using a supported operator with the
fact-set-expression.
A fact-set-expression may not contain any of the following:
■ assert
■ modify
■ new
■ References to non-final global variables.
Operator precedence is as in Java. Use parentheses to force desired precedence. For
example,
fact person var p && (p.age < 21 || p.age > 65)
Without the parentheses, the p in p.age is undefined (see Table 2–5 for more details
on operator precedence).
A local-object-variable or local-property-variable is in scope for all expressions
following the pattern that are following the pattern and connected with the &&
operator. If the pattern is not contained in an exists, ||, or ! expression, the variable
is also in scope in the rule's action-block. The &&'ed expressions may filter the returned
facts, so that only the facts surviving the filter are returned.
Join Operator
The && operator defines the cross product or join of two fact-set-expression operands.
The left-hand-side of a fact-set-expression && operator must be a fact set. The
right-hand-side of a join operator is another fact-set-expression. The result of applying
the && operator to two fact sets is the joined fact set.
Filter Operator
The && operator defines a filter operator that rejects facts in its left-hand-side
fact-set-expression that do not match the right-hand-side boolean-expression. The
2-34 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
Union Operator
The || operator defines the union of two fact-set-expression operands. When the||
operator is applied to fact-set-expressions, the following is true:
■ The expression’s vars cannot be referenced outside the containing expression.
■ The|| returns the concatenation of its input fact sets, but the contents of the
produced fact set are not accessible. Thus, || is typically used in a ! or exists
expression. Rather than a top-level || in a condition, it is usually better to use two
or more rules with top-level && operators so that vars defined in the condition can
be referenced in the action-block.
Empty Operator
The ! operator tests if the fact-set-expression is empty. When the ! is applied to the
fact-set-expression, the following is true:
■ The expression’s vars cannot be referenced outside the containing ! expression.
■ The ! operator returns a single row if the fact-set-expression is empty, else the !
operator returns an empty fact set.
Var Keyword
Note that when you use var, the fact is only visible using the var defined variable
(and not using the original name). Thus, the following example works, assuming
action.kind is defined:
if (fact action) {
println(action.kind);
}
However, for the following example, after var a is defined, the action.kind
reference produces a syntax error because you need to use a.kind after the var a
definition.
if (fact action var a) {
println(action.kind);
}
Aggregate
Aggregates support the following functions:
RL Language supports the aggregate pattern that applies one or more aggregate
functions to a factRowCollection, and binds the aggregates to pattern variables.
The usual SQL set of built-in aggregates is supported, and user-defined aggregates are
supported when a user-supplied Java class is supplied.
If an aggregate function uses primitive wrapper types, for example Long, Double, then
these will be unboxed such that the bind variable for the result has the appropriate
raw primitive type.
If the fact expression in an aggregate is empty, then the rule will not fire. This ensures
that if there are no matching facts for the expression, the aggregate function does not
return a number that is meaningless in this context. For example, the "sum" of a
property of a zero-size set is not meaningful.
For example, print the names of employees who are paid better than average:
if fact Emp emp && aggregate fact Emp(salary: var sal) : average(sal) var avgSal
&& emp.salary > avgSal {
println(emp.name);
}
Print the names of employees, who are paid better than the average of employees who
make over $100,000:
if fact Emp emp && aggregate fact Emp(salary: var sal) && Emp.salary > 100000
average(sal) var avgSal
&& emp.salary > avgSal {
println(emp.name);
}
2-36 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
isValid should return true when the result of the user defined aggregate is valid
and false otherwise.
Examples
Example 2–28 shows the action is placed on the agenda for all Counter facts with a
value of 1.
Example 2–29 shows an equivalent way to express the rule from Example 2–28, using a
constraint.
Example 2–30 shows an illegal use of a fact set, because c is used before it is defined.
Example 2–31 shows an action is placed on the agenda for all AttFacts with the
property a2==0 and without a matching, equal first elements, Counter.
Example 2–31 Using a Fact Set with && Operator for Counter Fact
class AttFact {int a1; int a2;}
rule ex3 {
if (fact AttFact(a2: 0) && ! fact Counter(id: AttFact.a1))
{ println(AttFact.a1); }
}
assert(new AttFact()); // will match because a1=a2=0
assert(new AttFact(a1: 1, a2: 0)); // will not match
run(); // rule fires once
Example 2–32 shows the condition, if (fact Ca a && fact Cb(v: a.v) b) is
interpreted as follows:
■ The fact Ca a returns a fact set containing a(v: 1), a(v: 2), a(v: 3)
■ The && operator returns a fact set containing the two rows {a(v: 1),b(v:
1)}, {a(v: 2),b(v: 2)}
2-38 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
Comparable Expression
Format
comparable-expression ::=
qname variable of type implementing java.lang.Comparable
| member of type implementing java.lang.Comparable
Object Expressions
The only expression operators for objects are assignment and cast.
Format
object-expression ::= object-assignment | ( ob-cast ) object-expression |
boolean-expression ? object-expression : object-expression
object-assignment ::= object-target-expression = object-primary-expression
ob-cast ::= object-type
2-40 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
Primary Expressions
Format
primary-expression ::= array-primary-expression
| string-primary-expression
| numeric-primary-expression
| boolean-primary-expression
| object-primary-expression
array-primary-expression ::=
array-constructor
| function-call returning array
| method-call* returning 1-dim Java array
| ( array-expression )
| array-target-expression
array-target-expression ::=
qname variable of type array
| member of type array
| array-primary-expression base type is Object [ numeric-expression int ]
string-primary-expression ::=
string literal (see "Literals" on page 2-8)
| object-primary-expression object is java.lang.String
numeric-primary-expression ::=
numeric literal
| function-call returning numeric
| method-call returning numeric
| array-primary-expression . length
| ( numeric-expression )
| numeric-target-expression
numeric-target-expression ::=
qname variable of type numeric
| member of type numeric
| array-primary-expression base type is numeric [ numeric-expression ]
boolean-primary-expression ::=
boolean-literal
| function-call returning boolean
| method-call returning boolean
| ( boolean-expression )
| boolean-target-expression
boolean-target-expression ::=
qname variable of type boolean
| member of type boolean
| array-primary-expression base type is boolean [ numeric-expression int ]
object-primary-expression ::=
new class-definition-name ( [ expression ( , expression )* ] argument list )
| new class-definition-name ( [ property-pattern ( , property-pattern )* ] property-value pairs )
| function-call returning Java object
| method-call returning Java object
| object-target-expression
object-target-expression ::=
qname variable of type object
2-42 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using Expressions
Examples
Example 2–33 shows the RL Language literal syntax (which is the same as Java).
Methods and functions can be overloaded. However, unlike Java, RL Language uses a
first fit algorithm to match an actual argument list to the overloaded functions.
Example 2–34 shows an example of example of overloading
new
RL Language classes do not have user-defined constructors. The default constructor
initializes properties to their default values. The RL Language new operator permits
specifying some property values (this works for Java bean properties, too).
A Java bean property may have a getter but no setter. Such a property may not be
modified.
Example
2-44 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Actions and Action Blocks
RL Language, unlike Java, requires action blocks and does not allow a single
semicolon terminated action.
Format
action ::= action-block | if | while | for | try | synchronized | return | throw
| assign | incr-decr-expression | primary-action
action-block ::= { ( variable | action )* }
Usage Notes
An action block is any number of local variable declarations and actions. The variables
are visible to subsequent variable initialization expressions and actions within the
same action block.
In RL Language, unlike in Java, all local variables must be initialized when they are
declared. Local variables may not be final.
To exit, you can invoke the System.exit(int) method from within an action.
Example
Using the if else action, if the test is true, execute the first action block, and if the test
is false, execute the optional else part, which may be another if action or an action
block.
RL Language, unlike Java, requires action blocks and does not allow a single
semicolon terminated action.
Format
if ::= if if-test action-block [ else if | action-block ]
if-test ::= boolean-expression
Examples
Example 2–37 shows an RL Language if else action block. Example 2–38 shows that an
action block is required.
2-46 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Actions and Action Blocks
While the test is true, execute the action block. A return, throw, or halt may exit the
action block.
Format
while ::= while while-test action-block
while-test ::= boolean-expression
Usage Notes
RL Language, unlike Java, requires action blocks and does not allow single semicolon
terminated action.
Examples
Example 2–39 prints "bye" twice.
RL Language, like Java, has a for loop. Using the for action block, the for-init portion
executes, then while the boolean-expression is true, first the specified action block is
executed then the for-update executes. A return, throw, or halt may exit the action
block.
Format
for ::= for ( for-init ; boolean-expression ; for-update ) action-block
for-init ::= variable | for-update
for-update ::= incr-decr-expression | assign | primary-expression
Usage Notes
RL Language does not allow a comma separated list of expressions in the for init
or for update clauses (Java does allow this).
Example
Example 2–41 shows RL Language code that converts an int[] to a double[].
2-48 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Actions and Action Blocks
Execute the first action block. Catch exceptions thrown during executions that match
the Throwable class in a catch clause. For the first match, execute the associated catch
action block. Bind the Throwable class instance to the given identifier and make it
available to the catch action block. Whether an exception is thrown in the try action
block, execute the finally action block, if given.
Uncaught exceptions are printed as error messages when using the RL Language
command-line and are thrown as RLExceptions when using a RuleSession's
executeRuleset or callFunction methods. The try, catch, and finally in RL
Language is like Java both in syntax and in semantics. There must be at least one
catch or finally clause.
Format
try ::= try action-block
( catch (class-implementing-throwable identifier ) action-block )*
[ finally action-block ]
class-implementing-throwable ::= qname
Usage Notes
In order to fully understand how to catch exceptions in RL Language, one must
understand how the stack frames are nested during rule execution. Rules do not call
other rules the way that functions or methods may call functions or methods.
Therefore, you cannot use a catch block in one rule's action block to catch exceptions in
another rule's action block. Exceptions thrown during rule firing must either be
handled by the firing rule's action block, or must be handled by a caller to the run,
runUntilHalt, or step functions that caused the rule to fire.
Examples
Example 2–42 shows the try catch and finally actions. The output from running this
example is:
exception in invoked Java method
this is really bad!
but at least it's over!
Note that RL Language treats the explicitly thrown Exception ("this is really
bad!") as an exception from an invoked Java method, and wraps the Exception in a
JavaException. The explicitly thrown Exception is available as the cause of the
JavaException.
As in Java, the synchronized action is useful for synchronizing the actions of multiple
threads. The synchronized action block lets you acquire the specified object's lock, then
execute the action-block, then release the lock.
Format
synchronized ::= synchronized object-primary-expression action-block
Example
Example 2–43 changes the name of a Person object, adding old names to the
nicknames, and synchronizes so that a concurrent reader of the Java object who is also
synchronizing will see a consistent view of the Person (See Example 2–12 details on
the Person bean).
2-50 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Actions and Action Blocks
Modify Action
Modify updates the named properties using the associated expressions. It also updates
the associated shadow fact, if any, and causes rules whose conditions reference the
updated properties and evaluate to true to be activated. Rules whose conditions do
not reference the updated properties are not activated.
The object argument to modify must be an object that has already been asserted, then
the values of that object are updated and network is updated with the slot-specific
semantics. The result is the object and the network are consistent.
Format
modify ::= modify (object-expression , property-update ( , property-update )* )
property-update ::= property-name : expression.
Usage Notes
It is common for a fact to have properties that are set or modified by rules. For
example, a customer in an application might have a status of "", "silver", or "gold". The
status may be set by rules that examine other properties of customer and related facts
(such as past orders). It is also common for these computed properties to be used in
further rule conditions. For example, give gold customers a 10% discount. A rule that
modifies a fact and reasserts it must be careful to add an extra condition so that it does
not reactive itself over and over. For example, if the following rule fires once, it will
fire over and over:
if fact Customer c && c.pastYearSpend > 1000 {
c.status = "gold";
assert(c);
}
You can fix this looping using the following rule definition:
if fact Customer c && c.pastYearSpend > 1000 && c.status != "gold" {
c.status = "gold";
assert(c);
}
Example 2–44 prevents the loop but does not activate rules that are looking for gold
customers
Example 2–44 demonstrates bad rules programming practice because it changes the
value of the customer object but not the value of the, shadow, customer fact. The
modify action lets you modify the object and fact together. Modify also activates rules
that test the modified properties but does not activate rules that test non-modified
properties.
if fact Customer c && c.pastYearSpend > 1000 {
modify(c, status: "gold");
}
This rule does not loop because the tested properties and modified properties are
disjoint. This rule can be used in an inference to fire subsequent rules that test for
status=="gold".
A second rule that illustrates infinite looping is the rule described as follows:
Give Employees earning at least $50,000 a 5% raise.
if Employee emp && emp.sal > 50000 {
modify(emp, sal: sal * 1.05);
}
Even using modify, this rule will self-trigger because it is testing the same property
(sal) that it is modifying, and the test is true after modification. To avoid looping in
this case, you could also add a raise property test, as follows:
if Employee emp && emp.sal > 50000 && !emp.raise {
modify(emp, sal: emp.sal * 1.05, raise: true);
}
Alternatively, to avoid looping in this case you could also add a fact to handle the
raise. For example:
public class RaiseGiven
{
Employee emp; // or possibly just an employee ID
}
2-52 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Actions and Action Blocks
Return Action
The return action returns from the action block of a function or a rule.
A return action in a rule pops the ruleset stack, so that execution continues with the
activations on the agenda that are from the ruleset that is currently at the top of the
ruleset stack.
If rule execution was initiated with either the run or step functions, and a return action
pops the last ruleset from the ruleset stack, then control returns to the caller of the run
or step function.
If rule execution was initiated with the runUntilHalt function, then a return action will
not pop the last ruleset from the ruleset stack. The last ruleset is popped with
runUntilHalt when there are not any activations left. The Oracle Rules Engine then
waits for more activations to appear. When they do, it places the last ruleset on the
ruleset stack before resuming ruleset firing.
Format
return ::= return [ return-value] ;
return-value ::= expression
If the function has a returns clause, then the return-value must be specified and it
must be of the type specified by the returns clause.
Usage Notes
A return action in a rule or a function without a returns clause must not specify a
return-value.
Throw Action
Format
throw ::= throw throwable ;
throwable ::= object-primary-expression
2-54 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Actions and Action Blocks
Assign Action
Format
assign ::= assignment-expression ;
assignment-expression ::= boolean-assignment
| numeric-assignment
| string-assignment
| object-assignment
| array-assignment
Example
Example 2–45 shows the use of the RL Language assignment expression. This prints "6
5".
Increment and decrement in RL Language, as in Java, are expressions that can appear
as actions.
Format
incr-decr ::= incr-decr-expression ;
incr-decr-expression ::= ( ++ | -- ) numeric-target-expression | numeric-target-expression ( ++ | -- )
Examples
Example 2–46 shows the use of the RL Language decrement action. This example
prints "0".
2-56 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Actions and Action Blocks
Primary Actions
A primary action is a primary expression such as a function call, assert, or Java method
call executed for its side-effects. For example, the println function is often used as a
primary action.
Format
primary-action ::= primary-expression ;
Rulegroup
A rulegroup provides support for decision table overrides. This supports the following
decision table features: the ability for one rule to override one or more other rules
Format
rulegroup ::= rulegroup rulegroup-name { rulegroup-property* ( rule | rulegroup )* }
rulegroup-name ::= identifier
rulegroup-property ::= mutex
mutex ::= mutex = boolean-literal ;
Usage Notes
A rulegroup construct is a top level construct in a ruleset. A rulegroup has an optional
boolean property:
■ mutex: The mutex property enables mutual exclusion between rules. The common
case is that the rules reside in the same rulegroup that has set mutex to true. In
more complex rulegroup hierarchies, two rules mutually exclude each other if
their closest common ancestor rulegroup has mutex set to true. When a rules fires,
existing activations for rules which it mutually excludes are removed from the
agenda preventing them from firing. Theses activations must be directly related as
identified by the set of facts that resulted in the activations being placed on the
agenda. This leads to the requirement that the conditions of all rules that mutually
exclude each other have the same fact clauses specified in the same order. This
occurs naturally for decision tables.
Example
Example 2–47 demonstrates the use of rulegroups with the mutex property. Note that
r2 and r3 reference the same set of fact types in the same order in the rule condition.
This is required within a mutex group. The tests in the patterns can be different. The
restriction on the shape of the rule condition in a mutex group extends to its
descendent groups. Thus, rules r4 and r5 also must reference the same set of fact types
in the same order. Assume that one instance of A and one instance of B have been
asserted and that r1, r2, r3, r4 and r5 have activations on the agenda. r3 will fire since it
has a higher priority. The activation of r2 will be removed without firing since r2 is in a
group with mutex=true. Since group2 is a member of group1, the activations of r4 and
r5 will also be removed without firing. Rule r1 will fire. Now, assume that r2, r4, and
r5 have activations on the agenda and assume that r4 fires first. The activation for r2
will be remove without firing since any rule in group2 firing mutually excludes both
r2 and r3. r5 will fire. It is not mutually excluded since group2 does not have
mutex=true.
Example 2–47 Ruleset with Rulegroup with Specified Fact Order of Reference
ruleset set1
{
rule r1 { ... }
rulegroup group1
{
mutex = true;
rule r2 { if fact A && fact B ... { ... }}
rule r3 { priority = 2; if fact A && fact B ... { ... }}
2-58 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Rulegroup
rulegroup group2
{
rule r4 { if fact A && fact B ... { ... }}
rule r5 { if fact A && fact B ... { ... }}
}
}
}
Built-in Functions
2-60 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
assert
Adds a fact to working memory or updates a fact already in working memory based
on the properties of the supplied object obj. If the supplied object obj is a Java instance,
then properties are Java bean properties defined by an associated BeanInfo class or
by the existence of getter and setter methods. If obj is an RL Language class instance,
then the properties are the fields of the class.
Format
function assert(Object obj);
Usage Notes
The fact in working memory is a shadow of the supplied object obj, and this shadow
contains a copy, clone, or reference to each property prop. If prop is a primitive type,
then prop is copied to the shadow. If prop implements the Java Cloneable interface,
then a clone, shallow copy, of prop is shadowed. Otherwise, only the reference to prop
is shadowed. The more a shadow can copy its object's properties, the better a rule with
references to several facts can be optimized.
Note that because == and != when applied to an Object in RL Language always
invokes the Object equals method, whether a shadow contains copies, clones, or
references is transparent to the RL Language program.
Assert may affect the agenda. Rules whose conditions now return a fact set because of
a new fact place activations on the agenda. Activations that test for non-existence of
facts, using !, may be removed from the agenda. Updates to facts may affect the
agenda. Activations whose rule conditions no longer match the changed facts are
removed from the agenda. Rules whose conditions return a fact set because of the
changed facts have activations placed on the agenda.
Assert should be used to update the fact in working memory if any part of the obj’s
state has been updated that could possibly have an effect on a rule condition, unless
the obj is a Java bean that supports registering property change listeners, and all that is
changed is the value of a bean property.
Examples
Example 2–48 prints, "Pavi has highest salary 65000.0" and Example 2–49 prints, "dept
10 has no employees!".
See Also
assertTree, id, object, retract
2-62 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
assertTree
Format
assertTree(Object root)
assertTree(String spec, Object root)
Usage Notes
There are two assertTree() signatures:
■ assertTree(Object root) is necessary with SDK2. This format traverses the object
graph and asserts objects as directed by internal metadata generated by SDK2.
■ assertTree(String spec, Object root) is necessary when SDK2 is not involved. Similar
to assertXPath, spec is a package specification enhanced to allow the specification
of multiple packages separated by a colon. This format asserts objects and
traverses the bean properties of an object if the object is in one of the specified
packages. Typically, the package specification will be the same one used in
establishing the JAXBContext.
The assertTree function does the following:
■ asserts objects starting with the root and every fact (object with a visible declared
fact type) referenced from the root, recursively.
■ assert JAXBElement instances it encounters, extract the value class object it
contains and continue.
See Also
assert
assertXPath
Format
function assertXPath(String pkg, Object element, String xpath);
See Also
assert, id, object, retract
2-64 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
clearRule
Clears the named rule from the rule session. Removes all of the rule’s activations from
the agenda.
Format
function clearRule(String name);
See Also
getRuleSession
clearRulesetStack
Format
function clearRulesetStack();
See Also
getRulesetStack, getStrategy, popRuleset, pushRuleset, run, setStrategy
2-66 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
Format
function clearWatchRules();
function clearWatchActivations();
function clearWatchFacts();
function clearWatchFocus();
function clearWatchCompilations();
function clearWatchAll();
See Also
watchRules, watchActivations, watchFacts, watchFocus, watchCompilations
contains
Format
contains(Collection c, Object o) returns boolean
Usage
When contains() encounters a JAXBElement in the collection c, it obtains the value
class from the JAXBElement and compares it to the Object o.
See Also
assertTree
2-68 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
getCurrentDate
The getCurrentDate function returns the date associated with the CurrentDate fact.
Format
getCurrentDate() returns Calendar
Usage Notes
The effective date and the current date are two orthogonal items. The effective date is
used to determine which rules are in affect according to the start and end effective date
properties. The CurrentDate fact allows reasoning on a rules engine managed fact
representing the "current" date.
Setting the current date does not affect the effective date semantics.
If you want to create rules to reason on the date explicitly in the rules, then use the
CurrentDate fact. If you want to assign start and or end effective dates to rules and
have the rules in effect determined from a date in the data, then use
setEffectiveDate().
See Also
setCurrentDate, getEffectiveDate, setEffectiveDate
getDecisionTrace
Format
getDecisionTrace() returns DecisionTrace
Usage Notes
See Also
getDecisionTraceLevel, getDecisionTraceLevel, watchRules, watchActivations,
watchFacts, watchFocus, watchCompilations
2-70 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
getDecisionTraceLevel
Format
getDecisionTraceLevel() returns int
Usage Notes
Supported decision trace levels include the following levels:
■ Off: decision tracing is disabled. This is defined as RuleSession.DECISION_
TRACE_OFF.
■ Production: rules fired are shown in trace. This is defined as
RuleSession.DECISION_TRACE_PRODUCTION.
■ Development: full decision tracing similar in detail to watchAll(). This is
defined as RuleSession.DECISION_TRACE_DEVELOPMENT.
See Also
getDecisionTrace, getDecisionTraceLimit, watchRules, watchActivations, watchFacts,
watchFocus, watchCompilations
getDecisionTraceLimit
Format
getDecisionTraceLimit() returns int
Usage Notes
See Also
getDecisionTrace, getDecisionTraceLevel
2-72 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
getEffectiveDate
The getEffectiveDate function returns the current value of the effective date.
Format
getEffectiveDate() returns Calendar
Usage Notes
The effective date and the current date are two orthogonal items. The effective date is
used to determine which rules are in affect according to the start and end effective date
properties. The CurrentDate fact allows reasoning on a engine managed fact
representing the "current" date. Both may be set explicitly.
Setting the current date does not affect the effective date semantics. Setting the
effective date does not affect the CurrentDate fact.
If you want to create rules to reason on the date explicitly in the rules, then use the
CurrentDate (setCurrentDate()). If you want to assign start and or end effective
dates to rules and have the rules in effect determined from a date in the data, then use
setEffectiveDate().
See Also
setEffectiveDate, getCurrentDate, setCurrentDate
getFactsByType
Returns a list of all facts in working memory that are instances of a specified class.
Format
function getFactsByType(String className) returns List
See Also
showFacts, watchRules, watchActivations, watchFacts, watchFocus,
watchCompilations
2-74 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
getRulesetStack
Format
function getRulesetStack() returns String[];
Usage Notes
See Also
clearRulesetStack, getStrategy, popRuleset, pushRuleset, setRulesetStack, setStrategy
getRuleSession
Format
function getRuleSession() returns RuleSession;
Example
rule learn {
if (fact f1 && …)
{
RuleSession rs = getRuleSession();
rs.executeRuleset("rule newRule { if fact f1 && fact f2 && … { … } }");
}
}
See Also
clearRule
2-76 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
getStrategy
Returns the current strategy. Table 2–7 shows the possible strategy values.
Format
function getStrategy() returns String;
See Also
clearRulesetStack, getRulesetStack, popRuleset, pushRuleset, setStrategy
halt
The halt function halts execution of the currently firing rule, and returns control to the
run, runUntilHalt, or step function that caused the halted rule to run. The agenda is
left intact, so that a subsequent run, runUntilHalt, or step can be executed to resume
rule firings.
The halt function has no effect if it is invoked outside the context of a run,
runUntilHalt, or step function.
Format
function halt();
See Also
reset, run, runUntilHalt, step
2-78 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
id
Return the fact id associated with the object obj. If obj is not associated with a fact,
returns -1.
Format
function id(Object obj) returns int;
See Also
assert, object, retract
object
Return the object associated with the given fact id. If there is no such fact id, returns
null.
Format
function object(int factId) returns Object;
See Also
assert, id, retract
2-80 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
println
Format
function println(char c);
function println(char[] ca);
function println(int i);
function println(long l);
function println(float f);
function println(double d);
function println(boolean b);
function println(Object obj);
popRuleset
Format
function popRuleset() returns String;
See Also
clearRulesetStack, getRulesetStack, getStrategy, pushRuleset, setStrategy
2-82 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
pushRuleset
Push the given ruleset onto the stack and make it the focus. It is an error to push a
ruleset that is already the focus (RLIllegalArgumentException is thrown for this
error).
Entry 0, the top of the stack, is the focus ruleset. The focus ruleset is the ruleset whose
activations are fired first by a subsequent run, runUntilHalt, or step function
execution.
Format
function pushRuleset(String focus);
Examples
Example 2–51 shows the RL Language using the pushRuleset function.
Example 2–52 shows the RL Language using the popRuleset function.
See Also
clearRulesetStack, getRulesetStack, getStrategy, popRuleset, setStrategy
retract
Remove the fact associated with the object obj from working memory.
Format
function retract(Object obj);
Usage Notes
Retract may affect the agenda. Activations that depend on the retracted fact are
removed from the agenda.
Note, rules that have conditions that test for non-existence of facts (using !) may place
new activations on the agenda.
See Also
assert, id, object
2-84 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
reset
Clears all facts from working memory, clears all activations from the agenda, and
reevaluates non-final global variable initialization expressions.
Format
function reset();
See Also
halt, run, runUntilHalt, step
run
Format
function run() returns int;
function run(String rulesetName) returns int;
Usage Notes
If the argument, rulesetName is supplied, the named ruleset is pushed on the top of the
ruleset stack before firing any rules.
If a null rulesetName is supplied, the ruleset stack is not modified before firing rules.
If no rulesetName is supplied and the default main ruleset is not on the ruleset stack,
then the main ruleset is placed at the bottom of the ruleset stack before firing any
rules.
Returns: int, the number of rules fired.
See Also
halt, reset, runUntilHalt, step
2-86 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
runUntilHalt
This function fires rule activations until halt is called. Unlike run and step,
runUntilHalt does not return when the agenda is empty. Also, runUntilHalt does not
pop the bottommost ruleset name from the ruleset stack. Instead, it waits for the
agenda to contain activations.
Format
function runUntilHalt() returns int;
Usage Notes
The only way for activations to be added to the agenda while the main RuleSession
thread is busy executing runUntilHalt is for a second thread to either:
1. Modify Java bean facts with PropertyChangeListeners.
2. Execute assert or retract functions.
Rules must be designed carefully when using runUntilHalt. For example, a rule that
attempts to find a fact with the minimum value of a property will fire when the first
instance of the fact is asserted, and then every time another instance is asserted with a
lower valued property.
See Also
halt, reset, run, step
setCurrentDate
The setCurrentDate function sets the date for reasoning on an engine managed fact
representing the "current" date (with the CurrentDate fact).
Format
setCurrentDate(Calendar newDate)
Usage Notes
The RLIllegalArgumentException exception is thrown if the newDate argument is
null.
If you need to reason on the date explicitly in the rules, then use the CurrentDate
fact. If you want to assign start and end effective dates to rules and have the rules in
effect determined from a date in the data, then they should use setEffectiveDate. The
setEffectiveDate function does not affect the CurrentDate fact.
By default the value of the current date is managed implicitly by the rules engine. The
value of the CurrentDate fact is updated to the current system date and (re)asserted
internally when a run family of built-in functions is invoked. This is done before any
rules fire so that the new current date is evaluated in rule conditions. In the case of
runUntilHalt, this update occurs each time there is a transition from 0 rules on the
agenda to > 0 rules on the agenda.
After the user invokes the setCurrentDate function, it becomes the responsibility of
the user to update the current date as required. The rules engine no longer manages it
implicitly. This remains in effect until the reset function is invoked. After the current
date is set explicitly with setCurrentDate, any invocation of setCurrentDate
function that would result in time going backward, set to an earlier point in time, is an
error and an RLIllegalArgumentException is thrown. After the reset function is
invoked, the current date may be set to any value.
See Also
getCurrentDate, getEffectiveDate, setEffectiveDate
2-88 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
setDecisionTraceLevel
Format
setDecisionTraceLevel(int level)
Usage Notes
Supported decision trace levels include the following levels:
■ Off: decision tracing is disabled. This is defined as RuleSession.DECISION_
TRACE_OFF.
■ Production: rules fired are shown in trace. This is defined as
RuleSession.DECISION_TRACE_PRODUCTION.
■ Development: full decision tracing similar in detail to watchAll(). This is
defined as RuleSession.DECISION_TRACE_DEVELOPMENT.
See Also
getDecisionTrace, getDecisionTraceLevel, getDecisionTraceLevel,
setDecisionTraceLimit, watchRules, watchActivations, watchFacts, watchFocus,
watchCompilations
setDecisionTraceLimit
Format
setDecisionTraceLimit(int count)
Usage Notes
The default value is 10000.
See Also
getDecisionTrace, getDecisionTraceLevel, getDecisionTraceLevel,
setDecisionTraceLevel
2-90 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
setEffectiveDate
The setEffectiveDate function updates the effective date in the rules engine.
By default, the value of the effective date is managed implicitly by the rules engine. In
this case, when a run family of built-in functions is invoked the effective date is
updated to the current system date. This is done before any rules fire so that the new
effective date is applied before rules begin to fire. In the case of runUntilHalt, this
update occurs each time there is a transition from 0 rule activations on the agenda to >
0 rule activations on the agenda.
Format
setEffectiveDate(Calendar newDate)
Usage Notes
Invoking setEffectiveDate is the only way that you can alter the effective date. After
the reset function is invoked, the effective date may be set to any value.
The RLIllegalArgumentException exception is thrown if the newDate argument is
null.
After you invoke the setEffectiveDate function, it becomes the responsibility of the
application to update the effective date as required. The rules engine no longer
manages it implicitly.
This remains in effect until the reset function is invoked.
This is useful for debugging, performing rule evaluation at a "point in time", or other
use cases that require application control of the effective date.
See Also
getEffectiveDate, getCurrentDate, setCurrentDate
setRulesetStack
Format
function setRulesetStack(String[] rulesetStack
See Also
clearRulesetStack, getRulesetStack, getStrategy, popRuleset, pushRuleset, setStrategy
2-92 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
setStrategy
Strategy specifies the order in which activations from the same ruleset and with the
same priority are executed. Table 2–7 shows the valid strategy values.
Format
function setStrategy(String strategy);
See Also
clearRulesetStack, getRulesetStack, getStrategy, popRuleset, pushRuleset
showActivations
The show functions print rule session state to the output Writer. State that can be
shown is: Activations all activations on the agenda
Format
function showActivations();
See Also
clearWatchRules, clearWatchActivations, clearWatchFacts, clearWatchFocus,
clearWatchCompilations, clearWatchAll, showFacts, watchRules, watchActivations,
watchFacts, watchFocus, watchCompilations
2-94 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
showFacts
The show functions print rule session state to the output Writer. State that can be
shown is: all facts in working memory.
Format
function showFacts();
See Also
clearWatchRules, clearWatchActivations, clearWatchFacts, clearWatchFocus,
clearWatchCompilations, clearWatchAll, showActivations, watchRules,
watchActivations, watchFacts, watchFocus, watchCompilations
step
Format
function step(int numRulesToFire) returns int;
function step(int numRulesToFire, String rulesetName) returns int;
Usage Notes
If no ruleset name is supplied and the main ruleset is not on the ruleset stack, then the
main ruleset is placed at the bottom of the ruleset stack before firing any rules.
If a ruleset named, rulesetName, is supplied, the specified ruleset is pushed on the top
of the ruleset stack before firing any rules. If a null ruleset name is supplied, the ruleset
stack is not modified before firing rules.
Returns the integer number of rules fired.
See Also
halt, reset, run, runUntilHalt
2-96 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Built-in Functions
The watch functions turn on printing of information about important rule session
events. The information is printed to the output Writer whenever the events occur. Use
a clearWatch function to turn off printing.
Table 2–8 describes the available debugging information.
Format
function watchRules();
function watchActivations();
function watchFacts();
function watchFocus();
function watchCompilations();
function watchAll();
See Also
clearWatchRules, clearWatchActivations, clearWatchFacts, clearWatchFocus,
clearWatchCompilations, clearWatchAll, showActivations, showFacts
2-98 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
3
3 Using the Command-line Interface
This chapter describes the RL command-line that reads rulesets from System.in and
writes output from the functions println, watch, and, show to System.out.
This chapter includes the following topics:
■ Section 3.1, "Starting and Using the Command-Line Interface"
■ Section 3.2, "RL Command-Line Options"
■ Section 3.3, "RL Command-Line Built-in Commands"
Where BeanPath is the classpath component to any supplied Java Bean classes.
To exit the command-line interface, use the special action exit; at the command
prompt. The exit; action cannot be in an included ruleset. Alternatively, to exit you
can invoke the System.exit(int) method in any action.
The RL command-line interface accumulates input line by line, and interprets the
input when the input stream includes either:
■ A complete named ruleset
■ One or more complete import, include, ruleset, definition, action
commands within an unnamed ruleset.
Note: The if,else and try, catch, and finally actions require
lookahead to determine where they end. In order to execute an if
without an else clause, or a try without a finally clause at the RL
command-line, you should add a semicolon terminator.
This is not necessary if you execute RL using include, or using the
RuleSession API.
Input must be complete at the end of a line. For example, if an action ends in the
middle of a line, then that action is not interpreted until some following action is
complete at the end of a line.
Example 3–2 Sample Command-Line Input Processing - Waiting for End of Line
RL> println("delayed"
); println("hello"
); println("world");
delayed
hello
world
RL>
To avoid this behavior, you can explicitly enclose the input in a ruleset. For
example,
ruleset main {
int i = 0; i = 1;
i = "i";
}
3-2 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
RL Command-Line Built-in Commands
Now, the error is on line 3 or, you can include the input file using an include.
If you do not want to read from the input after executing the command,
include "exit;" after the command.
For example,
-c "include file:script.rl; exit;"
–p Sets the next argument as the prompt string.
For example,
-p "RL> "
-o Specifies where to write output from println, watch, and show to the file
named by the next argument, instead of to System.out.
For example:
–o debug.log
3-4 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
4
4 Using a RuleSession
4-2 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
XML Navigation
See Also: "Working with Rules SDK Decision Point API" in the
Oracle Business Rules User's Guide
Note: The traffic.* sample classes are not included in the Oracle
Business Rules distribution.
4-4 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Debugging an RL Stacktrace
See Also: For documentation see the Javadoc for the RLClass,
RLObject, RLProperty and RLArray classes in the oracle.rules.rl
package. Thus, RL objects, or instances of RL classes, can be used to
hold rule engine results as well as Java objects.
sess.callFunctionWithArgument("assert", ti);
sess.callFunction("run");
location of a problem. This extra context is useful when working with Rules SDK and
Rules Designer.
The stacktrace includes the extra context showing the information for rule conditions,
rule actions, functions, variables, and RL class definitions. The XPath style format
consists of an RL construct and, if named, followed by the name enclosed in
parentheses. If a number, n, appears in brackets after a construct it indicates the nth
item following the previous construct. In combination with Rules SDK, RL generation
should significantly assist in identifying a location for an error in Rules Designer.
For example, consider the ruleset shown in Example 4–3. When this ruleset executes, it
gives the following report:
RLNullPointerException: object cannot be null
at line 12 column 13 in stackTraceContext /Rule(porsche)/Pattern(car)/Test[1]
at line 17 column 5 in stackTraceContext
rule porsche
{
if (fact Car car &&
car.make.startsWith("Porsche"))
{
println(car.make + " " + car.model);
}
}
assert(new Car());
}
ruleset stackTraceContext
{
class Car
{
String make;
String model;
}
rule porsche
{
if (fact Car car &&
car.make.startsWith("Porsche"))
{
println(car.make + " " + car.model);
4-6 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using RuleSession Pooling
}
}
assert(new Car());
If the rules in use by an application are updated, the application may need to load the
new rules so that subsequent rule executions use the new rules. This is supported by
the pool by invoking the refreshPool method passing it a list of the new RL. After the
pool has been refreshed, RuleSessions returned by getPoolableRuleSession will have
been initialized with the new RL code. When RuleSessions that were obtained before
the refresh are returned using returnPoolableRuleSession, they are not placed back in
the pool. The refreshed pool will only contain RuleSessions initialized with the new RL
code.
A soft upper bound on the size of the pool can be specified. This allows the pool to
respond to temporary increases in demand by growing the pool while allowing the
pool to shrink down to this soft upper bound when demand subsides.
Using the RuleSession pooling implementation, you create RuleSession instances
when the getPoolableRuleSession method is invoked and the pool is empty. If the load
is heavy enough, this will result in an instance count that is greater than the soft limit.
As the load subsides, the number of RuleSesion instances in the pool will
automatically be decreased to the soft limit.
4-8 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Using RuleSession Options
4-10 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
A
A Summary of Java and RL Differences
This appendix includes descriptions of differences between the RL Language and Java
languages.
■ For RL and Java objects, == always invokes the object equals method. RL does
not allow testing for object reference equality. For objects,!= does not test for
inequality of object references, but rather is the negation of the equals methods.
Thus, the statement:
if (object1 != object2){}
A-2 Oracle Fusion Middleware Language Reference Guide for Oracle Business Rules
Index
A class-definition-name, 2-4
clear function, 2-67
action, 2-45 clearRule function, 2-65
assign, 2-55 clearRulesetStack function, 2-66
modify, 2-51 clearWatch function, 2-67
primary, 2-57 clearWatchActivation function, 2-67
return, 2-53 clearWatchAll function, 2-67
throw, 2-54 clearWatchCompilations function, 2-67
action-block, 2-45 clearWatchFacts function, 2-67
catch, 2-49 clearWatchFocus function, 2-67
else, 2-46 clearWatchRules function, 2-67
finally, 2-49 collection aggregate, 2-36
for, 2-48 command line
if, 2-46 starting, 1-2
synchronized, 2-50 comparable expression, 2-39
try, 2-49 concatenation, 2-6
while, 2-47 string, 2-31
activation, 1-6 contains function, 2-68
active property, 2-13 count aggregate, 2-36
agenda, 1-6
aggregate functions, 2-36
aggregate keyword, 2-36 D
array-expression, 2-32 decision table
assert function, 2-61 logical option, 2-13
assertTree function, 2-63 decrement expression, 2-56
assertXpath function, 2-64 definition, 2-9
assignment-expression, 2-55 name, 2-9
association keyword, 2-21 qname, 2-9
autofocus, 2-12 variable, 2-10
autofocus= keyword, 2-12 double keyword, 2-4
average aggregate, 2-36
E
B
effectiveEndDate property, 2-13
back quote effectiveStartDate property, 2-13
and xml identifiers, 2-7 else
boolean keyword, 2-4, 2-10 action-block, 2-46
byte keyword, 2-4 else keyword, 2-46
exception
C throw, 2-54
exists keyword, 2-33
catch keyword, 2-49
expression
CFG_DECISION_TRACE_LEVEL parameter, 4-9
array-expression, 2-32
CFG_DECISION_TRACE_LIMIT parameter, 4-9
boolean-expression, 2-28
CFG_LOGGING system property, 4-8
comparable, 2-39
char keyword, 2-4
decrement, 2-56
Index-1
definition, 2-27 setEffectiveDate, 2-91
increment, 2-56 setRulesetStack, 2-92
numeric-expression, 2-30 setStrategy, 2-93
object-expression, 2-40 showActivation, 2-94
primary-expression, 2-41 showFacts, 2-95
string-expression, 2-31 step, 2-96
watch, 2-97
F
fact keyword, 2-33 G
fact set, 1-6, 2-33 getCurrentDate function, 2-69
fact set row, 1-6 getEffectiveDate function, 2-73
fact-class-body, 2-21 getFactsbyType function, 2-74
factpath, 2-33 getRuleSession function, 2-76
facts getRulesetStack function, 2-75
and working memory, 1-4 getStrategy function, 2-77
definition of, 1-4 global variable, 2-10
Java classes as, 1-5
RL classes as, 1-5
H
fact-set expression, 2-33
fact-set-expression, 2-33 halt function, 2-78
final keyword, 2-10 hide keyword, 2-21
finally keyword, 2-49
fire rule, 1-7 I
float keyword, 2-4
for id function, 2-79
action-block, 2-48 identifier, 2-7
for-init, 2-48 java-identifier, 2-7
for-update, 2-48 xml-identifier, 2-7
function if action-block, 2-46
assert, 2-61 implicit conversion, 2-4
assertTree, 2-63 import keyword, 2-25
assertXpath, 2-64 importing
clear, 2-67 Java class, 2-25
clearRule, 2-65 include
clearRulesetStack, 2-66 file, 2-26
contains, 2-68 http, 2-26
definition, 2-20 increment expression, 2-56
getCurrentDate, 2-69 instanceof keyword, 2-28
getDecisionTrace, 2-70 int keyword, 2-4
getDecisionTraceLevel, 2-71
getDecisionTraceLimit, 2-72 J
getEffectiveDate, 2-73
Java class
getFactsbyType, 2-74
importing, 2-25
getRuleSession, 2-76
Java-class-name, 2-4
getRuleSetStack, 2-75
java-identifier, 2-7
getStrategy, 2-77
java.lang.String, 2-6
halt, 2-78
JAXB and xml support, 2-16
id, 2-79
keyword, 2-20
object, 2-80 L
popRuleset, 2-82
literals, 2-8
println, 2-81
logical, 2-12
pushRuleset, 2-83
logical option, 2-13
recursive, 2-20
logical= keyword, 2-12
reset, 2-85
long keyword, 2-4
retract, 2-84
run, 2-86
runUntilHalt, 2-87 M
setCurrentDate, 2-88 maximum aggregate, 2-36
Index-2
minimum aggregate, 2-36 reverses keyword, 2-21
modify action, 2-51 RL
mutex property, 2-58 reserved words, 2-1
rulegroup, 2-58
mutext property, 2-58
N
rules
name active property, 2-13
definition, 2-9 autofocus, 2-12
named-ruleset, 2-2 definition, 2-12
nested ruleset, 2-2 effectiveEndDate property, 2-13
null keyword, 2-10 effectiveStartDate property, 2-13
numeric, 2-4 fire, 1-7
numeric-expression, 2-30 logical option, 2-13
precedence, 2-30 logical property, 2-12
ordering, 1-9
O priority, 1-9, 2-12
rule action, 1-2, 1-3
object function, 2-80 rule condition, 1-2, 1-3
object type, 2-6 rulesession
object-expression, 2-40 CFG_DECISION_TRACE parameter, 4-9
object-type, 2-4 CFG_DECISION_TRACE_LEVEL parameter, 4-9
options ruleset, 2-2
-c command-line, 3-3 include, 2-26
-i command-line, 3-3 nested, 2-2
-o command-line, 3-3 using, 1-2
-p command-line, 1-2, 3-3 ruleset stack, 1-9
-v command-line, 3-3 ruleset-name, 2-2
run function, 2-86
P runUntilHalt function, 2-87
popRuleset function, 2-82
precedence S
numeric-expression, 2-30 setCurrentDate function, 2-88
primary action, 2-57 setEffectiveDate function, 2-91
primary-expression, 2-41 setRulesetStack function, 2-92
primitive, 2-4 setStrategy
primitive type, 2-5 function, 2-93
println function, 2-81 queue strategy, 2-93
priority, 2-12 stack strategy, 2-93
priority= keyword, 2-12 short keyword, 2-4
property, 2-12 showActivations function, 2-94
property keyword, 2-21 showFacts function, 1-8, 2-95
pushRuleset function, 2-83 simple-type, 2-4
stack strategy, 2-93
Q starting command line interface, 1-2
step function, 2-96
qname
string
definition, 2-9
+ operator, 2-31
queue strategy, 2-93
concatenation, 2-6, 2-31
literal, 2-6
R type, 2-6
string-expression, 2-31
references keyword, 2-21
sum aggregate, 2-36
reserved words, 2-1
supports keyword, 2-16
reset function, 2-85
synchronized
results
keyword, 2-50
obtaining, 4-4
using external resources, 4-5
retract function, 1-8, 2-84 T
return keyword, 2-53 throw keyword, 2-54
returns keyword, 2-20
Index-3
try keyword, 2-49
type, 2-4
conversion, 2-4
implicit conversion, 2-4
java.lang.String, 2-6
object, 2-6
primitive, 2-5
simple-type, 2-4
string, 2-6
types
simple-type, 2-4
U
unnamed-ruleset, 2-2
user defined aggregate, 2-36
V
var keyword, 2-33
variable
definition, 2-10
global, 2-10
W
watchActivations function, 1-7, 2-97
watchAll function, 2-97
watchCompilations function, 2-97
watchFacts function, 1-7, 2-97
watchFocus function, 2-97
watchRules function, 1-7, 2-97
while
action-block, 2-47
keyword, 2-47
working memory, 1-4
X
XML
binding, 2-16
support, 2-16
XLINK class, 2-16
xpath support, 2-16
xml-identifier, 2-7
Index-4