Skip to main content

A safe, pure-Python finite state machine with colored terminal logging

Project description

StateLogic

StateLogic doesn’t just manage state. It protects it.

A pure, safe, and elegant finite state machine for Python — with colored terminal logging.

PyPI Tests License

StateLogic is a lightweight, dependency-free finite state machine library that enforces correctness by design.

It was born from frustration with existing FSM libraries that allow invalid states, silent failures, or require complex boilerplate. StateLogic fixes all of that — and adds beautiful colored logging as a bonus.

Design Philosophy — Why StateLogic Is Different (and Better)

"A state machine must never lie about its state."

StateLogic is built on four unbreakable principles:

1. The current state can only be changed via a valid, registered transition

Direct assignment like fsm.state("HACKED") is silently ignored if the state is not part of a defined transition.
This prevents bugs, race conditions, and security issues in critical systems.

2. You cannot set an initial state before defining transitions

fsm = StateLogic()
fsm.state("SOLID")        # → Does nothing (no transitions defined yet)
fsm.state()               # → None

Only after you define at least one transition are states considered "valid":

fsm.transition("melts", "SOLID", "LIQUID")
fsm.state("SOLID")        # → Now allowed

3. Invalid transitions are impossible — not just undetected

If you try to go from GASSOLID without defining that path, nothing happens.
No exception (unless you want one), no silent success — just correctness.

4. Hooks are first-class: before, on, and after

fsm.before("melts", lambda: input("Melt? ") == "Y")
fsm.on("melts", lambda: print("Melting started..."))
fsm.after("melts", lambda: print("Now it's water!"))

This isn't just convenience — it's enforced lifecycle safety.

These rules make StateLogic ideal for:

  • Embedded systems
  • Game logic
  • Workflow engines
  • Protocol implementations
  • Any domain where state corruption is unacceptable

Installation

pip install statelogic

Quick Example

from statelogic import StateLogic

s = StateLogic()
s.author("Wilgat").appName("WaterFSM").majorVersion(1)

# Define valid physics
s.transition("freeze",     "LIQUID", "SOLID")
s.transition("melts",      "SOLID",  "LIQUID")
s.transition("evaporate",  "LIQUID", "GAS")
s.transition("condense",   "GAS",    "LIQUID")

# Try to cheat physics
s.state("PLASMA")          # → Ignored. Still None.
print(s.state())           # → None

# Now play by the rules
s.transition("sublimate", "SOLID", "GAS")  # Define the edge case
s.state("SOLID")           # → Now allowed
s.sublimate()
print(s.state())           # → GAS

s.infoMsg("Sublimation complete!", "SCIENCE")

Output (with colors):

2025-12-02 10:30:45.123456 WaterFSM(v1.0.0)  [SCIENCE]: 
  Sublimation complete!

Features

  • Zero dependencies
  • Python 2.7 and 3.6+ compatible
  • Beautiful colored terminal logging (infoMsg, safeMsg, criticalMsg)
  • Full hook system: before, on, after
  • Dynamic attributes via Attr class
  • Signal handling (Ctrl+C → graceful exit)
  • Shell & environment utilities
  • 100% test coverage

Hook Examples

before — Guard transitions

def confirm():
    return input("Proceed? (y/n): ").lower() == "y"

s.before("launch", confirm)
s.launch()   # Only runs if user says yes

on — React immediately

s.on("error", lambda: s.criticalMsg("System failure!", "ALERT"))

after — Cleanup or notify

s.after("shutdown", lambda: s.safeMsg("System offline.", "BYE"))

Project Links

License

MIT © Wilgat


StateLogic doesn’t just manage state. It protects it.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

statelogic-1.2.2.tar.gz (16.3 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

statelogic-1.2.2-py3-none-any.whl (14.0 kB view details)

Uploaded Python 3

statelogic-1.2.2-py2-none-any.whl (13.9 kB view details)

Uploaded Python 2

File details

Details for the file statelogic-1.2.2.tar.gz.

File metadata

  • Download URL: statelogic-1.2.2.tar.gz
  • Upload date:
  • Size: 16.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for statelogic-1.2.2.tar.gz
Algorithm Hash digest
SHA256 dd02fa24fe0ae4c3f37797a23cb6b1d0472d1c153fadf6ed44583df5505508d8
MD5 3149f35e8967d8090fa731caa2c6c737
BLAKE2b-256 e546de1a692eff3ea01ba2bddded177ff4bb40e56d7f482d38d75920a670cfb5

See more details on using hashes here.

File details

Details for the file statelogic-1.2.2-py3-none-any.whl.

File metadata

  • Download URL: statelogic-1.2.2-py3-none-any.whl
  • Upload date:
  • Size: 14.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for statelogic-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c4976f217506ab2607280ab4aa5adc1bf5aadd078a03cc23f369ca0529492f6e
MD5 80da8856865542e1b93cb97f8096b1a7
BLAKE2b-256 aa11e977683fbef4b808f516af4fd3a9ef35c923986a423b936455e762bb183b

See more details on using hashes here.

File details

Details for the file statelogic-1.2.2-py2-none-any.whl.

File metadata

  • Download URL: statelogic-1.2.2-py2-none-any.whl
  • Upload date:
  • Size: 13.9 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.8.3 requests/2.27.1 setuptools/41.2.0 requests-toolbelt/1.0.0 tqdm/4.64.1 CPython/2.7.18

File hashes

Hashes for statelogic-1.2.2-py2-none-any.whl
Algorithm Hash digest
SHA256 c2896683c95c9551d0dc6455d5315e2936c90bb1294b09288fe3bcdde82534c0
MD5 9a18989057293e585c63eca9d4bf320d
BLAKE2b-256 63e07130c620a9359487897edddcbb79cb0837b83716b9254234dc4440882152

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page