1 | |
|
2 | |
|
3 | |
|
4 | |
|
5 | |
|
6 | |
|
7 | |
|
8 | |
|
9 | |
|
10 | |
|
11 | |
|
12 | |
|
13 | |
|
14 | |
|
15 | |
|
16 | |
package org.kuali.rice.core.framework.resourceloader; |
17 | |
|
18 | |
import org.kuali.rice.core.api.lifecycle.Lifecycle; |
19 | |
import org.kuali.rice.core.api.reflect.ObjectDefinition; |
20 | |
import org.kuali.rice.core.api.resourceloader.ResourceLoader; |
21 | |
import org.kuali.rice.core.api.resourceloader.ResourceLoaderContainer; |
22 | |
import org.kuali.rice.core.api.resourceloader.ServiceLocator; |
23 | |
import org.kuali.rice.core.api.util.ClassLoaderUtils; |
24 | |
|
25 | |
import javax.xml.namespace.QName; |
26 | |
|
27 | |
|
28 | |
|
29 | |
|
30 | |
|
31 | |
|
32 | |
|
33 | |
public class BaseResourceLoader extends ResourceLoaderContainer implements ResourceLoader { |
34 | |
|
35 | 0 | protected static final org.apache.log4j.Logger LOG = org.apache.log4j.Logger.getLogger(BaseResourceLoader.class); |
36 | |
|
37 | |
private ServiceLocator serviceLocator; |
38 | |
|
39 | |
private ClassLoader classLoader; |
40 | |
|
41 | 0 | private boolean postProcessContainer = true; |
42 | |
|
43 | |
public BaseResourceLoader(QName name, ClassLoader classLoader) { |
44 | 0 | this(name, classLoader, null); |
45 | 0 | } |
46 | |
|
47 | |
public BaseResourceLoader(QName name) { |
48 | 0 | this(name, ClassLoaderUtils.getDefaultClassLoader()); |
49 | 0 | } |
50 | |
|
51 | |
public BaseResourceLoader(QName name, ServiceLocator serviceLocator) { |
52 | 0 | this(name, ClassLoaderUtils.getDefaultClassLoader(), serviceLocator); |
53 | 0 | } |
54 | |
|
55 | |
public BaseResourceLoader(QName name, ClassLoader classLoader, ServiceLocator serviceLocator) { |
56 | 0 | super(name); |
57 | 0 | this.classLoader = classLoader; |
58 | 0 | this.serviceLocator = serviceLocator; |
59 | 0 | } |
60 | |
|
61 | |
public Object getObject(ObjectDefinition objectDefinition) { |
62 | |
|
63 | |
|
64 | |
|
65 | 0 | if (getName().getNamespaceURI() == null || getName().getNamespaceURI().equals(objectDefinition.getApplicationId()) || |
66 | |
objectDefinition.getApplicationId() == null) { |
67 | 0 | Object object = ObjectDefinitionResolver.createObject(objectDefinition, this.classLoader, true); |
68 | 0 | if (object != null) { |
69 | 0 | return postProcessObject(objectDefinition, object); |
70 | |
} |
71 | |
} |
72 | 0 | Object superObject = super.getObject(objectDefinition); |
73 | 0 | return (isPostProcessContainer() ? postProcessObject(objectDefinition, superObject) : superObject); |
74 | |
} |
75 | |
|
76 | |
public Object getService(QName serviceName) { |
77 | 0 | if (LOG.isDebugEnabled()) { |
78 | 0 | LOG.debug("ResourceLoader " + getName() + " fetching service " + serviceName + getMemStatus()); |
79 | |
} |
80 | 0 | if (this.serviceLocator != null) { |
81 | 0 | if (LOG.isDebugEnabled()) { |
82 | 0 | LOG.debug("Using internal service locator to fetch service " + serviceName); |
83 | |
} |
84 | 0 | Object service = this.serviceLocator.getService(serviceName); |
85 | 0 | if (service != null) { |
86 | 0 | return postProcessService(serviceName, service); |
87 | |
} |
88 | |
} |
89 | 0 | if (LOG.isDebugEnabled()) { |
90 | 0 | LOG.debug("ResourceLoader " + getName() + " didn't find service differing to child resource loaders "); |
91 | |
} |
92 | 0 | Object superService = super.getService(serviceName); |
93 | 0 | return (isPostProcessContainer() ? postProcessService(serviceName, superService) : superService); |
94 | |
} |
95 | |
|
96 | |
public void start() throws Exception { |
97 | 0 | if (this.classLoader instanceof Lifecycle) { |
98 | 0 | ((Lifecycle)this.classLoader).start(); |
99 | |
} |
100 | 0 | if (this.serviceLocator != null) { |
101 | 0 | LOG.info("Starting ResourceLoader " + this.getName()); |
102 | 0 | this.serviceLocator.start(); |
103 | |
} |
104 | 0 | super.start(); |
105 | 0 | } |
106 | |
|
107 | |
public void stop() throws Exception { |
108 | 0 | super.stop(); |
109 | 0 | if (this.serviceLocator != null) { |
110 | 0 | LOG.info("Stopping ResourceLoader " + this.getName()); |
111 | 0 | this.serviceLocator.stop(); |
112 | |
} |
113 | 0 | if (this.classLoader instanceof Lifecycle) { |
114 | 0 | ((Lifecycle) this.classLoader).stop(); |
115 | |
} |
116 | 0 | this.classLoader = null; |
117 | 0 | this.serviceLocator = null; |
118 | 0 | } |
119 | |
|
120 | |
public ClassLoader getClassLoader() { |
121 | 0 | return this.classLoader; |
122 | |
} |
123 | |
|
124 | |
public void setClassLoader(ClassLoader classLoader) { |
125 | 0 | this.classLoader = classLoader; |
126 | 0 | } |
127 | |
|
128 | |
protected Object postProcessObject(ObjectDefinition definition, Object object) { |
129 | 0 | return object; |
130 | |
} |
131 | |
|
132 | |
protected Object postProcessService(QName serviceName, Object service) { |
133 | 0 | return service; |
134 | |
} |
135 | |
|
136 | |
public boolean isPostProcessContainer() { |
137 | 0 | return postProcessContainer; |
138 | |
} |
139 | |
|
140 | |
public void setPostProcessContainer(boolean postProcessContainer) { |
141 | 0 | this.postProcessContainer = postProcessContainer; |
142 | 0 | } |
143 | |
|
144 | |
public String getContents(String indent, boolean servicePerLine) { |
145 | 0 | String contents = indent + this + "\n"; |
146 | |
|
147 | 0 | if (this.serviceLocator != null) { |
148 | 0 | contents += this.serviceLocator.getContents(indent + "+++", servicePerLine); |
149 | |
} |
150 | |
|
151 | 0 | for (ResourceLoader resourceLoader : this.getResourceLoaders()) { |
152 | 0 | contents += resourceLoader.getContents(indent + "+++", servicePerLine); |
153 | |
} |
154 | |
|
155 | 0 | return contents; |
156 | |
} |
157 | |
|
158 | |
private String getMemStatus() { |
159 | 0 | return "\n############################################################## \n" + "# " + dumpMemory() + "\n##############################################################\n"; |
160 | |
} |
161 | |
|
162 | |
private String dumpMemory() { |
163 | 0 | long total = Runtime.getRuntime().totalMemory() / 1024; |
164 | 0 | long free = Runtime.getRuntime().freeMemory() / 1024; |
165 | 0 | long max = Runtime.getRuntime().maxMemory() / 1024; |
166 | 0 | return "[Memory] max: " + max + "K, total: " + total + "K, free: " + free + "K, used: " + (total - free) + "K"; |
167 | |
} |
168 | |
|
169 | |
public ServiceLocator getServiceLocator() { |
170 | 0 | return this.serviceLocator; |
171 | |
} |
172 | |
} |