![]() |
mcap repositorypython swift golang serialization data typescript cpp robotics deserialization py_mcap_demo |
Repository Summary
Description | MCAP is a modular, performant, and serialization-agnostic container file format, useful for pub/sub and robotics applications. |
Checkout URI | https://github.com/foxglove/mcap.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-24 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | python swift golang serialization data typescript cpp robotics deserialization |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Packages
Name | Version |
---|---|
py_mcap_demo | 0.0.1 |
README
MCAP
MCAP is a modular container format and logging library for pub/sub messages with arbitrary message serialization. It is primarily intended for use in robotics applications, and works well under various workloads, resource constraints, and durability requirements.
Documentation
Developer quick start
MCAP libraries are provided in the following languages. For guidance on each language, see its corresponding README:
Language | Readme | API docs | Package name | Version |
---|---|---|---|---|
C++ | readme | API docs | mcap |
|
Go | readme | API docs | see releases | |
Python | readme | API docs | mcap |
|
JavaScript/TypeScript | readme | API docs | @mcap/core |
|
Swift | readme | API docs | see releases | |
Rust | readme | API docs | mcap |
To run the conformance tests, you will need to use Git LFS,
which is used to store the test logs under tests/conformance/data
.
MCAP CLI
Inspect, merge, and split MCAP files from the command line using the MCAP CLI.
Install with brew install mcap
or download the latest version directly from the releases page.
License
Release process
Release numbering follows a major.minor.patch format, abbreviated as “X.Y.Z” below.
CI will build the appropriate packages once tags are pushed, as described below.
Go library
- Update the
Version
in go/mcap/version.go - Tag a release matching the version number
go/mcap/vX.Y.Z
.
CLI
Tag a release matching releases/mcap-cli/vX.Y.Z
.
The version number is set at build time based on the tag.
C++
- Update the version in all relevant files
- cpp/bench/conanfile.py
- cpp/build-docs.sh
- cpp/build.sh
- cpp/docs/conanfile.py
- cpp/examples/conanfile.py
- cpp/mcap/include/mcap/types.hpp (
MCAP_LIBRARY_VERSION
) - cpp/mcap/include/conanfile.py
- cpp/test/conanfile.py
- Tag a release matching the version number
releases/cpp/vX.Y.Z
Python
There are several python packages; updating any follows a similar process.
- Update the version in the appropriate
__init__.py
file - Tag a release
- For the core mcap library, match the pattern
releases/python/vX.Y.Z
- For other packages, use
releases/python/PACKAGE/vX.Y.Z
- For example,
releases/python/mcap/v1.2.3
- For example,
- For the core mcap library, match the pattern
TypeScript
There are several TS packages; updating any follows a similar process.
- Update the version in the appropriate
package.json
- Tag a release matching
releases/typescript/PACKAGE/vX.Y.Z
- For example,
releases/typescript/core/v1.2.3
- For example,
Swift
Tag a release matching the version number releases/swift/vX.Y.Z
Rust
- Update the version in rust/Cargo.toml
- Tag a release matching the version number
releases/rust/vX.Y.Z
Citations
If you use MCAP in your research, please cite it in your work. Our suggested citation format is:
File truncated at 100 lines see the full file