Resolve a possible deadlock during system startup if system bundle stop is called from inside an activator.start method and the system bundle is still in the STARTNG state. The framework will now just throw an exception as a result of the stop call. As a side effect this makes it possible again to call System.exit inside an activator.start method while the framework is still in the STARTING state. However, the framework will not be shutdown when the jvm exits. (FELIX-1816, FELIX-1812)
git-svn-id: https://svn.apache.org/repos/asf/felix/trunk@831311 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/framework/src/main/java/org/apache/felix/framework/Felix.java b/framework/src/main/java/org/apache/felix/framework/Felix.java
index fa9a97e..a501b6a 100644
--- a/framework/src/main/java/org/apache/felix/framework/Felix.java
+++ b/framework/src/main/java/org/apache/felix/framework/Felix.java
@@ -761,6 +761,14 @@
AdminPermission.EXECUTE));
}
+ synchronized (m_bundleLock)
+ {
+ if ((getState() & (STARTING | STOPPING)) != 0)
+ {
+ throw new BundleException("Can't stop the system bundle while it is either starting or stopping.");
+ }
+ }
+
stopBundle(this, true);
}