blob: 0530d865e56e54205e543bdfc2fb8708957de77f [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2005, 2008 IBM Corporation and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.team.internal.ui.history;
import java.io.InputStream;
import java.net.URI;
import java.text.DateFormat;
import java.util.Date;
import org.eclipse.core.resources.IEncodedStorage;
import org.eclipse.core.resources.IFileState;
import org.eclipse.core.resources.IStorage;
import org.eclipse.core.runtime.Adapters;
import org.eclipse.core.runtime.Assert;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IPath;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.PlatformObject;
import org.eclipse.jface.resource.ImageDescriptor;
import org.eclipse.osgi.util.NLS;
import org.eclipse.team.core.history.IFileRevision;
import org.eclipse.team.internal.ui.TeamUIMessages;
import org.eclipse.ui.IPersistableElement;
import org.eclipse.ui.IStorageEditorInput;
import org.eclipse.ui.model.IWorkbenchAdapter;
public class FileRevisionEditorInput extends PlatformObject implements IWorkbenchAdapter, IStorageEditorInput {
private final Object fileRevision;
private final IStorage storage;
/**
* Creates FileRevisionEditorInput on the given revision.
* @param revision the file revision
* @param monitor
* @return a file revision editor input
* @throws CoreException
*/
public static FileRevisionEditorInput createEditorInputFor(IFileRevision revision, IProgressMonitor monitor) throws CoreException {
IStorage storage = revision.getStorage(monitor);
return new FileRevisionEditorInput(revision, storage);
}
private static IStorage wrapStorage(final IStorage storage,
final String charset) {
if (charset == null)
return storage;
if (storage instanceof IFileState) {
return new IFileState() {
@Override
public <T> T getAdapter(Class<T> adapter) {
return storage.getAdapter(adapter);
}
@Override
public boolean isReadOnly() {
return storage.isReadOnly();
}
@Override
public String getName() {
return storage.getName();
}
@Override
public IPath getFullPath() {
return storage.getFullPath();
}
@Override
public InputStream getContents() throws CoreException {
return storage.getContents();
}
@Override
public String getCharset() throws CoreException {
return charset;
}
@Override
public boolean exists() {
return ((IFileState) storage).exists();
}
@Override
public long getModificationTime() {
return ((IFileState) storage).getModificationTime();
}
};
}
return new IEncodedStorage() {
@Override
public <T> T getAdapter(Class<T> adapter) {
return storage.getAdapter(adapter);
}
@Override
public boolean isReadOnly() {
return storage.isReadOnly();
}
@Override
public String getName() {
return storage.getName();
}
@Override
public IPath getFullPath() {
return storage.getFullPath();
}
@Override
public InputStream getContents() throws CoreException {
return storage.getContents();
}
@Override
public String getCharset() throws CoreException {
return charset;
}
};
}
/**
* Creates FileRevisionEditorInput on the given revision.
* @param revision the file revision
* @param storage the contents of the file revision
*/
public FileRevisionEditorInput(Object revision, IStorage storage) {
Assert.isNotNull(revision);
Assert.isNotNull(storage);
this.fileRevision = revision;
this.storage = storage;
}
public FileRevisionEditorInput(IFileState state) {
this(state, state);
}
public FileRevisionEditorInput(Object revision, IStorage storage, String charset) {
this(revision, wrapStorage(storage, charset));
}
@Override
public IStorage getStorage() throws CoreException {
return storage;
}
@Override
public boolean exists() {
return true;
}
@Override
public ImageDescriptor getImageDescriptor() {
return null;
}
@Override
public String getName() {
IFileRevision rev = getAdapter(IFileRevision.class);
if (rev != null)
return NLS.bind(TeamUIMessages.nameAndRevision, new String[] { rev.getName(), rev.getContentIdentifier()});
IFileState state = getAdapter(IFileState.class);
if (state != null)
return state.getName() + " " + DateFormat.getInstance().format(new Date(state.getModificationTime())) ; //$NON-NLS-1$
return storage.getName();
}
@Override
public IPersistableElement getPersistable() {
//can't persist
return null;
}
@Override
public String getToolTipText() {
return storage.getFullPath().toString();
}
@Override
@SuppressWarnings("unchecked")
public <T> T getAdapter(Class<T> adapter) {
if (adapter == IWorkbenchAdapter.class)
return (T) this;
if (adapter == IStorage.class)
return (T) storage;
Object object = super.getAdapter(adapter);
if (object != null)
return (T) object;
return Adapters.adapt(fileRevision, adapter);
}
@Override
public Object[] getChildren(Object o) {
return new Object[0];
}
@Override
public ImageDescriptor getImageDescriptor(Object object) {
return null;
}
@Override
public String getLabel(Object o) {
IFileRevision rev = getAdapter(IFileRevision.class);
if (rev != null)
return rev.getName();
return storage.getName();
}
@Override
public Object getParent(Object o) {
return null;
}
@Override
public boolean equals(Object obj) {
if (obj instanceof FileRevisionEditorInput) {
FileRevisionEditorInput other = (FileRevisionEditorInput) obj;
return (other.fileRevision.equals(this.fileRevision));
}
return false;
}
@Override
public int hashCode() {
return fileRevision.hashCode();
}
public IFileRevision getFileRevision() {
if (fileRevision instanceof IFileRevision) {
return (IFileRevision) fileRevision;
}
return null;
}
public URI getURI() {
if (fileRevision instanceof IFileRevision) {
IFileRevision fr = (IFileRevision) fileRevision;
return fr.getURI();
}
return null;
}
}