These guidelines are based on the contributing guidelines for GNU Radio. Since gr-satellites is a GNU Radio out-of-tree module, we follow the same guidelines for consistency wherever it makes sense: coding style, code of conduct, etc.
gr-satellites follows the same coding guidelines as GNU Radio. These are described in GREP1.
For C++, clang-format is used. Formatting is checked in the CI pipeline and
can also be checked locally with the tools/clang_format.py
helper script.
For Python, we follow PEP8. In contrast to GNU Radio, which doesn't use a Python formatting checker, since a large amount of the gr-satellites code base is Python, we use pycodestyle to check PEP8 formatting. This is part of the CI pipeline and can be checked locally by running pycodestyle. Note that there are some [folders that are excluded] (https://github.com/daniestevez/gr-satellites-pycodestyle-action/blob/main/Dockerfile) from pycodestyle checking.
While GNU Radio has most of its code base written in C++, gr-satellites has the majority of its code base written in Python. This allows for a faster development, and performance is often not so critical, since small satellites typically transmit using low data rates. In particular, telemetry parsing is always written in Python using construct.
However, some kinds of blocks are equally simple to implement in C++ or in Python, so C++ should be preferred for those.
The same guidelines as for GNU Radio apply regarding commit messages:
- Keep the lines below 72 characters
- Avoid empty git commit messages
- The git commit message explains the change, the code only explains the current state
If you have an obvious test, that might speed up the time it takes to convince reviewers that your code is correct.
Adding support for a new satellite can be as easy as writing a SatYAML
file describing
the satellite if the satellite only uses protocols already supported by
gr-satellites. Since most satellites use a custom telemetry format, a new telemetry
parser should be written using
construct. See the
python/telemetry
folder for some examples, and take note that your new parser should be added
both to python/telemetry/__index__.py
and to
python/telemetry/CMakeLists.txt
.
For satellites using new or ad-hoc custom protocols, some components will need to be written to support them. Most likely, a new deframer will need to be written. Examples can be found in python/components/deframers.
See also the [note to satellite teams] planning to use gr-satellites for their mission.