All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy