dain        2005/02/08 21:07:54

  Modified:    modules/core/src/java/org/openejb ContainerIndex.java
  Added:       modules/core/src/java/org/openejb
                        ContainerNotFoundException.java
  Log:

  Changed ContainerIndex to throw ContainerNotFoundException when a container 
looked up by name is not found.
  The ContainerNorFoundException contains the container name which is a lot 
more readable the "-1"
  
  Revision  Changes    Path
  1.15      +7 -4      
openejb/modules/core/src/java/org/openejb/ContainerIndex.java
  
  Index: ContainerIndex.java
  ===================================================================
  RCS file: 
/home/projects/openejb/scm/openejb/modules/core/src/java/org/openejb/ContainerIndex.java,v
  retrieving revision 1.14
  retrieving revision 1.15
  diff -u -r1.14 -r1.15
  --- ContainerIndex.java       3 Feb 2005 03:09:52 -0000       1.14
  +++ ContainerIndex.java       9 Feb 2005 02:07:53 -0000       1.15
  @@ -189,9 +189,12 @@
           return (index == null) ? -1 : index.intValue();
       }
   
  -    public synchronized EJBContainer getContainer(String containerID) {
  -        //TODO return an informative exception if there is no such 
containerId.  Currently returns ArrayIndexOutOfBoundsException(-1)
  -        return getContainer(getContainerIndex(containerID));
  +    public synchronized EJBContainer getContainer(String containerID) throws 
ContainerNotFoundException {
  +        int containerIndex = getContainerIndex(containerID);
  +        if (containerIndex < 0) {
  +            throw new ContainerNotFoundException(containerID);
  +        }
  +        return getContainer(containerIndex);
       }
   
       public synchronized EJBContainer getContainer(Integer index) {
  
  
  
  1.1                  
openejb/modules/core/src/java/org/openejb/ContainerNotFoundException.java
  
  Index: ContainerNotFoundException.java
  ===================================================================
  /* ====================================================================
   * Redistribution and use of this software and associated documentation
   * ("Software"), with or without modification, are permitted provided
   * that the following conditions are met:
   *
   * 1. Redistributions of source code must retain copyright
   *    statements and notices.  Redistributions must also contain a
   *    copy of this document.
   *
   * 2. Redistributions in binary form must reproduce this list of
   *    conditions and the following disclaimer in the documentation
   *    and/or other materials provided with the distribution.
   *
   * 3. The name "OpenEJB" must not be used to endorse or promote
   *    products derived from this Software without prior written
   *    permission of The OpenEJB Group.  For written permission,
   *    please contact [EMAIL PROTECTED]
   *
   * 4. Products derived from this Software may not be called "OpenEJB"
   *    nor may "OpenEJB" appear in their names without prior written
   *    permission of The OpenEJB Group. OpenEJB is a registered
   *    trademark of The OpenEJB Group.
   *
   * 5. Due credit should be given to the OpenEJB Project
   *    (http://openejb.org/).
   *
   * THIS SOFTWARE IS PROVIDED BY THE OPENEJB GROUP AND CONTRIBUTORS
   * ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT
   * NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
   * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL
   * THE OPENEJB GROUP OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
   * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
   * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
   * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
   * OF THE POSSIBILITY OF SUCH DAMAGE.
   *
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the OpenEJB Project.  For more information
   * please see <http://openejb.org/>.
   *
   * ====================================================================
   */
  package org.openejb;
  
  /**
   * @version $Revision: 1.1 $ $Date: 2005/02/09 02:07:54 $
   */
  public class ContainerNotFoundException extends Exception {
      public ContainerNotFoundException() {
          super();
      }
  
      public ContainerNotFoundException(String message) {
          super(message);
      }
  
      public ContainerNotFoundException(String message, Throwable cause) {
          super(message, cause);
      }
  
      public ContainerNotFoundException(Throwable cause) {
          super(cause);
      }
  }
  
  
  

Reply via email to