Java tutorial
/******************************************************************************* * Copyright (c) 2011, 2013 Obeo. * 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: * Obeo - initial API and implementation *******************************************************************************/ package org.eclipse.acceleo.ui.interpreter.view.providers; import java.util.HashMap; import java.util.Map; import org.eclipse.acceleo.ui.interpreter.view.InterpreterFile; import org.eclipse.emf.common.notify.AdapterFactory; import org.eclipse.emf.edit.ui.provider.AdapterFactoryLabelProvider; import org.eclipse.jface.viewers.CellLabelProvider; import org.eclipse.jface.viewers.ViewerCell; import org.eclipse.swt.graphics.Image; import org.eclipse.ui.IEditorDescriptor; import org.eclipse.ui.PlatformUI; /** * This will act as the label provider for the "variables" Tree Viewer. * * @author <a href="mailto:laurent.goubet@obeo.fr">Laurent Goubet</a> */ public class ResultLabelProvider extends CellLabelProvider { /** The delegate label provider. */ private final AdapterFactoryLabelProvider delegate; /** Keeps track of the images we created through this label provider. */ private Map<String, Image> images = new HashMap<String, Image>(); /** * Instantiates this label provider given its adapter factory. * * @param adapterFactory * The adapter factory for this label provider. */ public ResultLabelProvider(AdapterFactory adapterFactory) { super(); delegate = new AdapterFactoryLabelProvider(adapterFactory); } /** * {@inheritDoc} * * @see org.eclipse.jface.viewers.BaseLabelProvider#dispose() */ @Override public void dispose() { for (Image image : images.values()) { image.dispose(); } images.clear(); super.dispose(); } /** * {@inheritDoc} * * @see org.eclipse.jface.viewers.CellLabelProvider#getToolTipText(java.lang.Object) */ @Override public String getToolTipText(Object element) { final String text = getText(element); if (text.indexOf('\n') != -1 || text.indexOf('\r') != -1) { return text; } return null; } /** * {@inheritDoc} * * @see org.eclipse.jface.viewers.CellLabelProvider#update(org.eclipse.jface.viewers.ViewerCell) */ @Override public void update(ViewerCell cell) { final Object element = cell.getElement(); final String text = getText(element); int indexOfNewLine = text.indexOf("\n\r") - 2; //$NON-NLS-1$ if (indexOfNewLine < 0) { indexOfNewLine = text.indexOf("\n") - 1; //$NON-NLS-1$ } if (indexOfNewLine < 0) { indexOfNewLine = text.indexOf("\r") - 1; //$NON-NLS-1$ } if (indexOfNewLine >= 0) { cell.setText(text.substring(0, indexOfNewLine) + " (...)"); //$NON-NLS-1$ } else { cell.setText(text); } cell.setImage(getImage(element)); } /** * Search for an editor associated with the given fileName, and return its icon. * * @param fileName * The name of the file for which we search an editor icon. * @return The icon of the editor associated with the given file name. */ private Image createEditorIcon(String fileName) { IEditorDescriptor[] descriptors = PlatformUI.getWorkbench().getEditorRegistry().getEditors(fileName); if (descriptors != null) { for (int i = 0; i < descriptors.length; i++) { IEditorDescriptor descriptor = descriptors[i]; if (descriptor.getImageDescriptor() != null) { Image image = descriptor.getImageDescriptor().createImage(); return image; } } } return PlatformUI.getWorkbench().getEditorRegistry().getImageDescriptor(fileName).createImage(); } /** * Returns the image to be displayed for the given element. * * @param element * Element for which we need an icon. * @return The image to be displayed for the given element. */ private Image getImage(Object element) { Image result = null; if (element instanceof InterpreterFile) { String key = ((InterpreterFile) element).getFileName(); if (key.indexOf('.') != -1) { key = key.substring(key.indexOf('.') + 1); } result = images.get(key); if (result == null) { result = createEditorIcon(((InterpreterFile) element).getFileName()); if (result != null) { images.put(key, result); } } if (result != null) { return result; } } return delegate.getImage(element); } /** * Returns the text to be displayed for the given element. * * @param element * Element for which we need a label. * @return The text to be displayed for the given element. */ private String getText(Object element) { if (element instanceof InterpreterFile) { return ((InterpreterFile) element).getFileName(); } return delegate.getText(element); } }