
org.ow2.bonita.pvm.model.Transition Maven / Gradle / Ivy
/*
* JBoss, Home of Professional Open Source
* Copyright 2005, JBoss Inc., and individual contributors as indicated
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This 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; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software 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 software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.ow2.bonita.pvm.model;
/**
* a transition in a {@link OpenProcessDefinition} graph.
*
* Guard conditions
*
* TODO
*
*
* Transitions as wait states
*
* A wait condition indicates wether a transition is to be taken synchronously
* or wether the transition will behave as a wait state.
*
*
*
* Transitions that are wait states can occur when an analyst has an actual
* state (e.g. 'making loss') and a desired state (e.g. 'making profit') and
* models a transition between those states. In that case the transition might
* take a long time and hence it results into a wait state for the system.
*
*
*
* If the wait condition is null or if it returns false, then the transition
* will be taking synchronously. Otherwise the transition will behave as a wait
* state and wait for a signal on the execution.
*
*
*
* Transitions as wait states has every thing to do with matching the process
* graph to transactions on the server. If the transition is taken in one (the
* current) transaction, then the async condition should be empty or evaluate to
* false. If the arrival of the execution in the destination node should occur
* in a separate execution
*
* @author Tom Baeyens
*/
public interface Transition extends ObservableElement {
/** the node from which this transition leaves. */
Node getSource();
/** the node in which this transition arrives. */
Node getDestination();
/**
* the general purpose condition that can be used in various ways by the
* activities.
*/
Condition getCondition();
}