Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPascal Rapicault2013-01-20 11:13:23 -0500
committerPascal Rapicault2013-01-20 11:13:23 -0500
commit91c54478e49e4764e02f677c1b1bc6e6ce09b265 (patch)
tree6bf321772af010c83b72b40ffe4ff6783d2a90e4 /bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2
parentaa717cf44d6ace46bdd500bb2fc58b4fe369d1fc (diff)
downloadrt.equinox.p2-91c54478e49e4764e02f677c1b1bc6e6ce09b265.tar.gz
rt.equinox.p2-91c54478e49e4764e02f677c1b1bc6e6ce09b265.tar.xz
rt.equinox.p2-91c54478e49e4764e02f677c1b1bc6e6ce09b265.zip
Revert "changes to the director"v20130120-161323
Diffstat (limited to 'bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2')
-rw-r--r--bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/DirectorComponent.java28
-rw-r--r--bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/SimpleDirector.java63
2 files changed, 91 insertions, 0 deletions
diff --git a/bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/DirectorComponent.java b/bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/DirectorComponent.java
new file mode 100644
index 000000000..08935c47a
--- /dev/null
+++ b/bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/DirectorComponent.java
@@ -0,0 +1,28 @@
+/*******************************************************************************
+ * Copyright (c) 2009-2010 IBM Corporation and others.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * IBM Corporation - initial API and implementation
+ * Sonatype, Inc. - ongoing development
+ *******************************************************************************/
+package org.eclipse.equinox.internal.p2.director;
+
+import org.eclipse.equinox.p2.planner.IPlanner;
+
+import org.eclipse.equinox.p2.core.IProvisioningAgent;
+import org.eclipse.equinox.p2.core.spi.IAgentServiceFactory;
+import org.eclipse.equinox.p2.engine.IEngine;
+
+public class DirectorComponent implements IAgentServiceFactory {
+
+ public Object createService(IProvisioningAgent agent) {
+ IEngine engine = (IEngine) agent.getService(IEngine.SERVICE_NAME);
+ IPlanner planner = (IPlanner) agent.getService(IPlanner.SERVICE_NAME);
+ return new SimpleDirector(engine, planner);
+ }
+
+}
diff --git a/bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/SimpleDirector.java b/bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/SimpleDirector.java
new file mode 100644
index 000000000..adf0fd4a6
--- /dev/null
+++ b/bundles/org.eclipse.equinox.p2.director/src/org/eclipse/equinox/internal/p2/director/SimpleDirector.java
@@ -0,0 +1,63 @@
+/*******************************************************************************
+ * Copyright (c) 2007, 2010 IBM Corporation and others. All rights reserved. This
+ * program and the accompanying materials are made available under the terms of
+ * the Eclipse Public License v1.0 which accompanies this distribution, and is
+ * available at http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * IBM Corporation - initial API and implementation
+ * Sonatype, Inc. - ongoing development
+ ******************************************************************************/
+package org.eclipse.equinox.internal.p2.director;
+
+import java.util.Collection;
+import org.eclipse.core.runtime.*;
+import org.eclipse.equinox.internal.provisional.p2.director.IDirector;
+import org.eclipse.equinox.internal.provisional.p2.director.PlanExecutionHelper;
+import org.eclipse.equinox.p2.engine.*;
+import org.eclipse.equinox.p2.metadata.IInstallableUnit;
+import org.eclipse.equinox.p2.planner.IPlanner;
+import org.eclipse.equinox.p2.planner.IProfileChangeRequest;
+import org.eclipse.osgi.util.NLS;
+
+public class SimpleDirector implements IDirector {
+ static final int PlanWork = 10;
+ static final int EngineWork = 100;
+ private IEngine engine;
+ private IPlanner planner;
+
+ public SimpleDirector(IEngine engine, IPlanner planner) {
+ if (engine == null)
+ throw new IllegalStateException("Provisioning engine is not registered"); //$NON-NLS-1$
+ this.engine = engine;
+ if (planner == null)
+ throw new IllegalStateException("Unable to find provisioning planner"); //$NON-NLS-1$
+ this.planner = planner;
+ }
+
+ public IStatus revert(IProfile currentProfile, IProfile revertProfile, ProvisioningContext context, IProgressMonitor monitor) {
+ SubMonitor sub = SubMonitor.convert(monitor, Messages.Director_Task_Updating, PlanWork + EngineWork);
+ try {
+ IProvisioningPlan plan = planner.getDiffPlan(currentProfile, revertProfile, sub.newChild(PlanWork));
+ return PlanExecutionHelper.executePlan(plan, engine, context, sub.newChild(EngineWork));
+ } finally {
+ sub.done();
+ }
+ }
+
+ public IStatus provision(IProfileChangeRequest request, ProvisioningContext context, IProgressMonitor monitor) {
+ String taskName = NLS.bind(Messages.Director_Task_Installing, ((ProfileChangeRequest) request).getProfile().getProperty(IProfile.PROP_INSTALL_FOLDER));
+ SubMonitor sub = SubMonitor.convert(monitor, taskName, PlanWork + EngineWork);
+ try {
+ Collection<IInstallableUnit> installRoots = request.getAdditions();
+ // mark the roots as such
+ for (IInstallableUnit root : installRoots) {
+ request.setInstallableUnitProfileProperty(root, IProfile.PROP_PROFILE_ROOT_IU, Boolean.toString(true));
+ }
+ IProvisioningPlan plan = planner.getProvisioningPlan(request, context, sub.newChild(PlanWork));
+ return PlanExecutionHelper.executePlan(plan, engine, context, sub.newChild(EngineWork));
+ } finally {
+ sub.done();
+ }
+ }
+}

Back to the top