Author: stefanegli
Date: Wed Sep 4 13:01:29 2013
New Revision: 1520001
URL: http://svn.apache.org/r1520001
Log:
SLING-2985 : link-with-editor support added for content browser
Added:
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/LinkHelper.java
(with props)
Modified:
sling/trunk/tooling/ide/eclipse-ui/plugin.xml
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/JcrContentContentProvider.java
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/JcrNode.java
Modified: sling/trunk/tooling/ide/eclipse-ui/plugin.xml
URL:
http://svn.apache.org/viewvc/sling/trunk/tooling/ide/eclipse-ui/plugin.xml?rev=1520001&r1=1520000&r2=1520001&view=diff
==============================================================================
--- sling/trunk/tooling/ide/eclipse-ui/plugin.xml (original)
+++ sling/trunk/tooling/ide/eclipse-ui/plugin.xml Wed Sep 4 13:01:29 2013
@@ -151,6 +151,7 @@
<viewerContentBinding
viewerId="org.eclipse.ui.navigator.ProjectExplorer">
<includes>
<contentExtension
pattern="org.apache.sling.ide.eclipse-ui.navigatorJcrContent" />
+ <contentExtension
pattern="org.apache.sling.ide.eclipse-ui.linkHelper"/>
</includes>
</viewerContentBinding>
</extension>
@@ -374,6 +375,25 @@
</and>
</enablement>
</decorator>
+ </extension>
+ <extension
+ point="org.eclipse.ui.navigator.linkHelper">
+ <linkHelper
+ class="org.apache.sling.ide.eclipse.ui.nav.model.LinkHelper"
+ id="org.apache.sling.ide.eclipse-ui.linkHelper">
+ <editorInputEnablement>
+ <or>
+ <instanceof
+ value="org.eclipse.ui.IEditorInput">
+ </instanceof>
+ </or>
+ </editorInputEnablement>
+ <selectionEnablement>
+ <instanceof
+ value="org.apache.sling.ide.eclipse.ui.nav.model.JcrNode">
+ </instanceof>
+ </selectionEnablement>
+ </linkHelper>
</extension>
</plugin>
Modified:
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/JcrContentContentProvider.java
URL:
http://svn.apache.org/viewvc/sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/JcrContentContentProvider.java?rev=1520001&r1=1520000&r2=1520001&view=diff
==============================================================================
---
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/JcrContentContentProvider.java
(original)
+++
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/JcrContentContentProvider.java
Wed Sep 4 13:01:29 2013
@@ -76,8 +76,14 @@ public class JcrContentContentProvider i
@Override
public Object getParent(Object element) {
- // TODO Auto-generated method stub
- return null;
+ if (!(element instanceof JcrNode)) {
+ return null;
+ } else if (element instanceof SyncDir) {
+ SyncDir syncDir = (SyncDir) element;
+ return syncDir.getFolder().getProject();
+ }
+ JcrNode node = (JcrNode) element;
+ return node.getParent();
}
@Override
Modified:
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/JcrNode.java
URL:
http://svn.apache.org/viewvc/sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/JcrNode.java?rev=1520001&r1=1520000&r2=1520001&view=diff
==============================================================================
---
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/JcrNode.java
(original)
+++
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/JcrNode.java
Wed Sep 4 13:01:29 2013
@@ -522,4 +522,8 @@ public class JcrNode implements IAdaptab
return false;
}
+ public JcrNode getParent() {
+ return parent;
+ }
+
}
Added:
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/LinkHelper.java
URL:
http://svn.apache.org/viewvc/sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/LinkHelper.java?rev=1520001&view=auto
==============================================================================
---
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/LinkHelper.java
(added)
+++
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/LinkHelper.java
Wed Sep 4 13:01:29 2013
@@ -0,0 +1,90 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.sling.ide.eclipse.ui.nav.model;
+
+import org.apache.sling.ide.eclipse.core.ProjectUtil;
+import org.apache.sling.ide.eclipse.core.internal.ProjectHelper;
+import org.eclipse.core.resources.IContainer;
+import org.eclipse.core.resources.IFile;
+import org.eclipse.core.resources.IFolder;
+import org.eclipse.core.resources.IProject;
+import org.eclipse.core.resources.IResource;
+import org.eclipse.core.runtime.IPath;
+import org.eclipse.jface.viewers.IStructuredSelection;
+import org.eclipse.jface.viewers.StructuredSelection;
+import org.eclipse.ui.IEditorInput;
+import org.eclipse.ui.IWorkbenchPage;
+import org.eclipse.ui.ide.ResourceUtil;
+import org.eclipse.ui.navigator.ILinkHelper;
+import org.w3c.dom.Node;
+
+public class LinkHelper implements ILinkHelper {
+
+ @Override
+ public IStructuredSelection findSelection(IEditorInput anInput) {
+ IFile file = ResourceUtil.getFile(anInput);
+ IProject project = file.getProject();
+ if (!ProjectHelper.isContentProject(project)) {
+ return null;
+ }
+ IPath syncDirFullPath =
ProjectUtil.getSyncDirectoryFullPath(project);
+ if (syncDirFullPath==null) {
+ return null;
+ }
+ if (!syncDirFullPath.isPrefixOf(file.getFullPath())) {
+ return null;
+ }
+ JcrNode selectedNode = createSelectionNode(file);
+ if (selectedNode!=null) {
+ return new StructuredSelection(selectedNode);
+ } else {
+ return null;
+ }
+ }
+
+ private JcrNode createSelectionNode(IResource resource) {
+ if (resource==null) {
+ return null;
+ }
+ final IContainer resourceParent = resource.getParent();
+ if (resource instanceof IFolder) {
+ IFolder container = (IFolder)resource;
+ IPath syncDirFullPath =
ProjectUtil.getSyncDirectoryFullPath(resource.getProject());
+ if (syncDirFullPath.equals(container.getFullPath())) {
+ // then we've reached the syncdir
+ return new SyncDir(container);
+ }
+ } else if (!(resource instanceof IFile)) {
+ return null;
+ }
+ JcrNode parent = createSelectionNode(resourceParent);
+ if (parent==null) {
+ return null;
+ }
+ Node domNode = null;
+ JcrNode selectedNode = new JcrNode(parent, domNode, resource);
+ return selectedNode;
+ }
+
+ @Override
+ public void activateEditor(IWorkbenchPage aPage,
+ IStructuredSelection aSelection) {
+ // nothing done here at the moment.
+ // PackageExplorerOpenActionProvider currently takes care of
opening jcr nodes in an editor
+ }
+
+}
Propchange:
sling/trunk/tooling/ide/eclipse-ui/src/org/apache/sling/ide/eclipse/ui/nav/model/LinkHelper.java
------------------------------------------------------------------------------
svn:mime-type = text/plain