Pytransitions

Latest version: v0.9.2

Safety actively analyzes 723625 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 2 of 9

0.8.9

- Bugfix 544: `NestedEvent` now wraps the machine's scope into partials passed to `HierarchicalMachine._process`. This prevents queued transitions from losing their scope.
- Feature 533: `(A)Graph.draw` function (object returned by `GraphMachine.get_graph()`) can be passed a file/stream object as first parameter or `None`. The later will result in `draw` returning a binary string. (thanks Blindfreddy).
- Feature 532: Use id(model) instead of model for machine-bound caches in `LockedMachine`, `AsyncMachine` and `GraphMachine`. This might influence pickling (thanks thedrow).

0.8.8

- Bugfix 526: `AsyncMachine` does not remove models when `remove_models` is called (thanks Plazas87)
- Feature 517: Introduce `try/except` for finalize callbacks in `Machine` and `HierachicalMachine`. Thus, errors occurring in finalize callbacks will be suppressed and only the original error will be raised.
- Feature 520: Show references in graphs and markup. Introduce `MarkupMachine.format_references` to tweak reference formatting (thanks StephenCarboni)
- Feature 485: Introduce `Machine.on_exception` to handle raised exceptions in callbacks (thanks thedrow)
- Feature 527: `Machine.get_triggers` now supports `State` and `Enum` as arguments (thanks luup2k)
- Feature 506: `NestedState` and `HierachicalMachine.add_states` now accept (lists of) states and enums as `initial` parameter

0.8.7

- State configuration dictionaries passed to `HierarchicalMachine` can also use `states` as a keyword to define substates. If `children` and `states` are present, only `children` will be considered.
- Feature 500: `HierarchicalMachine` with custom separator now adds `is_state` partials for nested states (e.g. `is_C.s3.a()`) to models (thanks alterscape)
- Bugfix 512: Use `model_attribute` consistently in `AsyncMachine` (thanks thedrow)
- Testing now treats most warnings as errors (thanks thedrow)
- As a consequence, `pygraphviz.Agraph` in `diagrams_pygraphviz` are now copied by `transitions` since `AGraph.copy` as of version `1.6` does not close temporary files appropriately
- `HierarchicalMachine` now checks whether `state_cls`, `event_cls` and `transition_cls` have been subclassed from nested base classes (e.g. `NestedState`) to prevent hard to debug inheritance errors

0.8.6

- `HierarchicalMachine.add_states` will raise a `ValueError` when an `Enum` name contains the currently used `NestedState.separator`.
- Bugfix 486: Reset `NestedState._scope` when enter/exit callbacks raise an exception (thanks m986883511)
- Bugfix 488: Let `HierarchicalMachine._get_trigger` which is bound to `model.trigger` raise a `MachineError` for invalid events and `AttributeError` for unknown events (thanks hsharrison)
- Introduced `HierarchicalMachine.has_trigger` to determine whether an event is valid for an HSM
- Feature 490: `AsyncMachine` features an event queue dictionary for individual models when `queued='model'` (thanks jekel)
- Feature 490: `Machine.remove_model` will now also remove model events from the event queue when `queued=True`
- Feature 491: `Machine.get_transitions` and its HSM counterpart now accept `Enum` and `State` for `source` and `dest` (thanks thedrow)

0.8.5

- `AsyncMachine.switch_model_context` is expected to be `async` now for easier integration of async code during model switch.
- Bugfix 478: Initializing a machine with `GraphSupport` threw an exception when initial was set to a nested or parallel state (thanks nickvazztau)

0.8.4

- Bugfix 477: Model callbacks were not added to a LockedHierarchicalMachine when the machine itself served as a model (thanks oliver-goetz)
- Bugfix 475: Clear collection of tasks to prevent memory leak when initializing many models (thanks h-nakai)
- Feature 474: Added static `AsyncMachine.protected_tasks` list which can be used to prevent `transitions` to cancel certain tasks.
- Feature: Constructor of `HierarchicalMachine` now accepts substates ('A_1_c') and parallel states (['A', 'B']) as `initial` parameter

Page 2 of 9

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.