blob: f02b42d6740f665060bdaf0db682f050404274fa [file] [log] [blame]
/**
* Copyright (c) 2009-2010 Thales Corporate Services S.A.S.
* 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:
* Thales Corporate Services S.A.S - initial API and implementation
*/
package org.eclipse.egf.application.internal.activity;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.SubMonitor;
import org.eclipse.egf.application.internal.activator.EGFApplicationPlugin;
import org.eclipse.egf.application.internal.l10n.ApplicationMessages;
import org.eclipse.egf.common.helper.EMFHelper;
import org.eclipse.egf.core.l10n.EGFCoreMessages;
import org.eclipse.egf.core.producer.InvocationException;
import org.eclipse.egf.model.fcore.Activity;
import org.eclipse.egf.producer.EGFProducerPlugin;
import org.eclipse.egf.producer.l10n.ProducerMessages;
import org.eclipse.egf.producer.manager.IActivityManager;
import org.eclipse.emf.common.util.Diagnostic;
import org.eclipse.emf.common.util.DiagnosticException;
import org.eclipse.emf.ecore.util.EcoreUtil;
import org.eclipse.osgi.util.NLS;
/**
* @author Xavier Maysonnave
*
*/
public class ActivityRunner {
protected Activity _activity;
public ActivityRunner(Activity activity) throws CoreException {
if (activity == null) {
throw new CoreException(EGFApplicationPlugin.getDefault().newStatus(IStatus.ERROR, ApplicationMessages.ActivityRunner_NullActivity, null));
}
_activity = activity;
}
public void run(IProgressMonitor monitor) throws CoreException {
IActivityManager<Activity> manager = null;
try {
// Retrieve an ActivityManager
manager = EGFProducerPlugin.getActivityManagerProducer(_activity).createActivityManager(_activity);
// Initialize Context
manager.initializeContext();
} catch (Throwable t) {
throw new CoreException(EGFApplicationPlugin.getDefault().newStatus(IStatus.ERROR, NLS.bind(ApplicationMessages.ActivityRunner_ActivityRunner_Exception, EcoreUtil.getURI(_activity)), t));
}
try {
// Pre-Invoke validation
Diagnostic diagnostic = manager.canInvoke();
if (diagnostic.getSeverity() == Diagnostic.ERROR) {
throw DiagnosticException.toCoreException(new DiagnosticException(diagnostic));
}
} catch (CoreException ce) {
throw ce;
} catch (InvocationException ie) {
throw new CoreException(EGFApplicationPlugin.getDefault().newStatus(IStatus.ERROR, NLS.bind(ApplicationMessages.ActivityRunner_PreInvokeProblems_message, EcoreUtil.getURI(_activity)), ie));
}
Diagnostic diagnostic = null;
try {
// Invoke
int ticks = manager.getSteps();
SubMonitor subMonitor = SubMonitor.convert(monitor, NLS.bind(EGFCoreMessages.Production_Invoke, EMFHelper.getText(manager.getElement())), (1000 * ticks));
if (ticks == 1) {
EGFApplicationPlugin.getDefault().logInfo(NLS.bind(ProducerMessages.Activity_Invocation, EMFHelper.getText(_activity)));
} else {
EGFApplicationPlugin.getDefault().logInfo(NLS.bind(ProducerMessages.Activity_Invocations, EMFHelper.getText(_activity), ticks));
}
diagnostic = manager.invoke(subMonitor.newChild(1000 * ticks, SubMonitor.SUPPRESS_NONE));
} catch (Throwable t) {
throw new CoreException(EGFApplicationPlugin.getDefault().newStatus(IStatus.ERROR, NLS.bind(ApplicationMessages.ActivityRunner_ActivityRunner_Exception, EcoreUtil.getURI(_activity)), t));
}
// Post Invoke Validation
if (diagnostic.getSeverity() == Diagnostic.ERROR) {
throw DiagnosticException.toCoreException(new DiagnosticException(diagnostic));
}
try {
// Dispose
manager.dispose();
} catch (Throwable t) {
throw new CoreException(EGFApplicationPlugin.getDefault().newStatus(IStatus.ERROR, ApplicationMessages.ActivityRunner_ActivityRunner_Exception, t));
}
}
}