< prev index next >

src/share/vm/classfile/classLoaderExt.hpp

Print this page




  32 class ClassListParser;
  33 
  34 class ClassLoaderExt: public ClassLoader { // AllStatic
  35 public:
  36 
  37   class Context {
  38     const char* _file_name;
  39   public:
  40     Context(const char* class_name, const char* file_name, TRAPS) {
  41       _file_name = file_name;
  42     }
  43 
  44     bool check(const ClassFileStream* stream, const int classpath_index) {
  45       return true;
  46     }
  47 
  48     bool should_verify(int classpath_index) {
  49       return false;
  50     }
  51 
  52     instanceKlassHandle record_result(Symbol* class_name,
  53                                       ClassPathEntry* e,
  54                                       const s2 classpath_index,
  55                                       instanceKlassHandle result, TRAPS) {
  56       if (ClassLoader::add_package(_file_name, classpath_index, THREAD)) {
  57 #if INCLUDE_CDS
  58         if (DumpSharedSpaces) {
  59           s2 classloader_type = ClassLoader::classloader_type(
  60                           class_name, e, classpath_index, CHECK_(result));
  61           result->set_shared_classpath_index(classpath_index);
  62           result->set_class_loader_type(classloader_type);
  63         }
  64 #endif
  65         return result;
  66       } else {
  67         return instanceKlassHandle(); // NULL
  68       }
  69     }
  70   };
  71 
  72 
  73   static void add_class_path_entry(const char* path, bool check_for_duplicates,
  74                                    ClassPathEntry* new_entry) {
  75     ClassLoader::add_to_list(new_entry);
  76   }
  77   static void append_boot_classpath(ClassPathEntry* new_entry) {
  78     ClassLoader::add_to_list(new_entry);
  79   }
  80   static void setup_search_paths() {}
  81   static bool is_boot_classpath(int classpath_index) {
  82    return true;
  83  }
  84   static Klass* load_one_class(ClassListParser* parser, TRAPS);
  85 };
  86 
  87 #endif // SHARE_VM_CLASSFILE_CLASSLOADEREXT_HPP


  32 class ClassListParser;
  33 
  34 class ClassLoaderExt: public ClassLoader { // AllStatic
  35 public:
  36 
  37   class Context {
  38     const char* _file_name;
  39   public:
  40     Context(const char* class_name, const char* file_name, TRAPS) {
  41       _file_name = file_name;
  42     }
  43 
  44     bool check(const ClassFileStream* stream, const int classpath_index) {
  45       return true;
  46     }
  47 
  48     bool should_verify(int classpath_index) {
  49       return false;
  50     }
  51 
  52     InstanceKlass* record_result(Symbol* class_name,
  53                                  ClassPathEntry* e,
  54                                  const s2 classpath_index,
  55                                  InstanceKlass* result, TRAPS) {
  56       if (ClassLoader::add_package(_file_name, classpath_index, THREAD)) {
  57 #if INCLUDE_CDS
  58         if (DumpSharedSpaces) {
  59           s2 classloader_type = ClassLoader::classloader_type(
  60                           class_name, e, classpath_index, CHECK_(result));
  61           result->set_shared_classpath_index(classpath_index);
  62           result->set_class_loader_type(classloader_type);
  63         }
  64 #endif
  65         return result;
  66       } else {
  67         return NULL;
  68       }
  69     }
  70   };
  71 
  72 
  73   static void add_class_path_entry(const char* path, bool check_for_duplicates,
  74                                    ClassPathEntry* new_entry) {
  75     ClassLoader::add_to_list(new_entry);
  76   }
  77   static void append_boot_classpath(ClassPathEntry* new_entry) {
  78     ClassLoader::add_to_list(new_entry);
  79   }
  80   static void setup_search_paths() {}
  81   static bool is_boot_classpath(int classpath_index) {
  82    return true;
  83  }
  84   static Klass* load_one_class(ClassListParser* parser, TRAPS);
  85 };
  86 
  87 #endif // SHARE_VM_CLASSFILE_CLASSLOADEREXT_HPP
< prev index next >