Catala is a domain-specific language for deriving faithful-by-construction algorithms from legislative texts. To learn quickly about the language and its features, you can jump right to the official Catala tutorial. You can join the Catala community on Zulip!
Catala is a programming language adapted for socio-fiscal legislative literate programming. By annotating each line of the legislative text with its meaning in terms of code, one can derive an implementation of complex socio-fiscal mechanisms that enjoys a high level of assurance regarding the code-law faithfulness.
Concretely, you have to first gather all the laws, executive orders, previous cases, etc. that contain information about the socio-fiscal mechanism that you want to implement. Then, you can proceed to annotate the text article by article, in your favorite text editor :
Once your code is complete and tested, you can use the Catala compiler to produce a lawyer-readable PDF version of your implementation. The Catala language has been specially designed in collaboration with law professionals to ensure that the code can be reviewed and certified correct by the domain experts, which are in this case lawyers and not programmers.
The Catala language is special because its logical structure mimics the logical structure of the law. Indeed, the core concept of "definition-under-conditions" that builds on default logic has been formalized by Professor Sarah Lawsky in her article A Logic for Statutes. The Catala language is the only programming language to our knowledge that embeds default logic as a first-class feature, which is why it is the only language perfectly adapted to literate legislative programming.
To get started, the best place is the tutorial of the language. A French version is also available but might be out of sync with the latest language features.
Note: bleeding-edge version
If you are interested in the latest development version, pre-built artifacts including binaries and API documentation can be found at https://catalalang.github.io/catala
Catala is available as an opam package! If opam is installed on your machine, simply execute:
opam install catala
To get the cutting-edge, latest version of Catala, you can also do
opam pin add catala --dev-repo
However, if you wish to get the latest developments of the compiler, you probably want to compile it from the sources of this repository or use nix. For that, see the dedicated readme.
Note: the --locked
flag can be added to the above commands to more closely
mimic known working dev setups. Conversely, opam lock
should be called to
regenerate the catala.opam.locked
file upon modifications of the main opam
file.
Use catala --help
if you have installed it to get more information about the
command line options available. The man page is also available
online. To get the development version
of the help, run make help_catala
after make build
. The catala
binary
corresponds to the Catala compiler.
The top-level Makefile
contains a lot of useful targets to run. To display
them, use
make help
While the compiler has some builtin backends for Catala (Python, Ocaml, etc.), it is also possible to add a custom backend to the Catala compiler without having to modify its source code. This plugin solution relies on dynamic linking: see the dedicated README.
Use clerk --help
if you have installed it to get more information about the
command line options available. To get the development version of the help, run
make help_clerk
after make build
. The clerk
binary corresponds to the
Catala build system, responsible for testing among other things.
To get more information about Clerk, see the dedicated readme
Catleg is a command line utility providing useful integration with LégiFrance, the official repository of French legal documentation. See the decidated repository for more information.
Syntax highlighting is available for several text-editors. Scripts can be found here.
A VSCode extension for Catala is available on the marketplace. It bundles a syntax highlighter and a dedicated LSP server which offers support for code navigation, auto-completion along with a UX for test suites. See the dedicated repository for more details.
A code formatting tool, catala-format
is available alongside the LSP
server. If installed, code formatting is directly available in VSCode.
This tool is based on a tree-sitter
grammar for
Catala. See the dedicated
repository for more
details.
A complete and handy reference of the Catala syntax can be found in the cheat sheet (for French and English versions of the syntax).
To audit the formal proof of the partial certification of the Catala compiler, see the dedicated readme.
The documentation is accessible online, both for the latest release and bleeding-edge version.
It is otherwise generated from the compiler source code using
dune
and odoc
. Run
make doc
to generate the documentation, then open the doc/odoc.html
file in any browser.
To explore the different programs written in Catala, see the dedicated readme.
To know how to use the code generated by the Catala compiler in your favorite programming language, head to the readme of the French law library. The corresponding pre-built examples are also available.
To know how you can contribute to the project, see the dedicated readme.
To know how to run or improve the Catala reference test suite, see the dedicated readme.
The compiler and all the code contained in this repository is released under the Apache license (version 2) unless another license is explicited for a sub-directory.
Catala is a research project from Inria, the French National Research Institute for Computer Science. The compiler is yet unstable and lacks some of its features.
The language is named after Pierre Catala, a professor of law who pionneered the French legaltech by creating a computer database of law cases, Juris-Data. The research group that he led in the late 1960s, the Centre d’études et de traitement de l’information juridique (CETIJ), has also influenced the creation by state conselor Lucien Mehl of the Centre de recherches et développement en informatique juridique (CENIJ), which eventually transformed into the entity managing the LegiFrance website, acting as the public service of legislative documentation.