Logo
Distributed Genetic Programming Framework
print print

File org.sfc.code.SharedInternalClassLoader.java

Here you can find all the information about the file org.sfc.code.SharedInternalClassLoader.java. You may explore it here or download it onto your local disk.
/*
 * Copyright (c) 2006 Thomas Weise
 * 
 * E-Mail           : tweise@gmx.de
 * Creation Date    : 2006-06-14 13:08:39
 * Original Filename: org.sfc.code.SharedInternalClassLoader.java
 * Version          : 1.0.0
 * Last modification: 2006-06-14
 *                by: Thomas Weise
 * 
 * License          : GNU LESSER GENERAL PUBLIC LICENSE
 *                    Version 2.1, February 1999
 *                    You should have received a copy of this license along
 *                    with this library; if not, write to the Free Software
 *                    Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 *                    MA 02111-1307, USA or download the license under
 *                    http://www.gnu.org/copyleft/lesser.html.
 *                    
 * Warranty         : This software is provided "as is" without any
 *                    warranty; without even the implied warranty of
 *                    merchantability or fitness for a particular purpose.
 *                    See the Gnu Lesser General Public License for more
 *                    details.
 */

 
package org.sfc.code;

import java.io.IOException;
import java.net.URL;
import java.util.Enumeration;

/**
 * The internally used shared class loader.
 *
 * @author Thomas Weise
 */

final class SharedInternalClassLoader extends BasicClassLoader<SharedSession>
  {
/**
 * <code>true</code> if recursion is enabled.
 */

  private volatile  boolean   m_rec;
    
/**
 * Create a new shared internal class loader.
 * @param p_owner The owning code session.
 */

  SharedInternalClassLoader(final SharedSession p_owner)
    {
    super(p_owner);
    }
  
/**
 * Finds the class with the specified binary name.
 * 
 * @param  p_name The binary name of the class
 *
 * @return  The resulting <tt>Class</tt> object
 *
 * @throws  ClassNotFoundException If the class could not be found
 */

  @Override
  protected final Class<?> findClass(final String p_name)
                                        throws ClassNotFoundException
    {
    Class<?> l_c;
    
    try
      {
      return super.findClass(p_name);
      }
    catch(ClassNotFoundException l_cne)
      {    
      if(this.m_rec)
        {
        l_c = this.m_owner.m_owner.find_class_except(p_name, this.m_owner);
        if(l_c != null) return l_c;
        }
      throw l_cne;
      }
    }
  
/**
 * Finds the class with the specified binary name non-recursively.
 * 
 * @param  p_name The binary name of the class
 *
 * @return  The resulting <tt>Class</tt> object
 *
 * @throws  ClassNotFoundException If the class could not be found
 */

  synchronized final Class<?> non_rec_load_class(final String p_name)
                                        throws ClassNotFoundException
    {
    this.m_rec = false;
    try
      {
      return super.loadClass(p_name, false);
      }
    finally
      {
      this.m_rec = true;
      }
    }
    
/**
 * Finds the resource with the given name. Class loader implementations
 * should override this method to specify where to find resources.  </p>
 *
 * @param  p_name
 *         The resource name
 *
 * @return  A <tt>URL</tt> object for reading the resource, or
 *          <tt>null</tt> if the resource could not be found
 *
 * @since  1.2
 */

  @Override
  public final URL findResource(final String p_name)
    {
    URL l_u;
    
    l_u = super.findResource(p_name);
    if(l_u != null) return l_u;
    
    if(this.m_rec)
      {
      return this.m_owner.m_owner.find_resource_except(p_name, this.m_owner);
      }
    
    return null;
    }
    
/**
 * Finds the resource with the specified name non-recursively.
 * 
 * @param  p_name The name of the resource.
 *
 * @return  The resource found, or <code>null</code> if no such resource
 *          exists.
 */

  synchronized final URL non_rec_get_res(final String p_name)
    {
    try
      {
      this.m_rec = false;
      return super.getResource(p_name);
      }
    finally
      {
      this.m_rec = true;
      }
    }
    
/**
 * Finds the resource with the given name.  A resource is some data
 * (images, audio, text, etc) that can be accessed by class code in a way
 * that is independent of the location of the code.
 *
 * <p> The name of a resource is a '<tt>/</tt>'-separated path name that
 * identifies the resource.
 *
 * <p> This method will first search the parent class loader for the
 * resource; if the parent is <tt>null</tt> the path of the class loader
 * built-in to the virtual machine is searched.  That failing, this method
 * will invoke {@link #findResource(String)} to find the resource.  </p>
 *
 * @param  p_name
 *         The resource name
 *
 * @return  A <tt>URL</tt> object for reading the resource, or
 *          <tt>null</tt> if the resource could not be found or the invoker
 *          doesn't have adequate  privileges to get the resource.
 */

  @Override
  public synchronized final URL getResource(final String p_name)
    {
    return super.getResource(p_name);
    }    
  
/**
 * Loads the class with the specified binary name.  
 *
 * @param  p_name  The <a href="#name">binary name</a> of the class.
 *
 * @param  p_resolve   If <tt>true</tt> then resolve the class.
 *
 * @return  The resulting <tt>Class</tt> object
 *
 * @throws  ClassNotFoundException
 *          If the class could not be found
 */

  @Override
  protected final synchronized Class<?> loadClass(
                                            final String  p_name,
                                            final boolean p_resolve)
                                            throws ClassNotFoundException
    {
    return super.loadClass(p_name, p_resolve);
    }
  
  
/**
 * Finds all the resources with the given name. A resource is some data
 * (images, audio, text, etc) that can be accessed by class code in a way
 * that is independent of the location of the code.
 *
 * <p>The name of a resource is a <tt>/</tt>-separated path name that
 * identifies the resource.
 *
 * <p> The search order is described in the documentation for {@link
 * #getResource(String)}.  </p>
 *
 * @param  p_name
 *         The resource name
 *
 * @return  An enumeration of {@link java.net.URL <tt>URL</tt>} objects for
 *          the resource.  If no resources could  be found, the enumeration
 *          will be empty.  Resources that the class loader doesn't have
 *          access to will not be in the enumeration.
 *
 * @throws  IOException
 *          If I/O errors occur
 *
 * @see  #findResources(String)
 */

  @Override
  public final  Enumeration<URL> getResources(final String p_name)
                                       throws IOException
    {    
    return this.m_owner.m_owner.get_resources(p_name);
    }
  }

File Information:

file name:SharedInternalClassLoader.java
package:org.sfc.code
qualified name:org.sfc.code.SharedInternalClassLoader.java
file type:Java Source File
download location:download http://dgpf.sourceforge.net/source/org/sfc/code/SharedInternalClassLoader.java
size:6.776 KB (6939 B)
uploaded: 2015-07-22 04:11:11 GMT+0000
last update: 2006-06-15 07:08:29 GMT+0000
last access: 2018-01-22 00:04:38 GMT+0000

statistics online since 2006-01-02.   RSS Feed
Contact us by sending an email to tweise@gmx.de to receive further information, to report errors, or to join our project.
All content on this site (http://dgpf.sourceforge.net/) is LGPL-licensed.
http://dgpf.sourceforge.net/scripts/source/source.php last modified at 2015-07-22 04:10:53 GMT+0000 served at 2018-01-22 00:04:38 GMT+0000.
Valid CSS Valid XHTML 1.1
Valid RSS SourceForge.net Logo