blob: c4378c6c9a27f7789523a9230cf129e88e8a096a [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2004 Composent, 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: Composent, Inc. - initial API and implementation
******************************************************************************/
package org.eclipse.ecf.core.identity;
import org.eclipse.core.runtime.Assert;
import org.eclipse.core.runtime.IAdapterManager;
import org.eclipse.ecf.internal.core.identity.Activator;
/**
* Base class for ID implementation classes
*
* Extensions for the <b>org.eclipse.ecf.namespace</b> extension point that
* expose new Namespace subclasses and their own ID implementations are
* recommended (but not required) to use this class as a superclass.
*
*/
public abstract class BaseID implements ID {
private static final long serialVersionUID = -6242599410460002514L;
protected Namespace namespace;
protected BaseID() {
//
}
protected BaseID(Namespace namespace) {
Assert.isNotNull(namespace, "namespace cannot be null"); //$NON-NLS-1$
this.namespace = namespace;
}
/*
* (non-Javadoc)
*
* @see java.lang.Comparable#compareTo(T)
*/
public int compareTo(Object o) {
Assert.isTrue(o != null && o instanceof BaseID, "incompatible types for compare"); //$NON-NLS-1$
return namespace.getCompareToForObject(this, (BaseID) o);
}
/*
* (non-Javadoc)
*
* @see java.lang.Object#equals(java.lang.Object)
*/
public boolean equals(Object o) {
if (o == null)
return false;
if (!(o instanceof BaseID)) {
return false;
}
return namespace.testIDEquals(this, (BaseID) o);
}
/*
* (non-Javadoc)
*
* @see org.eclipse.ecf.core.identity.ID#getName()
*/
public String getName() {
return namespace.getNameForID(this);
}
/*
* (non-Javadoc)
*
* @see org.eclipse.ecf.core.identity.ID#getNamespace()
*/
public Namespace getNamespace() {
return namespace;
}
/*
* (non-Javadoc)
*
* @see java.lang.Object#hashCode()
*/
public int hashCode() {
return namespace.getHashCodeForID(this);
}
/*
* (non-Javadoc)
*
* @see org.eclipse.ecf.core.identity.ID#toExternalForm()
*/
public String toExternalForm() {
return namespace.toExternalForm(this);
}
/**
* Called by {@link Namespace#getCompareToForObject(BaseID, BaseID)}.
*
* @param o the other ID to compare to. Will not be <code>null</code>.
* @return the appropriate value as per {@link Comparable} contract.
*/
protected abstract int namespaceCompareTo(BaseID o);
/**
* Called by {@link Namespace#testIDEquals(BaseID, BaseID)}.
* @param o the other ID to test against. May be <code>null</code>.
* @return <code>true</code> if this ID is equal to the given ID. <code>false</code> otherwise.
*/
protected abstract boolean namespaceEquals(BaseID o);
/**
* Called by {@link Namespace#getNameForID(BaseID)}.
*
* @return String name for this ID. Must not be <code>null</code>. Value returned should be unique within this Namespace.
*/
protected abstract String namespaceGetName();
/**
* Called by {@link Namespace#getHashCodeForID(BaseID)}.
*
* @return int hashCode for this ID. Returned value must be unique within this process.
*/
protected abstract int namespaceHashCode();
/**
* Called by {@link Namespace#toExternalForm(BaseID)}.
*
* @return String that represents this ID. Default implementation is to return
* <pre>
* namespace.getScheme() + Namespace.SCHEME_SEPARATOR + namespaceGetName();
* </pre>
*/
protected String namespaceToExternalForm() {
return namespace.getScheme() + Namespace.SCHEME_SEPARATOR + namespaceGetName();
}
/*
* (non-Javadoc)
*
* @see org.eclipse.core.runtime.IAdaptable#getAdapter(java.lang.Class)
*/
public Object getAdapter(Class clazz) {
IAdapterManager adapterManager = Activator.getDefault().getAdapterManager();
if (adapterManager == null)
return null;
return adapterManager.loadAdapter(this, clazz.getName());
}
}