You are viewing a plain text version of this content. The canonical link for it is here.
Posted to cvs@avalon.apache.org by cz...@apache.org on 2003/01/10 13:54:37 UTC

cvs commit: jakarta-avalon-excalibur/sourceresolve/src/java/org/apache/excalibur/source/impl/validity DeferredValidity.java DeferredAggregatedValidity.java AbstractAggregatedValidity.java AggregatedValidity.java

cziegeler    2003/01/10 04:54:37

  Modified:    sourceresolve/src/java/org/apache/excalibur/source/impl/validity
                        AggregatedValidity.java
  Added:       sourceresolve/src/java/org/apache/excalibur/source/impl/validity
                        DeferredValidity.java
                        DeferredAggregatedValidity.java
                        AbstractAggregatedValidity.java
  Log:
  Adding deferred source validities as a try
  
  Revision  Changes    Path
  1.5       +2 -19     jakarta-avalon-excalibur/sourceresolve/src/java/org/apache/excalibur/source/impl/validity/AggregatedValidity.java
  
  Index: AggregatedValidity.java
  ===================================================================
  RCS file: /home/cvs/jakarta-avalon-excalibur/sourceresolve/src/java/org/apache/excalibur/source/impl/validity/AggregatedValidity.java,v
  retrieving revision 1.4
  retrieving revision 1.5
  diff -u -r1.4 -r1.5
  --- AggregatedValidity.java	15 Dec 2002 11:56:48 -0000	1.4
  +++ AggregatedValidity.java	10 Jan 2003 12:54:37 -0000	1.5
  @@ -54,7 +54,6 @@
    */
   package org.apache.excalibur.source.impl.validity;
   
  -import java.util.ArrayList;
   import java.util.Iterator;
   import java.util.List;
   
  @@ -67,15 +66,9 @@
    * @version CVS $Revision$ $Date$
    */
   public final class AggregatedValidity
  +    extends AbstractAggregatedValidity
       implements SourceValidity
   {
  -    private final List m_list = new ArrayList();
  -
  -    public void add( final SourceValidity validity )
  -    {
  -        m_list.add( validity );
  -    }
  -
       /**
        * Check if the component is still valid.
        * If <code>0</code> is returned the isValid(SourceValidity) must be
  @@ -121,15 +114,5 @@
           return false;
       }
   
  -    public String toString()
  -    {
  -        final StringBuffer sb = new StringBuffer( "SourceValidity " );
  -        for( final Iterator i = m_list.iterator(); i.hasNext(); )
  -        {
  -            sb.append( i.next() );
  -            if( i.hasNext() ) sb.append( ':' );
  -        }
  -        return sb.toString();
  -    }
   }
   
  
  
  
  1.1                  jakarta-avalon-excalibur/sourceresolve/src/java/org/apache/excalibur/source/impl/validity/DeferredValidity.java
  
  Index: DeferredValidity.java
  ===================================================================
  /* ====================================================================
   * The Apache Software License, Version 1.1
   *
   * Copyright (c) 2002 The Apache Software Foundation. All rights
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:
   *    "This product includes software developed by the
   *    Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software
   *    itself, if and wherever such third-party acknowledgments
   *    normally appear.
   *
   * 4. The names "Jakarta", "Avalon", and "Apache Software Foundation"
   *    must not be used to endorse or promote products derived from this
   *    software without prior written permission. For written
   *    permission, please contact apache@apache.org.
   *
   * 5. Products derived from this software may not be called "Apache",
   *    nor may "Apache" appear in their name, without prior written
   *    permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``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 APACHE SOFTWARE FOUNDATION 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 Apache Software Foundation. For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  package org.apache.excalibur.source.impl.validity;
  
  import org.apache.excalibur.source.SourceValidity;
  
  
  /**
   * This object delivers a validity object if required. 
   * Used by the {@link DeferredAggregatedValidity}
   *
   * @author <a href="mailto:cziegeler@apache.org">Carsten Ziegeler</a>
   * @version CVS $Revision: 1.1 $ $Date: 2003/01/10 12:54:37 $
   */
  public interface DeferredValidity {
  
      /** 
       * Return the validity
       */
      SourceValidity getValidity();
  }
  
  
  
  1.1                  jakarta-avalon-excalibur/sourceresolve/src/java/org/apache/excalibur/source/impl/validity/DeferredAggregatedValidity.java
  
  Index: DeferredAggregatedValidity.java
  ===================================================================
  /* ====================================================================
   * The Apache Software License, Version 1.1
   *
   * Copyright (c) 2002 The Apache Software Foundation. All rights
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:
   *    "This product includes software developed by the
   *    Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software
   *    itself, if and wherever such third-party acknowledgments
   *    normally appear.
   *
   * 4. The names "Jakarta", "Avalon", and "Apache Software Foundation"
   *    must not be used to endorse or promote products derived from this
   *    software without prior written permission. For written
   *    permission, please contact apache@apache.org.
   *
   * 5. Products derived from this software may not be called "Apache",
   *    nor may "Apache" appear in their name, without prior written
   *    permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``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 APACHE SOFTWARE FOUNDATION 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 Apache Software Foundation. For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  package org.apache.excalibur.source.impl.validity;
  
  import java.io.IOException;
  import java.util.ArrayList;
  import java.util.Iterator;
  import java.util.ListIterator;
  
  import org.apache.excalibur.source.SourceValidity;
  
  /**
   * A validation object using a List.
   * This validity object does the same as the {@link AggregatedValidity}
   * object, but the contained validity objects are only fetched when
   * required.
   *
   * @author <a href="mailto:cziegeler@apache.org">Carsten Ziegeler</a>
   * @version CVS $Revision: 1.1 $ $Date: 2003/01/10 12:54:37 $
   */
  public final class DeferredAggregatedValidity
          extends AbstractAggregatedValidity
      implements SourceValidity
  {
  
      public void add( final DeferredValidity validity )
      {
          m_list.add( validity );
      }
  
      /**
       * Check if the component is still valid.
       * If <code>0</code> is returned the isValid(SourceValidity) must be
       * called afterwards!
       * If -1 is returned, the component is not valid anymore and if +1
       * is returnd, the component is valid.
       */
      public int isValid()
      {
          for( final ListIterator i = m_list.listIterator(); i.hasNext(); )
          {
              final Object o = i.next();
              final SourceValidity validity;
              if (o instanceof SourceValidity) {
                  validity = (SourceValidity)o;
              } else {
                  validity = ((DeferredValidity)o).getValidity();
                  i.set(validity);
              }
              final int v = validity.isValid();
              if( v < 1 )
              {
                  return v;
              }
          }
          return 1;
      }
  
      public boolean isValid( final SourceValidity validity )
      {
          AbstractAggregatedValidity aggregatedValidity = null;
          
          if (validity instanceof AbstractAggregatedValidity) 
          {
              aggregatedValidity = (AbstractAggregatedValidity)validity;
          }
          
          if ( null != aggregatedValidity) 
          {
              ArrayList otherList = aggregatedValidity.m_list;
              if( m_list.size() != otherList.size() )
              {
                  return false;
              }
  
              for(int i=0; i < m_list.size(); i++) {
                  final SourceValidity srcA = this.getValidity(i);
                  if ( srcA.isValid() < 1) {
                      final SourceValidity srcB = aggregatedValidity.getValidity(i);
                      if( !srcA.isValid( srcB ) )
                      {
                          return false;
                      }
                  }
              }
              return true;
          }
          return false;
      }
  
      public String toString()
      {
          final StringBuffer sb = new StringBuffer( "SourceValidity " );
          for( final Iterator i = m_list.iterator(); i.hasNext(); )
          {
              sb.append( i.next() );
              if( i.hasNext() ) sb.append( ':' );
          }
          return sb.toString();
      }
      
      SourceValidity getValidity(final int index) 
      {
          final Object o = m_list.get(index);
          final SourceValidity validity;
          if (o instanceof SourceValidity) {
              validity = (SourceValidity)o;
          } else {
              validity = ((DeferredValidity)o).getValidity();
              m_list.set(index, validity);
          }
          return validity;
      }
      
      private void writeObject(java.io.ObjectOutputStream out)
           throws IOException
      {
          // resolve all deferred source validities first
          for(int i=0; i<m_list.size();i++) {
              this.getValidity(i);
          }
          out.defaultWriteObject();
      }
  
  }
  
  
  
  
  1.1                  jakarta-avalon-excalibur/sourceresolve/src/java/org/apache/excalibur/source/impl/validity/AbstractAggregatedValidity.java
  
  Index: AbstractAggregatedValidity.java
  ===================================================================
  /* ====================================================================
   * The Apache Software License, Version 1.1
   *
   * Copyright (c) 2002 The Apache Software Foundation. All rights
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:
   *    "This product includes software developed by the
   *    Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software
   *    itself, if and wherever such third-party acknowledgments
   *    normally appear.
   *
   * 4. The names "Jakarta", "Avalon", and "Apache Software Foundation"
   *    must not be used to endorse or promote products derived from this
   *    software without prior written permission. For written
   *    permission, please contact apache@apache.org.
   *
   * 5. Products derived from this software may not be called "Apache",
   *    nor may "Apache" appear in their name, without prior written
   *    permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``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 APACHE SOFTWARE FOUNDATION 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 Apache Software Foundation. For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  package org.apache.excalibur.source.impl.validity;
  
  import java.util.ArrayList;
  import java.util.Iterator;
  
  import org.apache.excalibur.source.SourceValidity;
  
  /**
   * The base class for the aggregation implementations
   *
   * @author <a href="mailto:cziegeler@apache.org">Carsten Ziegeler</a>
   * @version CVS $Revision: 1.1 $ $Date: 2003/01/10 12:54:37 $
   */
  public abstract class AbstractAggregatedValidity
      implements SourceValidity
  {
      final ArrayList m_list = new ArrayList();
  
      public void add( final SourceValidity validity )
      {
          m_list.add( validity );
      }
  
      public String toString()
      {
          final StringBuffer sb = new StringBuffer( "SourceValidity " );
          for( final Iterator i = m_list.iterator(); i.hasNext(); )
          {
              sb.append( i.next() );
              if( i.hasNext() ) sb.append( ':' );
          }
          return sb.toString();
      }
      
      SourceValidity getValidity(final int index) 
      {
          return (SourceValidity) m_list.get(index);
      }
      
  }
  
  

--
To unsubscribe, e-mail:   <ma...@jakarta.apache.org>
For additional commands, e-mail: <ma...@jakarta.apache.org>