handler classes added
diff --git a/org.eclipse.emf.refactor.metrics.papyrus/META-INF/MANIFEST.MF b/org.eclipse.emf.refactor.metrics.papyrus/META-INF/MANIFEST.MF
index 8c14090..e998d27 100644
--- a/org.eclipse.emf.refactor.metrics.papyrus/META-INF/MANIFEST.MF
+++ b/org.eclipse.emf.refactor.metrics.papyrus/META-INF/MANIFEST.MF
@@ -9,6 +9,8 @@
org.eclipse.jdt.core;bundle-version="3.8.1",
org.eclipse.emf.ecore;bundle-version="2.8.1",
org.eclipse.emf.refactor.metrics;bundle-version="0.7.0",
+ org.eclipse.emf.refactor.metrics.runtime;bundle-version="0.7.0",
+ org.eclipse.emf.refactor.metrics.generator;bundle-version="0.7.0",
org.eclipse.gmf.runtime.diagram.ui;bundle-version="1.6.0",
org.eclipse.emf.facet.infra.browser.uicore;bundle-version="0.2.1"
Bundle-ActivationPolicy: lazy
diff --git a/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/CalculateMetricsOnElementCommandHandler.java b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/CalculateMetricsOnElementCommandHandler.java
new file mode 100644
index 0000000..ca06bf7
--- /dev/null
+++ b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/CalculateMetricsOnElementCommandHandler.java
@@ -0,0 +1,57 @@
+package org.eclipse.emf.refactor.metrics.papyrus.handler;
+
+import java.util.List;
+
+import org.eclipse.core.commands.ExecutionEvent;
+import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.core.commands.IHandler;
+import org.eclipse.core.commands.IHandlerListener;
+import org.eclipse.core.resources.IProject;
+import org.eclipse.emf.ecore.EObject;
+import org.eclipse.emf.refactor.metrics.papyrus.managers.PapyrusProjectManager;
+import org.eclipse.emf.refactor.metrics.papyrus.managers.PapyrusSelectionManager;
+import org.eclipse.emf.refactor.metrics.runtime.managers.RuntimeManager;
+import org.eclipse.jface.dialogs.MessageDialog;
+import org.eclipse.jface.viewers.ISelection;
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.graphics.Cursor;
+import org.eclipse.ui.PlatformUI;
+
+public class CalculateMetricsOnElementCommandHandler implements IHandler {
+
+ @Override
+ public void addHandlerListener(IHandlerListener handlerListener) { }
+
+ @Override
+ public void dispose() { }
+
+ @Override
+ public Object execute(ExecutionEvent event) throws ExecutionException {
+ Cursor oldCursor = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().getCursor();
+ PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().setCursor(new Cursor(null,SWT.CURSOR_WAIT));
+ ISelection selection = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getSelectionService().getSelection();
+ List<EObject> context = PapyrusSelectionManager.getESelection(selection);
+ IProject project = PapyrusProjectManager.getActualProject(selection);
+ if (project == null) {
+ PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().setCursor(oldCursor);
+ MessageDialog.openError(PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell(),
+ "EMF Quality Assurance", "Can not calculate metrics: project is " + project);
+ return null;
+ }
+ System.out.println("context: " + context);
+ RuntimeManager.getInstance();
+ RuntimeManager.calculateConfiguredMetricsOnElement(project, context);
+ PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().setCursor(oldCursor);
+ return null;
+ }
+
+ @Override
+ public boolean isEnabled() { return true; }
+
+ @Override
+ public boolean isHandled() { return true; }
+
+ @Override
+ public void removeHandlerListener(IHandlerListener handlerListener) { }
+
+}
diff --git a/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/CalculateMetricsTransitivelyCommandHandler.java b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/CalculateMetricsTransitivelyCommandHandler.java
new file mode 100644
index 0000000..2449501
--- /dev/null
+++ b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/CalculateMetricsTransitivelyCommandHandler.java
@@ -0,0 +1,56 @@
+package org.eclipse.emf.refactor.metrics.papyrus.handler;
+
+import java.util.List;
+
+import org.eclipse.core.commands.ExecutionEvent;
+import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.core.commands.IHandler;
+import org.eclipse.core.commands.IHandlerListener;
+import org.eclipse.core.resources.IProject;
+import org.eclipse.emf.ecore.EObject;
+import org.eclipse.emf.refactor.metrics.papyrus.managers.PapyrusProjectManager;
+import org.eclipse.emf.refactor.metrics.papyrus.managers.PapyrusSelectionManager;
+import org.eclipse.emf.refactor.metrics.runtime.managers.RuntimeManager;
+import org.eclipse.jface.dialogs.MessageDialog;
+import org.eclipse.jface.viewers.ISelection;
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.graphics.Cursor;
+import org.eclipse.ui.PlatformUI;
+
+public class CalculateMetricsTransitivelyCommandHandler implements IHandler {
+
+ @Override
+ public void addHandlerListener(IHandlerListener handlerListener) { }
+
+ @Override
+ public void dispose() { }
+
+ @Override
+ public Object execute(ExecutionEvent event) throws ExecutionException {
+ Cursor oldCursor = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().getCursor();
+ PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().setCursor(new Cursor(null,SWT.CURSOR_WAIT));
+ ISelection selection = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getSelectionService().getSelection();
+ List<EObject> context = PapyrusSelectionManager.getESelection(selection);
+ IProject project = PapyrusProjectManager.getActualProject(selection);
+ if (project == null) {
+ PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().setCursor(oldCursor);
+ MessageDialog.openError(PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell(),
+ "EMF Metrics", "Can not calculate metrics: project is " + project);
+ return null;
+ }
+ RuntimeManager.getInstance();
+ RuntimeManager.calculateConfiguredMetricsTransitively(project, context.get(0));
+ PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell().setCursor(oldCursor);
+ return null;
+ }
+
+ @Override
+ public boolean isEnabled() { return true; }
+
+ @Override
+ public boolean isHandled() { return true; }
+
+ @Override
+ public void removeHandlerListener(IHandlerListener handlerListener) { }
+
+}
diff --git a/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/GenerateNewMetricCompositeCommandHandler.java b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/GenerateNewMetricCompositeCommandHandler.java
new file mode 100644
index 0000000..dbf50b6
--- /dev/null
+++ b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/GenerateNewMetricCompositeCommandHandler.java
@@ -0,0 +1,54 @@
+package org.eclipse.emf.refactor.metrics.papyrus.handler;
+
+import java.util.List;
+
+import org.eclipse.core.commands.ExecutionEvent;
+import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.core.commands.IHandler;
+import org.eclipse.core.commands.IHandlerListener;
+import org.eclipse.emf.ecore.EObject;
+import org.eclipse.emf.ecore.EPackage;
+import org.eclipse.emf.refactor.metrics.generator.ui.NewMetricWizardComposite;
+import org.eclipse.emf.refactor.metrics.papyrus.managers.PapyrusSelectionManager;
+import org.eclipse.jface.viewers.ISelection;
+import org.eclipse.jface.viewers.IStructuredSelection;
+import org.eclipse.jface.wizard.WizardDialog;
+import org.eclipse.ui.IWorkbenchWindow;
+import org.eclipse.ui.PlatformUI;
+
+public class GenerateNewMetricCompositeCommandHandler implements IHandler {
+
+ @Override
+ public void addHandlerListener(IHandlerListener handlerListener) { }
+
+ @Override
+ public void dispose() { }
+
+ @Override
+ public Object execute(ExecutionEvent event) throws ExecutionException {
+ IWorkbenchWindow win = PlatformUI.getWorkbench().getActiveWorkbenchWindow();
+ ISelection selection = win.getSelectionService().getSelection();
+ List<EObject> context = PapyrusSelectionManager.getESelection(selection);
+ EObject selectedEObject = context.get(0);
+ String metamodel = ((EPackage) selectedEObject.eClass().eContainer()).getNsURI();
+ String contextType = selectedEObject.eClass().getInstanceClass().getSimpleName();
+ NewMetricWizardComposite wizard = new NewMetricWizardComposite(metamodel, contextType);
+ wizard.init(win.getWorkbench(), (IStructuredSelection) selection);
+ WizardDialog dialog = new WizardDialog(win.getShell(), wizard);
+ return dialog.open();
+ }
+
+ @Override
+ public boolean isEnabled() {
+ return true;
+ }
+
+ @Override
+ public boolean isHandled() {
+ return true;
+ }
+
+ @Override
+ public void removeHandlerListener(IHandlerListener handlerListener) { }
+
+}
diff --git a/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/GenerateNewMetricJavaCommandHandler.java b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/GenerateNewMetricJavaCommandHandler.java
new file mode 100644
index 0000000..b0b93fb
--- /dev/null
+++ b/org.eclipse.emf.refactor.metrics.papyrus/src/org/eclipse/emf/refactor/metrics/papyrus/handler/GenerateNewMetricJavaCommandHandler.java
@@ -0,0 +1,50 @@
+package org.eclipse.emf.refactor.metrics.papyrus.handler;
+
+import java.util.List;
+
+import org.eclipse.core.commands.ExecutionEvent;
+import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.core.commands.IHandler;
+import org.eclipse.core.commands.IHandlerListener;
+import org.eclipse.emf.ecore.EObject;
+import org.eclipse.emf.ecore.EPackage;
+import org.eclipse.emf.refactor.metrics.generator.ui.NewMetricWizardJava;
+import org.eclipse.emf.refactor.metrics.papyrus.managers.PapyrusSelectionManager;
+import org.eclipse.jface.viewers.ISelection;
+import org.eclipse.jface.viewers.IStructuredSelection;
+import org.eclipse.jface.wizard.WizardDialog;
+import org.eclipse.ui.IWorkbenchWindow;
+import org.eclipse.ui.PlatformUI;
+
+public class GenerateNewMetricJavaCommandHandler implements IHandler {
+
+ @Override
+ public void addHandlerListener(IHandlerListener handlerListener) { }
+
+ @Override
+ public void dispose() { }
+
+ @Override
+ public Object execute(ExecutionEvent event) throws ExecutionException {
+ IWorkbenchWindow win = PlatformUI.getWorkbench().getActiveWorkbenchWindow();
+ ISelection selection = win.getSelectionService().getSelection();
+ List<EObject> context = PapyrusSelectionManager.getESelection(selection);
+ EObject selectedEObject = context.get(0);
+ String metamodel = ((EPackage) selectedEObject.eClass().eContainer()).getNsURI();
+ String contextType = selectedEObject.eClass().getInstanceClass().getSimpleName();
+ NewMetricWizardJava wizard = new NewMetricWizardJava(metamodel, contextType);
+ wizard.init(win.getWorkbench(), (IStructuredSelection) selection);
+ WizardDialog dialog = new WizardDialog(win.getShell(), wizard);
+ return dialog.open();
+ }
+
+ @Override
+ public boolean isEnabled() { return true; }
+
+ @Override
+ public boolean isHandled() { return true; }
+
+ @Override
+ public void removeHandlerListener(IHandlerListener handlerListener) { }
+
+}