import org.argeo.api.init.RuntimeContext;
import org.argeo.api.init.RuntimeManager;
import org.argeo.init.logging.ThinLoggerFinder;
+import org.argeo.init.osgi.OsgiBoot;
import org.argeo.init.osgi.OsgiRuntimeContext;
import org.argeo.internal.init.InternalState;
-import org.osgi.framework.Bundle;
import org.osgi.framework.BundleContext;
-import org.osgi.framework.BundleException;
import org.osgi.framework.FrameworkEvent;
import org.osgi.framework.launch.Framework;
}
public void run() {
-// try {
-// for (Path p : Files.newDirectoryStream(Paths.get("/usr/local/lib/a2"), "*.so")) {
-// try {
-// System.load(p.toString());
-// } catch (UnsatisfiedLinkError e) {
-// e.printStackTrace();
-// }
-// }
-// } catch (IOException e) {
-// e.printStackTrace();
-// }
-
OsgiRuntimeContext managerRuntimeContext = new OsgiRuntimeContext(configuration);
try {
managerRuntimeContext.run();
BundleContext bc = managerRuntimeContext.getFramework().getBundleContext();
// uninstall init as a bundle since it will be available via OSGi system
- for (Bundle b : bc.getBundles()) {
- if (b.getSymbolicName().equals(SYMBOLIC_NAME_INIT)) {
- b.uninstall();
- }
- }
+ OsgiBoot.uninstallBundles(bc, SYMBOLIC_NAME_INIT);
bc.registerService(RuntimeManager.class, this, new Hashtable<>(configuration));
logger.log(Level.DEBUG, "Registered runtime manager");
managerRuntimeContext.waitForStop(0);
- } catch (InterruptedException | BundleException e) {
+ } catch (InterruptedException e) {
e.printStackTrace();
System.exit(1);
}
OsgiRuntimeContext runtimeContext = loadRuntime(relPath, configCallback);
runtimeContext.run();
Framework framework = runtimeContext.getFramework();
-
-// for (Bundle b : framework.getBundleContext().getBundles()) {
-// try {
-//// if (b.getSymbolicName().startsWith("org.eclipse.swt.gtk")) {
-//// b.uninstall();
-//// }
-//// else if (b.getSymbolicName().startsWith("org.eclipse.jface")) {
-//// b.uninstall();
-//// }
-// } catch (Exception e) {
-// // TODO Auto-generated catch block
-// e.printStackTrace();
-// }
-// }
-
if (framework != null) {// in case the framework has closed very quickly after run
framework.getBundleContext().addFrameworkListener((e) -> {
if (e.getType() >= FrameworkEvent.STOPPED) {