15 releases (breaking)

new 0.13.2 Dec 19, 2024
0.12.0 Dec 2, 2024
0.11.0 Oct 30, 2024
0.9.1 Jun 24, 2024
0.5.0 Oct 17, 2022

#80 in Compression

Download history 9992/week @ 2024-09-02 9761/week @ 2024-09-09 8359/week @ 2024-09-16 10714/week @ 2024-09-23 6509/week @ 2024-09-30 6489/week @ 2024-10-07 7040/week @ 2024-10-14 7960/week @ 2024-10-21 5807/week @ 2024-10-28 6314/week @ 2024-11-04 6528/week @ 2024-11-11 7639/week @ 2024-11-18 6602/week @ 2024-11-25 7652/week @ 2024-12-02 6312/week @ 2024-12-09 6632/week @ 2024-12-16

27,525 downloads per month
Used in foc

MIT license

385KB
3K SLoC

Rust MCAP library

A library for reading and writing Foxglove MCAP files. See the crate documentation for examples.

Design goals

  • Simple APIs: Users should be able to iterate over messages, with each automatically linked to its channel, and that channel linked to its schema. Users shouldn't have to manually track channel and schema IDs.

  • Performance: Writers shouldn't hold large buffers (e.g., the current chunk) in memory. Readers should support memory-mapped files to avoid needless copies and to let the OS do what it does best: loading and caching large files based on how you're actually reading them.

  • Resilience: Like MCAP itself, the library should let you recover every valid message from an incomplete file or chunk.

Building

By default this package will build with zstd compression support enabled. To build without the zstd dependency pass the --no-default-features flag:

cargo build --no-default-features

Dependencies

~2.4–9MB
~94K SLoC