aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormwebster <mwebster>2006-07-27 09:25:50 +0000
committermwebster <mwebster>2006-07-27 09:25:50 +0000
commit397a19d441eaf7fdc67e841232b410358b48ba11 (patch)
treea67e0abd10469f848e5ad8eca9cd853a72623930
parentcb812785a69a69f6eaa70ce959ea72c84062daa0 (diff)
downloadaspectj-397a19d441eaf7fdc67e841232b410358b48ba11.tar.gz
aspectj-397a19d441eaf7fdc67e841232b410358b48ba11.zip
Bug 151182 "NPE in BcelWeaver using LTW" (synchronize(loader) for adaptor create, initialize and weave)
-rw-r--r--loadtime/src/org/aspectj/weaver/loadtime/Aj.java14
1 files changed, 8 insertions, 6 deletions
diff --git a/loadtime/src/org/aspectj/weaver/loadtime/Aj.java b/loadtime/src/org/aspectj/weaver/loadtime/Aj.java
index 33398f0c5..43de84ef1 100644
--- a/loadtime/src/org/aspectj/weaver/loadtime/Aj.java
+++ b/loadtime/src/org/aspectj/weaver/loadtime/Aj.java
@@ -67,12 +67,14 @@ public class Aj implements ClassPreProcessor {
}
try {
- WeavingAdaptor weavingAdaptor = WeaverContainer.getWeaver(loader, weavingContext);
- if (weavingAdaptor == null) {
- if (trace.isTraceEnabled()) trace.exit("preProcess",bytes);
- return bytes;
- }
- return weavingAdaptor.weaveClass(className, bytes);
+ synchronized (loader) {
+ WeavingAdaptor weavingAdaptor = WeaverContainer.getWeaver(loader, weavingContext);
+ if (weavingAdaptor == null) {
+ if (trace.isTraceEnabled()) trace.exit("preProcess",bytes);
+ return bytes;
+ }
+ return weavingAdaptor.weaveClass(className, bytes);
+ }
} catch (Exception t) {
trace.error("preProcess",t);
//FIXME AV wondering if we should have the option to fail (throw runtime exception) here