You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@felix.apache.org by pa...@apache.org on 2008/03/05 13:50:10 UTC
svn commit: r633836 -
/felix/trunk/framework/src/main/java/org/apache/felix/framework/ExtensionManager.java
Author: pauls
Date: Wed Mar 5 04:50:05 2008
New Revision: 633836
URL: http://svn.apache.org/viewvc?rev=633836&view=rev
Log:
The extensionmanager creates a classcastexception if more then framework is around and both have extensions installed. This fixes the issue.
Modified:
felix/trunk/framework/src/main/java/org/apache/felix/framework/ExtensionManager.java
Modified: felix/trunk/framework/src/main/java/org/apache/felix/framework/ExtensionManager.java
URL: http://svn.apache.org/viewvc/felix/trunk/framework/src/main/java/org/apache/felix/framework/ExtensionManager.java?rev=633836&r1=633835&r2=633836&view=diff
==============================================================================
--- felix/trunk/framework/src/main/java/org/apache/felix/framework/ExtensionManager.java (original)
+++ felix/trunk/framework/src/main/java/org/apache/felix/framework/ExtensionManager.java Wed Mar 5 04:50:05 2008
@@ -227,7 +227,7 @@
new AdminPermission(bundle, AdminPermission.EXTENSIONLIFECYCLE));
}
- if (!bundle.getInfo().getProtectionDomain().implies(new AllPermission()))
+ if (!((BundleProtectionDomain) bundle.getInfo().getProtectionDomain()).impliesDirect(new AllPermission()))
{
throw new SecurityException("Extension Bundles must have AllPermission");
}
@@ -577,8 +577,12 @@
for (Iterator iter = m_sourceToExtensions.values().iterator(); iter.hasNext();)
{
- Bundle bundle = (Bundle) iter.next();
- _add(bundle.getSymbolicName(), bundle);
+ List extensions = (List) iter.next();
+ for (Iterator extIter = extensions.iterator(); extIter.hasNext();)
+ {
+ Bundle bundle = (Bundle) extIter.next();
+ _add(bundle.getSymbolicName(), bundle);
+ }
}
}