State Machine implementation
# Cannon  Cannon is a State Machine implementation for Smalltalk. [](https://github.com/ba-st/Cannon/actions/workflows/unit-tests.yml/badge.svg) [](https://codecov.io/gh/ba-st/Cannon/branch/release-candidate) [](https://github.com/ba-st/Cannon/actions/workflows/loading-groups.yml) [](https://github.com/ba-st/Cannon/actions/workflows/markdown-lint.yml) [](https://github.com/ba-st/Cannon/releases/latest) [](https://pharo.org) [](https://pharo.org) [](https://pharo.org) [](https://pharo.org) > *Name origin*: Astronomer [Annie Jump Cannon](https://en.wikipedia.org/wiki/Annie_Jump_Cannon). > A cool surname from a celebrity in astronomy, since Cannon works best when > combined with other BA-ST architecture projects, like [Stardust](https://github.com/ba-st/Stardust) > and [Kepler](https://github.com/ba-st/Kepler). With Cannon, we aim to provide a much-needed state machine implementation, which is required for any complex workflow architecture. ## Quick links - [**Explore the docs**](docs/README.md) - [Report a defect](https://github.com/ba-st/Cannon/issues/new?labels=Type%3A+Defect) - [Request a feature](https://github.com/ba-st/Cannon/issues/new?labels=Type%3A+Feature) ## License - The code is licensed under [MIT](LICENSE). - The documentation is licensed under [CC BY-SA 4.0](http://creativecommons.org/licenses/by-sa/4.0/). ## Installation To load the project in a Pharo image follow these [instructions](docs/how-to/how-to-load-in-pharo.md). ## Contributing Check the [Contribution Guidelines](CONTRIBUTING.md) --- > [*Icon pack by Icons8*](https://icons8.com)