blob: e98276bd632066e2d903095ede3d2639629ee214 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2012, 2015 Wind River Systems, Inc. and others. 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:
* Wind River Systems - initial API and implementation
*******************************************************************************/
package org.eclipse.tcf.te.tcf.filesystem.ui.internal.columns;
import org.eclipse.swt.graphics.Image;
import org.eclipse.tcf.te.tcf.filesystem.core.interfaces.runtime.IFSTreeNode;
/**
* Windows specific image provider extending the default image provider
* to retrieve the file's images based on file extension or cached file.
*/
public class WindowsImageProvider extends DefaultImageProvider {
// The background daemons that updates the images of the file system nodes.
static LabelProviderUpdateDaemon updateDaemon;
static {
updateDaemon = new LabelProviderUpdateDaemon();
updateDaemon.start();
}
/*
* (non-Javadoc)
* @see org.eclipse.tcf.te.tcf.filesystem.internal.columns.DefaultImageProvider#getImage(org.eclipse.tcf.te.tcf.filesystem.model.IFSTreeNode)
*/
@Override
public Image getImage(IFSTreeNode node) {
if (node.isRootDirectory()) {
return node.isWindowsNode() ? updateDaemon.getDiskImage() : super.getImage(node);
}
else if (node.isDirectory()) {
return updateDaemon.getFolderImage();
}
else if(node.isFile()) {
Image image = updateDaemon.getImage(node);
if (image == null) {
updateDaemon.enqueue(node);
image = getPredefinedImage(node);
}
return image;
}
return super.getImage(node);
}
}