You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@servicemix.apache.org by gn...@apache.org on 2008/01/21 12:42:30 UTC

svn commit: r613853 - /servicemix/smx4/kernel/trunk/gshell/gshell-features/src/main/java/org/apache/servicemix/gshell/features/internal/CommandProxy.java

Author: gnodet
Date: Mon Jan 21 03:42:29 2008
New Revision: 613853

URL: http://svn.apache.org/viewvc?rev=613853&view=rev
Log:
Fix features installation

Modified:
    servicemix/smx4/kernel/trunk/gshell/gshell-features/src/main/java/org/apache/servicemix/gshell/features/internal/CommandProxy.java

Modified: servicemix/smx4/kernel/trunk/gshell/gshell-features/src/main/java/org/apache/servicemix/gshell/features/internal/CommandProxy.java
URL: http://svn.apache.org/viewvc/servicemix/smx4/kernel/trunk/gshell/gshell-features/src/main/java/org/apache/servicemix/gshell/features/internal/CommandProxy.java?rev=613853&r1=613852&r2=613853&view=diff
==============================================================================
--- servicemix/smx4/kernel/trunk/gshell/gshell-features/src/main/java/org/apache/servicemix/gshell/features/internal/CommandProxy.java (original)
+++ servicemix/smx4/kernel/trunk/gshell/gshell-features/src/main/java/org/apache/servicemix/gshell/features/internal/CommandProxy.java Mon Jan 21 03:42:29 2008
@@ -19,12 +19,14 @@
 import java.io.IOException;
 import java.io.Reader;
 import java.util.Arrays;
+import java.util.List;
 import java.util.Properties;
 
 import org.apache.geronimo.gshell.command.Command;
 import org.apache.geronimo.gshell.obr.ObrCommandSupport;
 import org.apache.geronimo.gshell.support.OsgiCommandSupport;
 import org.apache.servicemix.gshell.features.Feature;
+import org.osgi.framework.Bundle;
 import org.osgi.framework.BundleContext;
 import org.osgi.framework.ServiceRegistration;
 import org.osgi.service.obr.RepositoryAdmin;
@@ -67,7 +69,32 @@
         if (c == 'y' || c == 'Y') {
             io.out.println("Installing feature.  Please wait...");
             registration.unregister();
-            doDeploy(admin, Arrays.asList(feature.getBundles()), true);
+            deploy(admin);
+        }
+    }
+
+    protected void deploy(RepositoryAdmin admin) throws Exception {
+        List<String> bundles = Arrays.asList(feature.getBundles());
+        int idx0 = -1;
+        int idx1 = -1;
+        while (++idx0 < bundles.size()) {
+            if (bundles.get(idx0).startsWith("obr:")) {
+                if (idx1 < 0) {
+                    idx1 = idx0;
+                }
+                bundles.set(idx0, bundles.get(idx0).substring("obr:".length()));
+            } else {
+                if (idx1 >= 0) {
+                    doDeploy(admin, bundles.subList(idx1, idx0), true);
+                    idx1 = -1;
+                } else {
+                    Bundle bundle = getBundleContext().installBundle(bundles.get(idx0), null);
+                    bundle.start();
+                }
+            }
+        }
+        if (idx1 >= 0) {
+            doDeploy(admin, bundles.subList(idx1, idx0), true);
         }
     }