littlefs2

Crates.iolittlefs2
lib.rslittlefs2
version0.5.0
sourcesrc
created_at2019-12-15 11:07:18.206746
updated_at2024-10-25 09:02:16.610956
descriptionIdiomatic Rust API for littlefs
homepage
repositoryhttps://github.com/trussed-dev/littlefs2
max_upload_size
id189525
size130,327
publishers (github:trussed-dev:publishers)

documentation

https://docs.rs/littlefs2

README

littlefs2

Idiomatic Rust API for littlefs

Crates.io version API docs CI

What is this?

Idiomatic Rust API for the littlefs microcontroller filesystem by Chris Haster.

Number 2 refers to the on-disk format version, supporting inline files, custom attributes and dynamic wear-leveling.

We follow std::fs as much as reasonable.

The low-level bindings are provided by the littlefs2-sys library.

The core types that are independent of a specific implementation version are provided by the littlefs2-core crate, see the core directory. These types are re-exported from the littlefs2 crate too.

Upstream release: v2.2.1

no_std

This library is no_std compatible, but there are two gotchas.

  • The dev-dependency memchr of littlefs2-sys has its std features activated. To prevent this, upgrade to at least Rust 1.51 and add resolver = "2" in the consuming code's [package] section. This will be the default in Rust 2021 edition.

  • At link time, lfs.c has a dependency on strcpy. When not linking to a libc with this symbol, activate the c-stubs feature to provide an implementation.

License

littlefs is licensed under BSD-3-Clause. This API for littlefs is licensed under either of Apache License, Version 2.0 or MIT License at your option. Previous bindings exist in the rust-littlefs repository, also dual-licensed under Apache-2.0 and MIT.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Commit count: 136

cargo fmt