Clover coverage report - Drools - 2.0-rc2
Coverage timestamp: Wed May 11 2005 07:12:26 BST
file stats: LOC: 122   Methods: 6
NCLOC: 35   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
SimpleSemanticsRepository.java 100% 75% 66.7% 75%
coverage coverage
 1    package org.drools.smf;
 2   
 3    /*
 4    * $Id: SimpleSemanticsRepository.java,v 1.2.2.2 2005/04/07 17:32:15 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   
 43    import java.util.HashMap;
 44    import java.util.Map;
 45   
 46    /**
 47    * Simple in-memory repository of semantic modules.
 48    *
 49    * @author <a href="mailto:bob@werken.com">bob mcwhirter </a>
 50    */
 51    public class SimpleSemanticsRepository implements SemanticsRepository
 52    {
 53    // ------------------------------------------------------------
 54    // Instance members
 55    // ------------------------------------------------------------
 56   
 57    /** Semantic modules, indexed by URI. */
 58    private Map modules;
 59   
 60    private ClassLoader classLoader;
 61   
 62    // ------------------------------------------------------------
 63    // Constructors
 64    // ------------------------------------------------------------
 65   
 66    /**
 67    * Construct an empty repository.
 68    */
 69  7 public SimpleSemanticsRepository()
 70    {
 71  7 this.modules = new HashMap( );
 72    }
 73   
 74    // ------------------------------------------------------------
 75    // Instance methods
 76    // ------------------------------------------------------------
 77   
 78    // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
 79    // org.drools.smf.SemanticsRepository
 80    // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
 81   
 82  0 void setClassLoader(ClassLoader classLoader)
 83    {
 84  0 this.classLoader = classLoader;
 85    }
 86   
 87    /**
 88    * Register a <code>SemanticModule</code> with a URI.
 89    *
 90    * @param module The <code>SemanticModule</code>.
 91    */
 92  13 public void registerSemanticModule(SemanticModule module)
 93    {
 94  13 this.modules.put( module.getUri( ), module );
 95    }
 96   
 97    /**
 98    * @see SemanticsRepository
 99    */
 100  1819 public SemanticModule lookupSemanticModule(String uri) throws NoSuchSemanticModuleException
 101    {
 102  1819 if ( !this.modules.containsKey( uri ) )
 103    {
 104  1 throw new NoSuchSemanticModuleException( uri );
 105    }
 106   
 107  1818 return ( SemanticModule ) this.modules.get( uri );
 108    }
 109   
 110    /**
 111    * @see SemanticsRepository
 112    */
 113  1 public SemanticModule[] getSemanticModules()
 114    {
 115  1 return ( SemanticModule[] ) this.modules.values( ).toArray(SemanticModule.EMPTY_ARRAY );
 116    }
 117   
 118  0 public ClassLoader getSemanticModuleClassLoader()
 119    {
 120  0 return this.classLoader;
 121    }
 122    }