spacepackets/README.md

74 lines
3.5 KiB
Markdown
Raw Normal View History

2022-08-16 11:03:51 +02:00
[![Crates.io](https://img.shields.io/crates/v/spacepackets)](https://crates.io/crates/spacepackets)
[![docs.rs](https://img.shields.io/docsrs/spacepackets)](https://docs.rs/spacepackets)
[![ci](https://github.com/us-irs/spacepackets-rs/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/us-irs/spacepackets-rs/actions/workflows/ci.yml)
2023-12-13 15:39:41 +01:00
[![coverage](https://shields.io/endpoint?url=https://absatsw.irs.uni-stuttgart.de/projects/spacepackets/coverage-rs/latest/coverage.json)](https://absatsw.irs.uni-stuttgart.de/projects/spacepackets/coverage-rs/latest/index.html)
2022-08-16 11:03:51 +02:00
2022-06-18 22:50:08 +02:00
ECSS and CCSDS Spacepackets
======
This package contains generic implementations for various CCSDS
(Consultative Committee for Space Data Systems) and ECSS
(European Cooperation for Space Standardization) packet standards.
Currently, this includes the following components:
- Space Packet implementation according to
[CCSDS Blue Book 133.0-B-2](https://public.ccsds.org/Pubs/133x0b2e1.pdf)
2023-06-12 04:13:41 +02:00
- CCSDS File Delivery Protocol (CFDP) packet implementations according to
[CCSDS Blue Book 727.0-B-5](https://public.ccsds.org/Pubs/727x0b5.pdf)
2022-06-18 22:50:08 +02:00
- PUS Telecommand and PUS Telemetry implementation according to the
[ECSS-E-ST-70-41C standard](https://ecss.nl/standard/ecss-e-st-70-41c-space-engineering-telemetry-and-telecommand-packet-utilization-15-april-2016/).
2023-01-09 11:19:10 +01:00
- CUC (CCSDS Unsegmented Time Code) implementation according to
[CCSDS 301.0-B-4 3.2](https://public.ccsds.org/Pubs/301x0b4e1.pdf)
- CDS (CCSDS Day Segmented Time Code) implementation according to
[CCSDS 301.0-B-4 3.3](https://public.ccsds.org/Pubs/301x0b4e1.pdf)
2023-01-20 20:01:27 +01:00
- Some helper types to support ASCII timecodes as specified in
[CCSDS 301.0-B-4 3.5](https://public.ccsds.org/Pubs/301x0b4e1.pdf)
2022-08-16 10:11:49 +02:00
# Features
2022-09-13 10:21:52 +02:00
`spacepackets` supports various runtime environments and is also suitable for `no_std` environments.
2022-12-19 11:02:36 +01:00
## Default features
2022-08-16 10:11:49 +02:00
2022-08-16 10:51:40 +02:00
- [`std`](https://doc.rust-lang.org/std/): Enables functionality relying on the standard library.
- [`alloc`](https://doc.rust-lang.org/alloc/): Enables features which operate on containers
2022-08-16 10:11:49 +02:00
like [`alloc::vec::Vec`](https://doc.rust-lang.org/beta/alloc/vec/struct.Vec.html).
2022-08-16 11:03:51 +02:00
Enabled by the `std` feature.
2022-12-19 11:02:36 +01:00
## Optional Features
2022-12-04 17:18:10 +01:00
- [`serde`](https://serde.rs/): Adds `serde` support for most types by adding `Serialize` and `Deserialize` `derive`s
2024-03-18 15:14:40 +01:00
- [`chrono`](https://crates.io/crates/chrono): Add basic support for the `chrono` time library.
- [`timelib`](https://crates.io/crates/time): Add basic support for the `time` time library.
2024-03-29 13:42:02 +01:00
- [`defmt`](https://defmt.ferrous-systems.com/): Add support for the `defmt` by adding the
2024-04-03 14:16:42 +02:00
[`defmt::Format`](https://defmt.ferrous-systems.com/format) derive on many types.
2022-09-13 10:31:47 +02:00
# Examples
You can check the [documentation](https://docs.rs/spacepackets) of individual modules for various
usage examples.
2023-12-01 10:33:12 +01:00
# Coverage
Coverage was generated using [`grcov`](https://github.com/mozilla/grcov). If you have not done so
already, install the `llvm-tools-preview`:
```sh
rustup component add llvm-tools-preview
2023-12-01 17:21:36 +01:00
cargo install grcov --locked
2023-12-01 10:33:12 +01:00
```
After that, you can simply run `coverage.py` to test the project with coverage. You can optionally
supply the `--open` flag to open the coverage report in your webbrowser.
2024-05-14 15:37:20 +02:00
# Miri
You can run the [`miri`](https://github.com/rust-lang/miri) tool on this library to check for
undefined behaviour (UB). This library does not use use any `unsafe` code blocks, but `miri` could
still catch UB from used libraries.
```sh
cargo +nightly miri nextest run --all-features
```