/*******************************************************************************
* Copyright (c) 2009 - 2013 Spring IDE Developers
* 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:
* Spring IDE Developers - initial API and implementation
*******************************************************************************/
package org.springframework.ide.eclipse.beans.ui.editor.hyperlink.bean;
import java.util.LinkedHashSet;
import java.util.Set;
import org.eclipse.core.resources.IFile;
import org.eclipse.jface.text.BadLocationException;
import org.eclipse.jface.text.IDocument;
import org.eclipse.jface.text.IRegion;
import org.eclipse.jface.text.ITextViewer;
import org.eclipse.jface.text.hyperlink.IHyperlink;
import org.eclipse.wst.xml.core.internal.provisional.document.IDOMNode;
import org.springframework.ide.eclipse.beans.core.internal.model.BeansModelUtils;
import org.springframework.ide.eclipse.beans.core.model.IBeansConfig;
import org.springframework.ide.eclipse.beans.core.model.IBeansImport;
import org.springframework.ide.eclipse.beans.ui.editor.hyperlink.IMultiHyperlinkCalculator;
import org.springframework.ide.eclipse.beans.ui.editor.util.BeansEditorUtils;
import org.springframework.ide.eclipse.core.model.IModelElement;
import org.springsource.ide.eclipse.commons.ui.SpringUIUtils;
import org.w3c.dom.Node;
/**
* {@link IMultiHyperlinkCalculator} for hyperlinking to imported resources.
* @author Christian Dupuis
* @since 2.2.7
*/
@SuppressWarnings("restriction")
public class ImportHyperlinkCalculator implements IMultiHyperlinkCalculator {
public IHyperlink[] createHyperlinks(String name, String target, Node node, Node parentNode, IDocument document,
ITextViewer textViewer, IRegion hyperlinkRegion, IRegion cursor) {
Set<IHyperlink> hyperlinks = new LinkedHashSet<IHyperlink>();
try {
int startOffset = ((IDOMNode) node).getStartOffset();
int endOffset = ((IDOMNode) node).getEndOffset();
int start = document.getLineOfOffset(startOffset) + 1;
int end = document.getLineOfOffset(endOffset) + 1;
IFile file = BeansEditorUtils.getFile(document);
IModelElement element = BeansModelUtils.getMostSpecificModelElement(start, end, file, null);
if (element instanceof IBeansImport) {
for (IBeansConfig config : ((IBeansImport) element).getImportedBeansConfigs()) {
hyperlinks.add(new WorkspaceFileHyperlink(hyperlinkRegion, (IFile) config.getElementResource()));
}
}
}
catch (BadLocationException e) {
}
return hyperlinks.toArray(new IHyperlink[hyperlinks.size()]);
}
public IHyperlink createHyperlink(String name, String target, Node node, Node parentNode, IDocument document,
ITextViewer textViewer, IRegion hyperlinkRegion, IRegion cursor) {
IHyperlink[] hyperlinks = createHyperlinks(name, target, node, parentNode, document, textViewer,
hyperlinkRegion, cursor);
if (hyperlinks != null && hyperlinks.length > 0) {
return hyperlinks[0];
}
return null;
}
/**
* Hyperlink for files within the workspace. (As long as there is an IFile, this can be used) Opens the default
* editor for the file.
*/
class WorkspaceFileHyperlink implements IHyperlink {
private IRegion region;
private IFile file;
public WorkspaceFileHyperlink(IRegion region, IFile file) {
this.region = region;
this.file = file;
}
public IRegion getHyperlinkRegion() {
return region;
}
public String getTypeLabel() {
return null;
}
public String getHyperlinkText() {
String path = file.getFullPath().toString();
if (path.length() > 60) {
path = path.substring(0, 25) + "..." + path.substring(path.length() - 25, path.length());
}
return "Open '" + path + "'";
}
public void open() {
if ((file != null) && file.exists()) {
SpringUIUtils.openInEditor(file, 1);
}
}
}
}