/*-
* Copyright © 2012 Diamond Light Source Ltd.
*
* This file is part of GDA.
*
* GDA is free software: you can redistribute it and/or modify it under the
* terms of the GNU General Public License version 3 as published by the Free
* Software Foundation.
*
* GDA 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 General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along
* with GDA. If not, see <http://www.gnu.org/licenses/>.
*/
package gda.observable;
/**
* Interface for an object that supports type observation
*
*/
public interface Observable<E> {
/**
* Add an object to this objects's list of Observers.
* On adding the observer the Observable will call the Observer's update method.
* @param observer
* object that implement Observer and wishes to be notified by this object
*/
void addObserver(Observer<E> observer) throws Exception;
/**
* Add an object to this objects's list of Observers, in a way that the Observable will send
* events only if they pass the provided predicate.
*
* On adding the observer the Observable will call the Observer's update method.
* @param observer
* object that implement Observer and wishes to be notified by this object
*/
void addObserver(Observer<E> observer, Predicate<E> predicate) throws Exception;
/**
* Delete an object from this objects's list of IObservers.
*
* @param observer
* object that implement Observer and wishes to be notified by this object
*/
void removeObserver(Observer<E> observer);
}