/* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program 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 this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /* * AbstractTestSetProducer.java * Copyright (C) 2002 University of Waikato, Hamilton, New Zealand * */ package weka.gui.beans; import java.awt.BorderLayout; import java.beans.EventSetDescriptor; import java.io.Serializable; import java.util.Vector; import javax.swing.JPanel; /** * Abstract class for TestSetProducers that contains default * implementations of add/remove listener methods and defualt * visual representation. * * @author Mark Hall * @version $Revision: 1.5 $ * @since 1.0 * @see TestSetProducer */ public abstract class AbstractTestSetProducer extends JPanel implements TestSetProducer, Visible, BeanCommon, Serializable { /** for serialization */ private static final long serialVersionUID = -7905764845789349839L; /** * Objects listening to us */ protected Vector m_listeners = new Vector(); protected BeanVisual m_visual = new BeanVisual("AbstractTestSetProducer", BeanVisual.ICON_PATH+"DefaultTrainTest.gif", BeanVisual.ICON_PATH+"DefaultTrainTest_animated.gif"); /** * non null if this object is a target for any events. */ protected Object m_listenee = null; /** * Logger */ protected transient weka.gui.Logger m_logger = null; /** * Creates a new AbstractTestSetProducer instance. */ public AbstractTestSetProducer() { setLayout(new BorderLayout()); add(m_visual, BorderLayout.CENTER); } /** * Add a listener for test sets * * @param tsl a TestSetListener value */ public synchronized void addTestSetListener(TestSetListener tsl) { m_listeners.addElement(tsl); } /** * Remove a listener for test sets * * @param tsl a TestSetListener value */ public synchronized void removeTestSetListener(TestSetListener tsl) { m_listeners.removeElement(tsl); } /** * Set the visual for this bean * * @param newVisual a BeanVisual value */ public void setVisual(BeanVisual newVisual) { m_visual = newVisual; } /** * Get the visual for this bean * * @return a BeanVisual value */ public BeanVisual getVisual() { return m_visual; } /** * Use the default visual for this bean */ public void useDefaultVisual() { m_visual.loadIcons(BeanVisual.ICON_PATH+"DefaultTrainTest.gif", BeanVisual.ICON_PATH+"DefaultTrainTest_animated.gif"); } /** * Returns true if, at this time, * the object will accept a connection according to the supplied * event name * * @param eventName the event name * @return true if the object will accept a connection */ public boolean connectionAllowed(String eventName) { return (m_listenee == null); } /** * Returns true if, at this time, * the object will accept a connection according to the supplied * EventSetDescriptor * * @param esd the EventSetDescriptor * @return true if the object will accept a connection */ public boolean connectionAllowed(EventSetDescriptor esd) { return connectionAllowed(esd.getName()); } /** * Notify this object that it has been registered as a listener with * a source with respect to the supplied event name * * @param eventName the event name * @param source the source with which this object has been registered as * a listener */ public synchronized void connectionNotification(String eventName, Object source) { if (connectionAllowed(eventName)) { m_listenee = source; } } /** * Notify this object that it has been deregistered as a listener with * a source with respect to the supplied event name * * @param eventName the event name * @param source the source with which this object has been registered as * a listener */ public synchronized void disconnectionNotification(String eventName, Object source) { if (m_listenee == source) { m_listenee = null; } } /** * Set a logger * * @param logger a weka.gui.Logger value */ public void setLog(weka.gui.Logger logger) { m_logger = logger; } /** * Stop any processing that the bean might be doing. * Subclass must implement */ public abstract void stop(); }