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) { }
+
+}