2020-06-02 11:26:30 +03:00
# Contributing to Catala
2021-03-10 13:15:36 +03:00
The project is open to external contributions, in the spirit of open source.
2020-12-14 12:59:15 +03:00
If you want to open a pull request, please follow the instructions below.
2020-06-02 11:26:30 +03:00
2021-03-10 13:15:36 +03:00
To ask a question to the Catala team, please open an issue on this repository.
You can also join the [Zulip chat ](https://zulip.catala-lang.org/ ) to ask
2021-01-05 21:05:29 +03:00
any questions about the project.
2021-03-10 13:15:36 +03:00
If you want to contribute to the project on a longer-term basis, or if you have
specific competences as a socio-fiscal lawyer or a programming language specialist,
2020-12-14 12:59:15 +03:00
please [contact the authors ](mailto:contact@catala-lang.org ).
The Catala team meets over visioconference once every two weeks.
2020-06-02 11:26:30 +03:00
Please note that the copyright of this code is owned by Inria;
2021-03-10 13:15:36 +03:00
by contributing, you disclaim all copyright interests in favor of Inria.
Both the code for the compiler and the examples in this repository are
2020-12-14 12:59:15 +03:00
distributed under the Apache2 license.
2020-06-02 11:26:30 +03:00
### Writing Catala code
2021-03-10 13:15:36 +03:00
Before writing Catala code, please read the
[tutorial ](https://catala-lang.org/en/examples/tutorial ). You can run the
programs of the tutorial yourself by following the instruction in the
[README of the `examples` directory ](examples/README.md ). Then, it is suggested
that you create a new example directory again according to the instructions of
2020-12-21 18:02:00 +03:00
this README.
Let us now present the typical Catala workflow. First, you need to locate
2021-03-10 13:15:36 +03:00
the legislative text that you want to use as a reference. Then, simply
2020-12-21 18:02:00 +03:00
copy-paste the text into your source file.
2020-06-02 11:26:30 +03:00
2021-03-10 13:15:36 +03:00
First you will have to format the copy-pasted text using Catala headings
2020-12-21 18:02:00 +03:00
and articles markers:
2020-06-02 11:26:30 +03:00
2021-03-10 13:15:36 +03:00
```markdown
## Heading
2020-06-02 11:26:30 +03:00
2021-03-10 13:33:51 +03:00
### Sub-heading (the more '#', the less important)
2020-06-02 11:26:30 +03:00
2021-03-10 13:15:36 +03:00
#### [Legislative atom]
2020-06-02 11:26:30 +03:00
```
2021-03-10 13:15:36 +03:00
Please look at the code of other examples to see how to format things properly.
While formatting the text, don't forget regularly to try and parse your example
2020-12-21 18:02:00 +03:00
using for instance
2020-06-02 11:26:30 +03:00
```
make -C examples/foo foo.tex
```
2021-03-10 13:15:36 +03:00
to see if you've made any syntax errors. Once the text formatting is done, you
can start to annotate each legislative atom (article, provision, etc.) with
2020-12-21 18:02:00 +03:00
some Catala code. To open up a code section in Catala, simply use
2020-06-02 11:26:30 +03:00
2021-03-10 13:15:36 +03:00
~~~markdown
```catala
2020-06-02 11:26:30 +03:00
# In code sections, comments start with #
scope Foo:
< your code goes here >
```
2021-03-10 13:15:36 +03:00
~~~
2020-06-02 11:26:30 +03:00
2021-03-10 13:15:36 +03:00
While all the code sections are equivalent in terms of execution, you can
mark some as "metadata" so that they are printed differently on lawyer-facing
2020-12-21 18:02:00 +03:00
documents. Here's how it works:
2020-06-02 11:26:30 +03:00
2021-03-10 13:15:36 +03:00
~~~markdown
> Begin metadata # > Début métadonnées en français
```catala
2020-06-02 11:26:30 +03:00
declaration structure FooBar:
data foo content boolean
2020-12-10 11:27:51 +03:00
data bar content money
2020-06-02 11:26:30 +03:00
< your structure / enumeration / scope declarations goes here >
```
2021-03-10 13:15:36 +03:00
> End metadata # > Fin métadonnées en français
~~~
Again, make sure to regularly check that your example is parsing correctly. The error message from the compiler should help you debug the syntax if need be. You can also
2020-12-21 18:02:00 +03:00
live-test the programs you wrote by feeding them to the interpreter
2021-03-10 13:15:36 +03:00
(see the [README of the `examples` directory ](examples/README.md )); this will
2020-12-21 18:02:00 +03:00
also type-check the programs, which is useful for debugging them.
2020-06-02 11:26:30 +03:00
## Working on the compiler
2021-03-10 13:15:36 +03:00
The Catala compiler is a standard dune-managed OCaml project.
You can look at the
[online OCaml documentation ](https://catala-lang.org/ocaml_docs/ ) for the
2020-12-21 18:02:00 +03:00
different modules' interfaces as well as high-level architecture documentation.
2020-12-14 12:59:15 +03:00
2021-05-03 18:44:37 +03:00
Please note that the `ocamlformat` version this project uses is `0.18.0` .
2021-03-23 13:40:57 +03:00
Using another version may cause spurious diffs to appear in your pull requests.
2021-05-03 18:44:37 +03:00
### Example: adding a builtin function
The language provides a limited number of builtin functions, which are sometimes
needed for things that can't easily be expressed in Catala itself; in case you
need more, here is how one can be added:
2021-05-04 18:48:52 +03:00
2021-05-03 18:44:37 +03:00
- Choose a name wisely. Be ready to patch any code that already used the name
for scope parameters, variables or structure fields, since it won't compile
anymore.
- Add an element to the `builtin_expression` type in `surface/ast.ml(i)`
- Add your builtin in the `builtins` list in `surface/lexer.ml` , and with proper
translations in all of the language-specific modules `surface/lexer_en.ml` ,
`surface/lexer_fr.ml` , etc.
- The rest can all be done by following the type errors downstream:
- Add a corresponding element to the lower-level AST in `dcalc/ast.ml(i)` , type `unop`
- Extend the translation accordingly in `surface/desugaring.ml`
- Extend the printer (`dcalc/print.ml`) and the typer with correct type
information (`dcalc/typing.ml`)
- Finally, provide the implementations:
2021-05-04 18:48:52 +03:00
- in `lcalc/to_ocaml.ml` , function `format_unop`
- in `dcalc/interpreter.ml` , function `evaluate_operator`
- Update the syntax guide in `doc/syntax/syntax.tex` with your new builtin
2021-05-03 18:44:37 +03:00
2020-12-14 12:59:15 +03:00
## Internationalization
2021-03-10 13:15:36 +03:00
The Catala language should be adapted to any legislative text that follows a
2021-04-02 18:57:44 +03:00
general-to-specifics statutes order. Therefore, there exists multiple versions
2020-12-14 12:59:15 +03:00
of the Catala surface syntax, adapted to the language of the legislative text.
2021-03-10 13:15:36 +03:00
Currently, Catala supports English and French legislative text via the
2021-05-09 23:55:50 +03:00
`--language=en` , `--language=fr` or `--language=pl` option.
2020-12-14 12:59:15 +03:00
2021-03-10 13:15:36 +03:00
Technically, support for new languages can be added via a new lexer. If you want
to add a new language, you can start from
[existing lexer examples ](src/catala/catala_surface/lexer_fr.ml ), tweak and open
a pull request. If you don't feel familiar enough with OCaml to do so, please
2020-12-14 12:59:15 +03:00
leave an issue on this repository.