Skip to content

fadoss/maude-bindings

Repository files navigation

Language bindings for Maude

Language bindings for the Maude specification language using SWIG. They make use of a modified version of Maude extended with a model checker for system controlled by strategies, which is also accessible through the bindings.

The Python package is available at PyPI. After installing it using pip install maude, it can be directly used since Maude is embedded in the package:

import maude
maude.init()
nat = maude.getModule('NAT')
t = nat.parseTerm('1 + 2')
t.reduce()
print(t)

Bindings for other languages supported by SWIG can be built from this repository, but they have not been given specific support and testing. Specific instructions for some of them are available here.

Building

This repository includes the extended version of Maude as a submodule, which has to be cloned first with git submodule update --init or an equivalent Git command. To build the Python package, scikit-build-core is used through any of the standard commands:

python -m build  # or
pip wheel .

This will cause Maude to be built in the subprojects directory, for which the Meson build system, Ninja, and various external libraries and tools are required, as described in its repository. Alternatively, compiled versions of Maude as a library can be downloaded from its releases section and placed in their expected locations:

  • subprojects/maudesmc/installdir/lib for the libraries, and
  • subprojects/maudesmc/build for the config.h header file.

In this case or when building Maude directly from its subdirectory, CMAKE_ARGS="-DBUILD_LIBMAUDE=OFF" should be added before the previous command.

Bindings for other languages can also be built using CMake directly, where srcdir is the directory where the repository has been cloned, and language is one of the languages supported by SWIG:

cmake <srcdir> -DLANGUAGE=<language>
cmake --build .

For some language targets this will be enough, but additional steps could be expected for others.

Documentation

Documentation for the Python package is available here, which can be largely extrapolated to other target languages. Javadoc-generated documentation is also available. In addition to these, the examples in the repository can be used as a reference for various topics:

  • Loading files, parsing terms, reducing, rewriting, rewriting with strategies, and searching in test.py.
  • Matching in match.py.
  • Applying rules selectively in apply.py.
  • Unification in unify.py.
  • Manipulating the rewrite graph in graph.py.
  • Model checking in modelcheck.py.
  • Narrowing in vunarrow.py.
  • Variant generation in variants.py.
  • Iterating over the arguments of a term in gui.py.
  • Building terms from symbols in buildTerm.py.
  • Inspecting modules in maudedoc.py.
  • Loading files and input raw text in loading.py.
  • Metalevel manipulations in metalevel.py.
  • Custom special operators in hooks.py.

Moreover, a tutorial on the library is available in the article Maude as a library: an efficient all-purpose programming interface, along with a description of its design and implementation.