/*
 * Copyright (c) 1998, 2007, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

/*
 * Licensed Materials - Property of IBM
 * RMI-IIOP v1.0
 * Copyright IBM Corp. 1998 1999  All Rights Reserved
 *
 */

package sun.rmi.rmic.iiop;

import java.util.Hashtable;
import java.io.File;
import java.io.FileInputStream;

DirectoryLoader is a simple ClassLoader which loads from a specified file system directory.
Author:Bryan Atsatt
/** * DirectoryLoader is a simple ClassLoader which loads from a specified * file system directory. * @author Bryan Atsatt */
public class DirectoryLoader extends ClassLoader { private Hashtable cache; private File root;
Constructor.
/** * Constructor. */
public DirectoryLoader (File rootDir) { cache = new Hashtable(); if (rootDir == null || !rootDir.isDirectory()) { throw new IllegalArgumentException(); } root = rootDir; } private DirectoryLoader () {}
Convenience version of loadClass which sets 'resolve' == true.
/** * Convenience version of loadClass which sets 'resolve' == true. */
public Class loadClass(String className) throws ClassNotFoundException { return loadClass(className, true); }
This is the required version of loadClass which is called both from loadClass above and from the internal function FindClassFromClass.
/** * This is the required version of loadClass which is called * both from loadClass above and from the internal function * FindClassFromClass. */
public synchronized Class loadClass(String className, boolean resolve) throws ClassNotFoundException { Class result; byte classData[]; // Do we already have it in the cache? result = (Class) cache.get(className); if (result == null) { // Nope, can we get if from the system class loader? try { result = super.findSystemClass(className); } catch (ClassNotFoundException e) { // No, so try loading it... classData = getClassFileData(className); if (classData == null) { throw new ClassNotFoundException(); } // Parse the class file data... result = defineClass(classData, 0, classData.length); if (result == null) { throw new ClassFormatError(); } // Resolve it... if (resolve) resolveClass(result); // Add to cache... cache.put(className, result); } } return result; }
Reurn a byte array containing the contents of the class file. Returns null if an exception occurs.
/** * Reurn a byte array containing the contents of the class file. Returns null * if an exception occurs. */
private byte[] getClassFileData (String className) { byte result[] = null; FileInputStream stream = null; // Get the file... File classFile = new File(root,className.replace('.',File.separatorChar) + ".class"); // Now get the bits... try { stream = new FileInputStream(classFile); result = new byte[stream.available()]; stream.read(result); } catch(ThreadDeath death) { throw death; } catch (Throwable e) { } finally { if (stream != null) { try { stream.close(); } catch(ThreadDeath death) { throw death; } catch (Throwable e) { } } } return result; } }