Clover coverage report - Drools - 2.0-rc2
Coverage timestamp: Wed May 11 2005 07:12:26 BST
file stats: LOC: 123   Methods: 5
NCLOC: 66   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
ConsequenceHandler.java 50% 91.3% 80% 86.7%
coverage coverage
 1    package org.drools.io;
 2   
 3    /*
 4    * $Id: ConsequenceHandler.java,v 1.6 2005/02/04 02:13:38 mproctor Exp $
 5    *
 6    * Copyright 2001-2003 (C) The Werken Company. All Rights Reserved.
 7    *
 8    * Redistribution and use of this software and associated documentation
 9    * ("Software"), with or without modification, are permitted provided that the
 10    * following conditions are met:
 11    *
 12    * 1. Redistributions of source code must retain copyright statements and
 13    * notices. Redistributions must also contain a copy of this document.
 14    *
 15    * 2. Redistributions in binary form must reproduce the above copyright notice,
 16    * this list of conditions and the following disclaimer in the documentation
 17    * and/or other materials provided with the distribution.
 18    *
 19    * 3. The name "drools" must not be used to endorse or promote products derived
 20    * from this Software without prior written permission of The Werken Company.
 21    * For written permission, please contact bob@werken.com.
 22    *
 23    * 4. Products derived from this Software may not be called "drools" nor may
 24    * "drools" appear in their names without prior written permission of The Werken
 25    * Company. "drools" is a trademark of The Werken Company.
 26    *
 27    * 5. Due credit should be given to The Werken Company. (http://werken.com/)
 28    *
 29    * THIS SOFTWARE IS PROVIDED BY THE WERKEN COMPANY AND CONTRIBUTORS ``AS IS''
 30    * AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 31    * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 32    * ARE DISCLAIMED. IN NO EVENT SHALL THE WERKEN COMPANY OR ITS CONTRIBUTORS BE
 33    * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 34    * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 35    * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 36    * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 37    * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 38    * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 39    * POSSIBILITY OF SUCH DAMAGE.
 40    *
 41    */
 42    import java.util.HashSet;
 43   
 44    import org.drools.rule.Declaration;
 45    import org.drools.rule.Rule;
 46    import org.drools.smf.Configuration;
 47    import org.drools.smf.ConsequenceFactory;
 48    import org.drools.smf.FactoryException;
 49    import org.drools.smf.SemanticModule;
 50    import org.drools.spi.Condition;
 51    import org.drools.spi.Consequence;
 52    import org.drools.spi.Duration;
 53    import org.xml.sax.Attributes;
 54    import org.xml.sax.SAXException;
 55    import org.xml.sax.SAXParseException;
 56   
 57    /**
 58    * @author mproctor
 59    *
 60    * TODO To change the template for this generated type comment go to Window -
 61    * Preferences - Java - Code Style - Code Templates
 62    */
 63    class ConsequenceHandler extends BaseAbstractHandler implements Handler
 64    {
 65  66 ConsequenceHandler( RuleSetReader ruleSetReader )
 66    {
 67  66 this.ruleSetReader = ruleSetReader;
 68   
 69  66 if ( (this.validParents == null) && (this.validPeers == null) )
 70    {
 71  66 this.validParents = new HashSet( );
 72  66 this.validParents.add( Rule.class );
 73   
 74  66 this.validPeers = new HashSet( );
 75  66 this.validPeers.add( Duration.class );
 76  66 this.validPeers.add( Condition.class );
 77  66 this.validPeers.add( Declaration.class );
 78   
 79  66 this.allowNesting = false;
 80    }
 81    }
 82   
 83  76 public Object start( String uri, String localName, Attributes attrs ) throws SAXException
 84    {
 85  76 this.ruleSetReader.startConfiguration( localName, attrs );
 86  76 return null;
 87    }
 88   
 89  76 public Object end( String uri, String localName ) throws SAXException
 90    {
 91  76 Configuration config = this.ruleSetReader.endConfiguration( );
 92  76 SemanticModule module = this.ruleSetReader.lookupSemanticModule( uri,
 93    localName );
 94   
 95  76 ConsequenceFactory factory = module.getConsequenceFactory( localName );
 96  76 Consequence consequence;
 97  76 try
 98    {
 99  76 Rule rule = (Rule) this.ruleSetReader.getParent( Rule.class );
 100  76 consequence = factory.newConsequence( rule,
 101    this.ruleSetReader.getFactoryContext( ),
 102    config );
 103   
 104  76 rule.setConsequence( consequence );
 105    }
 106    catch ( FactoryException e )
 107    {
 108  0 throw new SAXParseException( "error constructing consequence",
 109    this.ruleSetReader.getLocator( ), e );
 110    }
 111  76 return null;
 112    }
 113   
 114  0 public boolean popParent()
 115    {
 116  0 return true;
 117    }
 118   
 119  152 public Class generateNodeFor()
 120    {
 121  152 return Consequence.class;
 122    }
 123    }