jadex.bdi.planlib.protocols.AbstractInitiatorPlan Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jadex-applib-bdi Show documentation
Show all versions of jadex-applib-bdi Show documentation
The Jadex applib BDI package contains ready to use functionalities for BDI agents mostly in form of modules called capabilities.
package jadex.bdi.planlib.protocols;
import jadex.bdiv3.runtime.IGoal;
import jadex.bdiv3x.runtime.IMessageEvent;
import jadex.bdiv3x.runtime.Plan;
/**
* This plan serves as a base class for initiator plans.
* It automatically handles protocol cancellation when
* the plan is aborted.
*/
public abstract class AbstractInitiatorPlan extends Plan
{
//-------- attributes --------
/** The timeout. */
private long timeout;
//-------- constructors --------
/**
* Initialize the plan
*/
public void body()
{
// Determine timeout.
if(hasParameter("timeout") && getParameter("timeout").getValue()!=null)
{
timeout = ((Long)getParameter("timeout").getValue()).longValue();
}
else if(getBeliefbase().containsBelief("timeout") && getBeliefbase().getBelief("timeout").getFact()!=null)
{
timeout = ((Long)getBeliefbase().getBelief("timeout").getFact()).longValue();
}
else
{
timeout = -1;
}
// Update interaction state
if(hasParameter("interaction_state"))
{
InteractionState state = (InteractionState)getParameter("interaction_state").getValue();
if(state==null)
{
state = new InteractionState();
getParameter("interaction_state").setValue(state);
}
state.setInteractionState(InteractionState.INTERACTION_RUNNING);
}
}
//-------- methods --------
/**
* Get the timeout.
*/
public long getTimeout()
{
return timeout;
}
/**
* Called when the plan is aborted, i.e.,
* when the corresponding interaction goal
* is dropped.
* Terminates the interaction using the
* FIPA-Cancel-Meta-Protocol.
*/
public void aborted()
{
getLogger().info("Initiator aborting");
IGoal cancel = createGoal("cmcap.cm_initiate");
cancel.getParameter("message").setValue(getInitialMessage());
cancel.getParameter("timeout").setValue(Long.valueOf(getTimeout()));
if(hasParameter("interaction_state"))
{
cancel.getParameter("interaction_state").setValue(getParameter("interaction_state").getValue());
}
// System.out.println("Initiator aborting: "+this+", "+getComponentIdentifier());
dispatchSubgoalAndWait(cancel);
// System.out.println("Initiator aborted: "+this+", "+getComponentIdentifier());
getLogger().info("Initiator aborted");
}
//-------- template methods --------
/**
* Get the initial message.
* Has to be provided by subclasses.
* Needed for sending cancel message in
* correct conversation.
*/
protected abstract IMessageEvent getInitialMessage();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy