| Recommend this page to a friend! | 
|  Download | 
| Info | Documentation | Screenshots |  Files |  Install with Composer |  Download | Reputation | Support forum | Blog | Links | 
| Ratings | Unique User Downloads | Download Rankings | ||||
| Not enough user ratings | Total: 50 | All time:  10,720 This week: 63  | ||||
| Version | License | PHP version | Categories | |||
| php-state-machine 1.0 | GNU General Publi... | 5 | PHP 5, Data types | 
| Description | Author | ||||||||||||||||||||||
| This package can define a state machine and process trigger events. | 
 | ||||||||||||||||||||||
<h1 align="center">PHP State Machine</h1>
<p align="center">
<img src="https://github.com/jagarsoft/php-state-machine/raw/master/assets/images/StateMachine-Logo.png" alt="StateMachine Logo" width="150" height="150">
</p>
<p align="center">
<a href="https://scrutinizer-ci.com/g/jagarsoft/php-state-machine/?branch=master"><img src="https://scrutinizer-ci.com/g/jagarsoft/php-state-machine/badges/quality-score.png?b=master" alt="Scrutinizer Code Quality"></a>
<a href="https://scrutinizer-ci.com/g/jagarsoft/php-state-machine/?branch=master"><img src="https://scrutinizer-ci.com/g/jagarsoft/php-state-machine/badges/coverage.png?b=master" alt="Code Coverage"></a>
<a href="https://scrutinizer-ci.com/g/jagarsoft/php-state-machine/build-status/master"><img src="https://scrutinizer-ci.com/g/jagarsoft/php-state-machine/badges/build.png?b=master" alt="Build Status"></a>
<a href="https://packagist.org/packages/jagarsoft/php-state-machine"><img src="https://img.shields.io/packagist/dt/jagarsoft/php-state-machine?style=plastic" alt="Packagist Downloads"></a>
<a href="https://www.php.net/"><img src="https://img.shields.io/badge/language-PHP-green.svg?longCache=true&style=plastic" alt="language PHP"></a>
<a href="http://perso.crans.org/besson/LICENSE.html"><img src="https://img.shields.io/badge/License-GPL-blue.svg?longCache=true&style=plastic" alt="GPL license"></a>
<a href="https://shields.io"><img src="https://img.shields.io/badge/badges-shields.io-green.svg?longCache=true&style=plastic" alt="Badges shields.io"></a>
</p>
It's a data structure made of two key items: * States * Transitions
Transitions go from an initial state to a destination state fired by events.
You can view a State Machine as a graph like this [^1]:

Also, you can think about it, as a double-entry array or _State Transition Table_ indexed by current state and current event. Content will be the next state [^1]:

Bound to the next state, you can set a action function that will be executed when event will be raised at the current state, after run, the new state will be set. In foremention example, output may be the action performed by bound function over some servomotor or something like that (save data, etc).
You can cancel the transition to the next state invoking _cancelTransition_ within action function. Current state will be remain.
Action functions are atomic. If you fire new events in an action function, they will be enqueued, and their action functions, if any, will be invoked consecutively, every time action function return.
If you cancel transition within a nested event, subsequent events may fail if no alternative event is defined for the current state.
Unexpected events for the current state will throw an exception.
You can fire common event from any state, by defining a _addCommonTransition_ with expected event and destination state only, but you must add all states yet.
[^1]: https://en.wikipedia.org/wiki/Finite-state_machine
By _Composer_, just issue next command:
composer require jagarsoft/php-state-machine
$state_1 = StateEnum::STATE_1;
$state_2 = StateEnum::STATE_2;
$state_3 = StateEnum::STATE_3;
$event_a = EventEnum::EVENT_A;
$event_b = EventEnum::EVENT_B;
$event_c = EventEnum::EVENT_C;
echo PHP_EOL;
$commonAction = function (StateMachine $sm){
    echo "My current state is {$sm->getCurrentState()}".
         " on {$sm->getCurrentEvent()}".
         " and {$sm->getNextState()} will be the next state".PHP_EOL;
};
(new StateMachine())
        ->addState($state_1)
        ->addState($state_2)
        ->addState($state_3)
        ->addTransition($state_1, $event_a, $state_2, $commonAction)
        ->addTransition($state_2, $event_b, $state_3, $commonAction)
        ->addTransition($state_3, $event_c, $state_1, $commonAction)
        ->fireEvent($event_a)
        ->fireEvent($event_b)
        ->fireEvent($event_c)
        ->fireEvent($event_a)
        ->fireEvent($event_b)
        ->fireEvent($event_c);
Output:
My current state is 1 on A and 2 will be the next state
My current state is 2 on B and 3 will be the next state
My current state is 3 on C and 1 will be the next state
My current state is 1 on A and 2 will be the next state
My current state is 2 on B and 3 will be the next state
My current state is 3 on C and 1 will be the next state
_StateMachine_ gives you the followings features:
Coming soon... you will be able to create _StateMachine_ from other sources, for instance, DOT definition. _StateMachine_ so created is fully functional and will respond to their events. Moveover, you will be able to save your current _StateMachine_ to that format too.
GNU General Public License v2.0 only
| Screenshots (1) | ||
|  Files (16) | 
| File | Role | Description | ||
|---|---|---|---|---|
|  assets (1 directory) | ||||
|  src (3 files) | ||||
|  tests (1 file, 1 directory) | ||||
|    .scrutinizer.yml | Data | Auxiliary data | ||
|    composer.json | Data | Auxiliary data | ||
|    composer.lock | Data | Auxiliary data | ||
|    LICENSE | Lic. | License text | ||
|    phpunit.xml | Data | Auxiliary data | ||
|    README.md | Doc. | Documentation | ||
|  Files (16) | / | src | 
| File | Role | Description | 
|---|---|---|
|  ActionsKeyEnum.php | Class | Class source | 
|  StateMachine.php | Class | Class source | 
|  StateMachineBuilder.php | Class | Class source | 
|  Files (16) | / | tests | / | Stubs | 
| File | Role | Description | 
|---|---|---|
|  EventEnum.php | Class | Class source | 
|  StateEnum.php | Class | Class source | 
|  StateMachineArrayBuilder.php | Class | Class source | 
|  StateMachineWinzouBuilder.php | Class | Class source | 
| The PHP Classes site has supported package installation using the Composer tool since 2013, as you may verify by reading this instructions page. | 
|  Install with Composer | 
| Version Control | Unique User Downloads | Download Rankings | |||||||||||||||
| 100% | 
 | 
 | 
| Applications that use this package | 
 If you know an application of this package, send a message to the author to add a link here.
 If you know an application of this package, send a message to the author to add a link here.