/******************************************************************************
* Copyright (c) 2016 Oracle
* 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:
* Konstantin Komissarchik - initial implementation and ongoing maintenance
******************************************************************************/
package org.eclipse.sapphire.services;
import org.eclipse.sapphire.FilteredListener;
import org.eclipse.sapphire.Property;
import org.eclipse.sapphire.PropertyContentEvent;
/**
* @author <a href="mailto:konstantin.komissarchik@oracle.com">Konstantin Komissarchik</a>
*/
public abstract class ReferenceService<T> extends DataService<T>
{
@Override
protected final void initDataService()
{
context( Property.class ).attach
(
new FilteredListener<PropertyContentEvent>()
{
@Override
protected void handleTypedEvent( final PropertyContentEvent event )
{
refresh();
}
}
);
initReferenceService();
}
protected void initReferenceService()
{
}
public final T target()
{
return data();
}
/**
* Returns the key that can be used to reference the provided object. The default implementation
* throws UnsupportedOperationException.
*
* @param object the object
* @return the key
* @throws UnsupportedOperationException if this service does not support key extraction
* @throws IllegalArgumentException if the object is not a valid target for this reference
*/
public String reference( final T object )
{
throw new UnsupportedOperationException();
}
}