/*****************************************************************
JADE - Java Agent DEvelopment Framework is a framework to develop
multi-agent systems in compliance with the FIPA specifications.
Copyright (C) 2000 CSELT S.p.A.
GNU Lesser General Public License
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation,
version 2.1 of the License.
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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the
Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*****************************************************************/
package jade.domain.introspection;
//#APIDOC_EXCLUDE_FILE
import jade.util.leap.List;
import jade.util.leap.ArrayList;
import jade.util.leap.Iterator;
import jade.core.AID;
import jade.content.AgentAction;
/**
This class represents the <code>stop-notify</code> action,
requesting to end a continuous notification of some events via ACL
messages.
@author Giovanni Rimassa - Universita' di Parma
@version $Date: 2005-02-16 18:18:28 +0100 (mer, 16 feb 2005) $ $Revision: 5552 $
*/
public class StopNotify implements AgentAction {
private AID observed;
private List events = new ArrayList();
/**
Default constructor. A default constructor is necessary for
ontological classes.
*/
public StopNotify() {
}
/**
Set the <code>observed</code> slot of this action.
@param id The agent identifier of the agent whose events were
being notified so far.
*/
public void setObserved(AID id) {
observed = id;
}
/**
Retrieve the value of the <code>observed</code> slot of this
event, containing the agent identifier of the agent whose
events were being notified so far.
@return The value of the <code>observed</code> slot, or
<code>null</code> if no value was set.
*/
public AID getObserved() {
return observed;
}
/**
Add an event name to the <code>events</code> slot collection of
this object.
@param evName The event name to add to the collection.
*/
public void addEvents(String evName) {
events.add(evName);
}
/**
Remove all event names from the <code>events</code> slot
collection of this object.
*/
public Iterator getAllEvents() {
return events.iterator();
}
}