Author: cziegeler
Date: Sat Sep 19 09:08:41 2015
New Revision: 1703963

URL: http://svn.apache.org/viewvc?rev=1703963&view=rev
Log:
FELIX-5034 : Reduce and correct locking related to the hook registry

Modified:
    felix/trunk/framework/src/main/java/org/apache/felix/framework/Felix.java

Modified: 
felix/trunk/framework/src/main/java/org/apache/felix/framework/Felix.java
URL: 
http://svn.apache.org/viewvc/felix/trunk/framework/src/main/java/org/apache/felix/framework/Felix.java?rev=1703963&r1=1703962&r2=1703963&view=diff
==============================================================================
--- felix/trunk/framework/src/main/java/org/apache/felix/framework/Felix.java 
(original)
+++ felix/trunk/framework/src/main/java/org/apache/felix/framework/Felix.java 
Sat Sep 19 09:08:41 2015
@@ -3280,9 +3280,7 @@ public class Felix extends BundleImpl im
     Bundle[] getBundles(BundleContext bc)
     {
         Collection<Bundle> bundles = 
m_installedBundles[IDENTIFIER_MAP_IDX].values();
-        // If the requesting bundle is something other than the system bundle, 
return the shrunk
-        // collection of bundles. If it *is* the system bundle, it should 
receive the unfiltered bundles.
-        if ( !bundles.isEmpty() && bc.getBundle() != this )
+        if ( !bundles.isEmpty() )
         {
             Set<ServiceReference<org.osgi.framework.hooks.bundle.FindHook>> 
hooks =
                     
getHookRegistry().getHooks(org.osgi.framework.hooks.bundle.FindHook.class);
@@ -3309,6 +3307,11 @@ public class Felix extends BundleImpl im
                         }
                     }
                 }
+                if ( bc.getBundle() != this ) {
+                    // If the requesting bundle is something other than the 
system bundle, return the shrunk
+                    // collection of bundles. If it *is* the system bundle, it 
should receive the unfiltered bundles.
+                    bundles = shrunkBundles;
+                }
             }
         }
 


Reply via email to