The following lists a few coding conventions for Trixi.jl:
- Modules, types, structs with
CamelCase
. - Functions, variables with lowercase
snake_case
. - Indentation with 2 spaces (never tabs!), line continuations indented with 4 spaces.
- Maximum line length (strictly): 100.
- Functions that mutate their input are named with a trailing
!
. - Functions order their parameters similar to Julia Base.
- The main modified argument comes first. For example, if the right-hand side
du
is modified, it should come first. If only thecache
is modified, e.g., inprolong2interfaces!
and its siblings, put thecache
first. - Otherwise, use the order
mesh, equations, solver, cache
. - If something needs to be specified in more detail for dispatch, put the additional argument before the general one
that is specified in more detail. For example, we use
have_nonconservative_terms(equations), equations
anddg.mortar, dg
.
- The main modified argument comes first. For example, if the right-hand side
- Prefer
for i in ...
tofor i = ...
for better semantic clarity and greater flexibility. - Executable code should only use ASCII characters.
- Docstrings and comments can and should use Unicode characters where it helps understanding.
- Multiline expressions should be explicitly grouped by parentheses and not rely on Julia's implicit line continuation syntax.
- When naming multiple functions of a single or similar category, prefer to put the
general classification first and the specialization second. Example: Use
flux_central
instead ofcentral_flux
. This helps when searching for available functions on the REPL (e.g., when trying to find all flux functions).
Based on that, and personal experience, a formatting tool with a few helpful
options is included in utils/julia-format.jl
. Note, however, that this tool is
not yet optimal, as it re-indents too greedily.
This is a list of handy style guides that are mostly consistent with each other and this guide, and which have been used as a basis: