01: /**
02: * JOnAS: Java(TM) Open Application Server
03: * Copyright (C) 1999-2007 Bull S.A.S.
04: * Contact: jonas-team@objectweb.org
05: *
06: * This library is free software; you can redistribute it and/or
07: * modify it under the terms of the GNU Lesser General Public
08: * License as published by the Free Software Foundation; either
09: * version 2.1 of the License, or any later version.
10: *
11: * This library is distributed in the hope that it will be useful,
12: * but WITHOUT ANY WARRANTY; without even the implied warranty of
13: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14: * Lesser General Public License for more details.
15: *
16: * You should have received a copy of the GNU Lesser General Public
17: * License along with this library; if not, write to the Free Software
18: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19: * USA
20: *
21: * --------------------------------------------------------------------------
22: * $Id: ClientClassLoader.java 10094 2007-03-23 16:15:39Z sauthieg $
23: * --------------------------------------------------------------------------
24: */package org.objectweb.jonas_lib.loader;
25:
26: import java.io.IOException;
27: import java.net.URL;
28:
29: /**
30: * ClassLoader used for loading Client classes and resources
31: *
32: * @author Guillaume Sauthier
33: */
34: public class ClientClassLoader extends AbsModuleClassLoader {
35:
36: /** classes are located in the module root */
37: private static final String CLASSES_DIRECTORY = "";
38:
39: /** WSDL files are located in META-INF/wsdl directory */
40: private static final String WSDL_DIRECTORY = "META-INF/wsdl/";
41:
42: /**
43: * Create a new ClientClassLoader with default parent ClassLoader
44: *
45: * @param module an URL of Client files
46: *
47: * @throws IOException if creation fails
48: */
49: public ClientClassLoader(URL module) throws IOException {
50: super (new URL[] { module });
51: }
52:
53: /**
54: * Create a new ClientClassLoader with specified parent ClassLoader
55: *
56: * @param module an URL of Client files
57: * @param parent the parent ClassLoader to use
58: *
59: * @throws IOException if creation fails
60: */
61: public ClientClassLoader(URL module, ClassLoader parent)
62: throws IOException {
63: super (new URL[] { module }, parent);
64: }
65:
66: /**
67: * Create a new ClientClassLoader with specified parent ClassLoader
68: *
69: * @param modules an URL[] of Client files + dependencies
70: * @param parent the parent ClassLoader to use
71: *
72: * @throws IOException if creation fails
73: */
74: public ClientClassLoader(URL[] modules, ClassLoader parent)
75: throws IOException {
76: super (modules, parent);
77: }
78:
79: /**
80: * Add the directory and the content of
81: * META-INF/wsdl/ in the ClassLoader.
82: *
83: * @throws IOException When initialisation fails.
84: */
85: protected void init() throws IOException {
86: super.init();
87: addInRepository(CLASSES_DIRECTORY);
88: addContentInRepository(WSDL_DIRECTORY);
89: }
90: }
|