org.apache.mina.statemachine.transition.Transition Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*/
package org.apache.mina.statemachine.transition;
import org.apache.mina.statemachine.State;
import org.apache.mina.statemachine.StateMachine;
import org.apache.mina.statemachine.event.Event;
/**
* The interface implemented by classes which need to react on transitions
* between states.
*
* @author Apache MINA Project
*/
public interface Transition {
/**
* Executes this {@link Transition}. It is the responsibility of this
* {@link Transition} to determine whether it actually applies for the
* specified {@link Event}. If this {@link Transition} doesn't apply
* nothing should be executed and false must be returned.
*
* @param event the current {@link Event}.
* @return true if the {@link Transition} was executed,
* false otherwise.
*/
boolean execute(Event event);
/**
* @return the {@link State} which the {@link StateMachine} should move to
* if this {@link Transition} is taken and {@link #execute(Event)} returns
* true. null
if this {@link Transition} is a loopback
* {@link Transition}.
*/
State getNextState();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy