/*
* $Id$
*
* Copyright (c) 2009-2010 by Joel Uckelman
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License (LGPL) as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, copies are available
* at http://www.opensource.org.
*/
package VASSAL.property;
import java.util.List;
/**
* An interface for handling {@link PropertyListener}s.
* {@link PropertyContainer}s may delegate listener handling to instances
* of this class.
*
* @since 3.2.0
* @author Joel Uckelman
*/
public interface PropertySupport {
/**
* Adds a listener for all changes.
*
* @param listener the listener to add
*/
public void addPropertyListener(PropertyListener<Object> listener);
/**
* Removes a listner for all changes.
*
* @param listener the listener to remove
*/
public void removePropertyListener(PropertyListener<Object> listener);
/**
* Checks whether there are {@link PropertyListener}s for all changes.
*
* @return {@code true} if there are listeners
*/
public boolean hasListeners();
/**
* Returns a list of {@link PropertyListener}s listening to all changes.
*
* @return a list of listeners
*/
public List<PropertyListener<Object>> getPropertyListeners();
/**
* Adds a listener for a specific {@link Property}.
*
* @param prop the {@link Property} to listen on
* @param listener the listener to add
*/
public <T> void addPropertyListener(Property<T> prop,
PropertyListener<? super T> listener);
/**
* Removes a listener for a specific {@link Property}.
*
* @param prop the {@link Property} listened on
* @param listener the listener to remove
*/
public <T> void removePropertyListener(Property<T> prop,
PropertyListener<? super T> listener);
/**
* Returns a list of {@link PropertyListener}s listening to a given
* {@link Property}.
*
* @param prop the {@link Property} listened on
* @return a list of listeners
*/
public <T> List<PropertyListener<? super T>>
getPropertyListeners(Property<T> prop);
/**
* Checks whether there are {@link PropertyListener}s for a given
* {@link Property}.
*
* @return {@code true} if there are listeners for the given property
*/
public <T> boolean hasListeners(Property<T> prop);
/**
* Notifies listeners of a property change.
*
* @param src the source of the change
* @param prop the changed {@link Property}
* @param oldVal the old value of the {@link Property}
* @param newVal the new value of the {@link Property}
*/
public <T> void fireChanged(Object src, Property<T> prop, T oldVal, T newVal);
}