The SCCD (Statecharts + Class Diagrams) compiler and runtime.

Joeri Exelmans edd93ffb47 notes.txt: Better choice of words 4 년 전
bsml_features e92f44ba01 Rename python src dirs to match installed names (can set to 'src' dir so you don't have to re-install after every change). Updated SCCD schema to accept all existing tests. Added XML namespace to tests. Compiler checks input file against SCCD schema. New compiler dependency 'lxml' (largely compatible with xml.etree) for dealing with XML namespaces and schemas. 5 년 전
examples dacbbec4ee Microwave example: various changes 4 년 전
legacy 7d7f3832fe Remove JavaScript stuff. Move existing SCCD examples, doc and textualnotations to 'legacy' folder. Update setup script. Add digital watch example (doesn't run yet, need to figure out how to connect existing Python code with the statechart model) 5 년 전
src ff9420f0a1 Some long uncommitted changes (not sure exactly what or why) 4 년 전
test 33969e5928 Controller and test framework can deal with bags of (simultaneous) input events. Add examples 19, 20 and 21 from Day & Atlee. 4 년 전
.gitignore a6753bd559 Fixed all tests. 5 년 전
LICENSE 04ec602b01 initial commit (from svn repo) 9 년 전
README.md 29062d730c Add shell.nix file 4 년 전
notes.txt edd93ffb47 notes.txt: Better choice of words 4 년 전
shell.nix 29062d730c Add shell.nix file 4 년 전

README.md

Statechart interpreter with semantic variation

Dependencies

Tip: Users of the Nix package manager can get a usable development environment through the supplied shell.nix file instead of manually installing all dependencies.

Mandatory

  • CPython >= 3.6 or PyPy >= 7.3.0 (Compatible with Python 3.6)
  • The following packages from PyPi:
    • lark-parser for parsing action language code and various fragments of the statechart language (such as target state references in an XPath-like syntax)
    • lxml, wraps the C-library libxml2, used for parsing the statechart XML input format
    • termcolor for colored terminal output
    • dataclasses standard library backport, not needed for Python >= 3.7.

Optional

  • state-machine-cat to render statecharts as SVG images. Runs on NodeJS, installable from NPM.
  • Graphviz dot to render the priorities between a statechart's transitions as a graph.

Installation

There's a setup.py script in the src directory.

Alternatively, you can just set your PYTHONPATH environment variable to the absolute path of the src directory. This is recommended for development.

Running the tests

Assuming you followed the installation instructions above, run:

python3 -m sccd.test.run test/test_files

It will recursively visit the directory tree of test_files and look for XML files starting with with test_ (tests that should succeed) or fail_ (for tests that should fail), and execute them. The tree also contains XML files starting with statechart_: these are individual statechart models that are not directly executable, but are used by test files. The tree also contains SVG files: these contain automatically rendered images of statechart models.

Runtime environment variables

The following environment variables can be set to change the behavior of the runtime. These options can be set while running the tests, or while running one of the examples.

  • SCCDDEBUG: When set, additional debug information is printed, such as a trace of the individual transitions taken.
  • SCCDTIMINGS: When set, at exit, the runtime will print information about how much time in total was spent during various parts of its execution, such as loading the model, generating transition candidates, executing transitions, executing actions, and more.

Included tools

The following Python modules are runnable from terminal:

  • sccd.test.run, already mentioned, runs tests.
  • sccd.statechart.cmd.render will render test files and statecharts as SVG images. Depends on state-machine-cat command. Example of a rendered file
  • sccd.statechart.cmd.render_priorities will render the statechart's transition priorities, as determined by the chosen semantics, as a graph. Depends on dot command. Example of a rendered file
  • sccd.statechart.cmd.check_model will check if a model is valid.
  • sccd.action_lang.cmd.prompt is an interactive prompt for the action language that is part of the statechart language.