[jboss-jira] [JBoss JIRA] Commented: (JBRULES-1050) Extra space between variable and field name in LHS causes crash
Alexandre Gattiker (JIRA)
jira-events at lists.jboss.org
Tue Jul 31 10:00:49 EDT 2007
[ http://jira.jboss.com/jira/browse/JBRULES-1050?page=comments#action_12370567 ]
Alexandre Gattiker commented on JBRULES-1050:
---------------------------------------------
The proposed workaround actually fails upon inserting a fact. Here is an illustration, with slightly modified code and rule:
java.lang.NullPointerException
at org.drools.rule.AbstractCompositeRestriction$CompositeContextEntry.updateFromTuple(AbstractCompositeRestriction.java:112)
at org.drools.common.SingleBetaConstraints.updateFromTuple(SingleBetaConstraints.java:93)
at org.drools.reteoo.JoinNode.assertTuple(JoinNode.java:115)
at org.drools.reteoo.SingleTupleSinkAdapter.createAndPropagateAssertTuple(SingleTupleSinkAdapter.java:55)
at org.drools.reteoo.LeftInputAdapterNode.assertObject(LeftInputAdapterNode.java:131)
at org.drools.reteoo.SingleObjectSinkAdapter.propagateAssertObject(SingleObjectSinkAdapter.java:20)
at org.drools.reteoo.ObjectTypeNode.assertObject(ObjectTypeNode.java:168)
at org.drools.reteoo.Rete.assertObject(Rete.java:168)
at org.drools.reteoo.ReteooRuleBase.assertObject(ReteooRuleBase.java:190)
at org.drools.reteoo.ReteooWorkingMemory.doInsert(ReteooWorkingMemory.java:70)
at org.drools.common.AbstractWorkingMemory.insert(AbstractWorkingMemory.java:848)
at org.drools.common.AbstractWorkingMemory.insert(AbstractWorkingMemory.java:822)
at org.drools.common.AbstractWorkingMemory.insert(AbstractWorkingMemory.java:623)
at com.sample.DroolsTest.main(DroolsTest.java:27)
package com.sample
import com.sample.DroolsTest.Child;
import com.sample.DroolsTest.Parent;
import com.sample.DroolsTest.Item;
rule "My Rule"
when
$c:Child($cparent: parent)
$co:Item(attachment in ($c, $cparent))
then
System.out.println("wawa");
end
package com.sample;
import java.io.InputStreamReader;
import java.io.Reader;
import org.drools.RuleBase;
import org.drools.RuleBaseFactory;
import org.drools.WorkingMemory;
import org.drools.compiler.PackageBuilder;
import org.drools.event.DebugWorkingMemoryEventListener;
import org.drools.rule.Package;
/**
* This is a sample file to launch a rule package from a rule source file.
*/
public class DroolsTest {
public static final void main(String[] args) {
try {
RuleBase ruleBase = readRule();
WorkingMemory workingMemory = ruleBase.newStatefulSession();
workingMemory
.addEventListener(new DebugWorkingMemoryEventListener());
// go !
Child child = new Child();
workingMemory.insert(child);
workingMemory.fireAllRules();
} catch (Throwable t) {
t.printStackTrace();
}
}
private static RuleBase readRule() throws Exception {
Reader source = new InputStreamReader(DroolsTest.class
.getResourceAsStream("/Sample.drl"));
PackageBuilder builder = new PackageBuilder();
builder.addPackageFromDrl(source);
Package pkg = builder.getPackage();
RuleBase ruleBase = RuleBaseFactory.newRuleBase();
ruleBase.addPackage(pkg);
return ruleBase;
}
public static class Parent {
}
public static class Child {
private Parent parent;
public Parent getParent() {
return parent;
}
}
public static class Item {
private Object attachment;
public Object getAttachment() {
return attachment;
}
}
}
> Extra space between variable and field name in LHS causes crash
> ---------------------------------------------------------------
>
> Key: JBRULES-1050
> URL: http://jira.jboss.com/jira/browse/JBRULES-1050
> Project: JBoss Rules
> Issue Type: Bug
> Security Level: Public(Everyone can see)
> Affects Versions: 4.0.0.GA
> Reporter: Alexandre Gattiker
> Assigned To: Mark Proctor
>
> Writing a condition as "$co:Item(attachment in ($c, $c. parent))" fails at runtime with an uninformative exception. Removing the extra space and writing "$c.parent" corrects the problem.
> Below is the rule file, sample code and exception trace.
> package com.sample
>
> import com.sample.DroolsTest.Child;
> import com.sample.DroolsTest.Parent;
> import com.sample.DroolsTest.Item;
>
> rule "My Rule"
>
> when
> $c:Child()
> $co:Item(attachment in ($c, $c. parent))
> then
> System.out.println("wawa");
> end
> package com.sample;
> import java.io.InputStreamReader;
> import java.io.Reader;
> import org.drools.RuleBase;
> import org.drools.RuleBaseFactory;
> import org.drools.WorkingMemory;
> import org.drools.compiler.PackageBuilder;
> import org.drools.event.DebugWorkingMemoryEventListener;
> import org.drools.rule.Package;
> /**
> * This is a sample file to launch a rule package from a rule source file.
> */
> public class DroolsTest {
> public static final void main(String[] args) {
> try {
> RuleBase ruleBase = readRule();
> } catch (Throwable t) {
> t.printStackTrace();
> }
> }
> private static RuleBase readRule() throws Exception {
> Reader source = new InputStreamReader(DroolsTest.class
> .getResourceAsStream("/Sample.drl"));
> PackageBuilder builder = new PackageBuilder();
> builder.addPackageFromDrl(source);
> Package pkg = builder.getPackage();
> RuleBase ruleBase = RuleBaseFactory.newRuleBase();
> ruleBase.addPackage(pkg);
> return ruleBase;
> }
> public static class Parent {
> }
> public static class Child {
> private Parent parent;
> public Parent getParent() {
> return parent;
> }
> }
> public static class Item {
> private Object attachment;
> public Object getAttachment() {
> return attachment;
> }
> }
> }
> java.lang.NullPointerException
> at org.drools.reteoo.builder.PatternBuilder.createConstraints(PatternBuilder.java:128)
> at org.drools.reteoo.builder.PatternBuilder.attachPattern(PatternBuilder.java:72)
> at org.drools.reteoo.builder.PatternBuilder.build(PatternBuilder.java:54)
> at org.drools.reteoo.builder.GroupElementBuilder$AndBuilder.build(GroupElementBuilder.java:112)
> at org.drools.reteoo.builder.GroupElementBuilder.build(GroupElementBuilder.java:70)
> at org.drools.reteoo.builder.ReteooRuleBuilder.addSubRule(ReteooRuleBuilder.java:136)
> at org.drools.reteoo.builder.ReteooRuleBuilder.addRule(ReteooRuleBuilder.java:109)
> at org.drools.reteoo.ReteooBuilder.addRule(ReteooBuilder.java:116)
> at org.drools.reteoo.ReteooRuleBase.addRule(ReteooRuleBase.java:262)
> at org.drools.common.AbstractRuleBase.addPackage(AbstractRuleBase.java:333)
> at com.sample.DroolsTest.readRule(DroolsTest.java:33)
> at com.sample.DroolsTest.main(DroolsTest.java:20)
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the jboss-jira
mailing list