Class IClassLoader

    • Field Detail

      • ANNO_java_lang_Override

        public IClass ANNO_java_lang_Override
        Representation of the Override annotation.
      • TYPE_java_lang_AssertionError

        public IClass TYPE_java_lang_AssertionError
        Representation of the AssertionError type.
      • TYPE_java_lang_Boolean

        public IClass TYPE_java_lang_Boolean
        Representation of the Boolean type.
      • TYPE_java_lang_Byte

        public IClass TYPE_java_lang_Byte
        Representation of the Byte type.
      • TYPE_java_lang_Character

        public IClass TYPE_java_lang_Character
        Representation of the Character type.
      • TYPE_java_lang_Class

        public IClass TYPE_java_lang_Class
        Representation of the Class type.
      • TYPE_java_lang_Cloneable

        public IClass TYPE_java_lang_Cloneable
        Representation of the Cloneable type.
      • TYPE_java_lang_Double

        public IClass TYPE_java_lang_Double
        Representation of the Double type.
      • TYPE_java_lang_Exception

        public IClass TYPE_java_lang_Exception
        Representation of the Exception type.
      • TYPE_java_lang_Error

        public IClass TYPE_java_lang_Error
        Representation of the Error type.
      • TYPE_java_lang_Float

        public IClass TYPE_java_lang_Float
        Representation of the Float type.
      • TYPE_java_lang_Integer

        public IClass TYPE_java_lang_Integer
        Representation of the Integer type.
      • TYPE_java_lang_Iterable

        public IClass TYPE_java_lang_Iterable
        Representation of the Iterable type.
      • TYPE_java_lang_Long

        public IClass TYPE_java_lang_Long
        Representation of the Long type.
      • TYPE_java_lang_Object

        public IClass TYPE_java_lang_Object
        Representation of the Object type.
      • TYPE_java_lang_RuntimeException

        public IClass TYPE_java_lang_RuntimeException
        Representation of the RuntimeException type.
      • TYPE_java_lang_Short

        public IClass TYPE_java_lang_Short
        Representation of the Short type.
      • TYPE_java_lang_String

        public IClass TYPE_java_lang_String
        Representation of the String type.
      • TYPE_java_lang_StringBuilder

        public IClass TYPE_java_lang_StringBuilder
        Representation of the StringBuilder type.
      • TYPE_java_lang_Throwable

        public IClass TYPE_java_lang_Throwable
        Representation of the Throwable type.
      • TYPE_java_io_Serializable

        public IClass TYPE_java_io_Serializable
        Representation of the Serializable type.
      • TYPE_java_util_Iterator

        public IClass TYPE_java_util_Iterator
        Representation of the Iterator type.
    • Constructor Detail

      • IClassLoader

        public IClassLoader​(IClassLoader optionalParentIClassLoader)
    • Method Detail

      • postConstruct

        protected final void postConstruct()
        This method must be called by the constructor of the directly derived class. (The reason being is that this method invokes abstract loadIClass(String) which will not work until the implementing class is constructed.)
      • findIClass

        protected abstract IClass findIClass​(String descriptor)
                                      throws ClassNotFoundException
        Find a new IClass by descriptor; return null if a class for that descriptor could not be found.

        Similar ClassLoader.findClass(java.lang.String), this method must

        The format of a descriptor is defined in JVMS 4.3.2. Typical descriptors are:

        • I (Integer)
        • Lpkg1/pkg2/Cls; (Class declared in package)
        • Lpkg1/pkg2/Outer$Inner; Member class
        Notice that this method is never called for array types.

        Notice that this method is never called from more than one thread at a time. In other words, implementations of this method need not be synchronized.

        Returns:
        null if a class with that descriptor could not be found
        Throws:
        ClassNotFoundException - if an exception was raised while loading the class
      • createJavacLikePathIClassLoader

        public static IClassLoader createJavacLikePathIClassLoader​(File[] optionalBootClassPath,
                                                                   File[] optionalExtDirs,
                                                                   File[] classPath)
        Create an IClassLoader that looks for classes in the given "boot class path", then in the given "extension directories", and then in the given "class path".

        The default for the optionalBootClassPath is the path defined in the system property "sun.boot.class.path", and the default for the optionalExtensionDirs is the path defined in the "java.ext.dirs" system property.