[jboss-jira] [JBoss JIRA] Resolved: (JBRULES-1050) Extra space between variable and field name in LHS causes crash

Edson Tirelli (JIRA) jira-events at lists.jboss.org
Wed Aug 1 18:25:49 EDT 2007


     [ http://jira.jboss.com/jira/browse/JBRULES-1050?page=all ]

Edson Tirelli resolved JBRULES-1050.
------------------------------------

    Fix Version/s: 4.0.1
       Resolution: Done

Fixed.

Changed parser to ignore comments and white spaces when parsing nested accessors paths and qualified identifiers. Unit test added. Following expression is correctly parsed:

"org   .   drools/*comment*/\t  .Message( text not matches $c#comment\n. property )\n";
        assertEquals( "org.drools.Message", 
                      pat.getObjectType() );
        assertEquals( "not matches",
                      restr.getEvaluator() );
        assertEquals( "$c.property",
                      restr.getText() );
 
Thanks for reporting and providing test case. Fix will be included in 4.0.1.
 

> 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: Edson Tirelli
>             Fix For: 4.0.1
>
>
> 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