Generated from the example.def file:
/* -*- buffer-read-only: t -*- vi: set ro:
*
* DO NOT EDIT THIS FILE (example-fsm.h)
*
* It has been AutoGen-ed Sunday October 1, 2006 at 12:59:12 PM PDT
* From the definitions /home/bkorb/ag/addon/autofsm/example.def
* and the template file fsm
*
* Automated Finite State Machine
*
* Copyright (c) 2001-2006 by Bruce Korb
*
* AutoFSM is free software copyrighted by Bruce Korb.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name ``Bruce Korb'' nor the name of any other
* contributor may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* AutoFSM IS PROVIDED BY Bruce Korb ``AS IS'' AND ANY EXPRESS
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL Bruce Korb OR ANY OTHER CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/*
* This file enumerates the states and transition events for a FSM.
*
* te_ex_state
* The available states. FSS_INIT is always defined to be zero
* and FSS_INVALID and FSS_DONE are always made the last entries.
*
* te_ex_event
* The transition events. These enumerate the event values used
* to select the next state from the current state.
* EX_EV_INVALID is always defined at the end.
*/
#ifndef AUTOFSM_EXAMPLE_FSM_H_GUARD
#define AUTOFSM_EXAMPLE_FSM_H_GUARD
/*
* Finite State machine States
*
* Count of non-terminal states. The generated states INVALID and DONE
* are terminal, but INIT is not :-).
*/
#define EX_STATE_CT 4
typedef enum {
EX_ST_INIT, EX_ST_LONUM, EX_ST_DASH, EX_ST_HINUM, EX_ST_INVALID,
EX_ST_DONE
} te_ex_state;
/*
* Finite State machine transition Events.
*
* Count of the valid transition events
*/
#define EX_EVENT_CT 5
typedef enum {
EX_EV_COMMA, EX_EV_NUM, EX_EV_DASH, EX_EV_BANG, EX_EV_EOL,
EX_EV_INVALID
} te_ex_event;
/*
* Run the FSM. Will return EX_ST_DONE or EX_ST_INVALID
*/
extern te_ex_state
ex_run_fsm(
void* cookie );
#endif /* AUTOFSM_EXAMPLE_FSM_H_GUARD */
/*
* Local Variables:
* mode: C
* c-file-style: "stroustrup"
* tab-width: 4
* indent-tabs-mode: nil
* End:
* end of example-fsm.h */