Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authortfaure2011-10-07 17:31:18 +0000
committertfaure2011-10-07 17:31:18 +0000
commit3567a11984e953f9b5a2c104df3de28b681f2a36 (patch)
tree2532b87ccdfbef725006ddc32acf950b2fd74893
parentbcdd10b4a5ed008fbc868b87dae31ad4f6aca1c1 (diff)
downloadorg.eclipse.papyrus-3567a11984e953f9b5a2c104df3de28b681f2a36.tar.gz
org.eclipse.papyrus-3567a11984e953f9b5a2c104df3de28b681f2a36.tar.xz
org.eclipse.papyrus-3567a11984e953f9b5a2c104df3de28b681f2a36.zip
NEW - bug 356146: [model abstraction] lock decorator not updated for SVN
https://bugs.eclipse.org/bugs/show_bug.cgi?id=356146 Copy/Paste/Delete available for ISubResourceFile
-rw-r--r--plugins/core/org.eclipse.papyrus.onefile/plugin.xml9
-rw-r--r--plugins/core/org.eclipse.papyrus.onefile/src/org/eclipse/papyrus/onefile/providers/ISubresourceFileActionProvider.java76
2 files changed, 85 insertions, 0 deletions
diff --git a/plugins/core/org.eclipse.papyrus.onefile/plugin.xml b/plugins/core/org.eclipse.papyrus.onefile/plugin.xml
index 4f84edddb0a..c6b00c436b8 100644
--- a/plugins/core/org.eclipse.papyrus.onefile/plugin.xml
+++ b/plugins/core/org.eclipse.papyrus.onefile/plugin.xml
@@ -115,6 +115,15 @@
</instanceof>
</or>
</triggerPoints>
+ <actionProvider
+ class="org.eclipse.papyrus.onefile.providers.ISubresourceFileActionProvider"
+ id="org.eclipse.papyrus.onefile.DiContent.EditActions">
+ <enablement>
+ <instanceof
+ value="org.eclipse.papyrus.onefile.model.ISubResourceFile">
+ </instanceof>
+ </enablement>
+ </actionProvider>
</navigatorContent>
</extension>
<extension point="org.eclipse.ui.navigator.viewer">
diff --git a/plugins/core/org.eclipse.papyrus.onefile/src/org/eclipse/papyrus/onefile/providers/ISubresourceFileActionProvider.java b/plugins/core/org.eclipse.papyrus.onefile/src/org/eclipse/papyrus/onefile/providers/ISubresourceFileActionProvider.java
new file mode 100644
index 00000000000..572f3fd52b3
--- /dev/null
+++ b/plugins/core/org.eclipse.papyrus.onefile/src/org/eclipse/papyrus/onefile/providers/ISubresourceFileActionProvider.java
@@ -0,0 +1,76 @@
+/*****************************************************************************
+ * Copyright (c) 2011 Atos Origin Integration.
+ *
+ * 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:
+ * Tristan Faure (Atos Origin) tristan.faure@ato.net - Initial API and implementation
+ *****************************************************************************/
+package org.eclipse.papyrus.onefile.providers;
+
+import java.util.Iterator;
+import java.util.LinkedList;
+import java.util.List;
+
+import org.eclipse.core.resources.IResource;
+import org.eclipse.core.runtime.IAdaptable;
+import org.eclipse.core.runtime.Platform;
+import org.eclipse.jface.viewers.ISelection;
+import org.eclipse.jface.viewers.IStructuredSelection;
+import org.eclipse.jface.viewers.StructuredSelection;
+import org.eclipse.ui.actions.ActionContext;
+import org.eclipse.ui.internal.navigator.resources.actions.EditActionProvider;
+
+
+/**
+ * An edit action provider to provide Copy/Paste/Delete on sub resources
+ *
+ * @author Tristan Faure
+ *
+ */
+@SuppressWarnings("restriction")
+public class ISubresourceFileActionProvider extends EditActionProvider {
+
+ @Override
+ public void setContext(ActionContext context) {
+ // TODO Auto-generated method stub
+ List<Object> resources = new LinkedList<Object>();
+ if(context.getSelection() instanceof IStructuredSelection) {
+ IStructuredSelection contextSelec = (IStructuredSelection)context.getSelection();
+ for(Iterator<?> i = contextSelec.iterator(); i.hasNext();) {
+ Object o = i.next();
+ IResource res = adapt(o, IResource.class);
+ if(res != null) {
+ resources.add(res);
+ }
+ }
+ }
+ if(!resources.isEmpty()) {
+ ISelection selec = new StructuredSelection(resources);
+ super.setContext(new ActionContext(selec));
+ } else {
+ super.setContext(context);
+ }
+ }
+
+ @SuppressWarnings("unchecked")
+ public <T> T adapt(Object o, Class<T> aClass) {
+ T result = null;
+ if(aClass.isInstance(o)) {
+ result = (T)o;
+ }
+ if(o instanceof IAdaptable) {
+ IAdaptable adaptable = (IAdaptable)o;
+ result = (T)adaptable.getAdapter(aClass);
+ }
+ if(result == null) {
+ result = (T)Platform.getAdapterManager().getAdapter(o, aClass);
+ }
+
+ return result;
+ }
+
+}

Back to the top