4 releases
0.6.0 | Jun 11, 2023 |
---|---|
0.5.3 | Jun 11, 2023 |
0.5.2 | Jun 11, 2023 |
0.5.1 | Jun 11, 2023 |
0.5.0 |
|
#89 in No standard library
20,946 downloads per month
Used in 31 crates
(6 directly)
130KB
1.5K
SLoC
no-std-io
Fork
no-std-io
is a fork of core2.
Overview
Ever wanted a Cursor
or the Error
trait in no_std
? Well now you can have it. A 'fork' of Rust's std
modules for no_std
environments, with the added benefit of optionally taking advantage of alloc
.
The goal of this crate is to provide a stable interface for building I/O and error trait functionality in
no_std
environments. The current code corresponds to the most recent stable API of Rust 1.56.0.
It is also a goal to achieve a true alloc-less experience, with opt-in alloc support.
This crate works on stable
with some limitations in functionality, and nightly
without limitations by adding
the relevant feature flag.
This crate is std
by default -- use no default features to get no_std
mode.
Usage
[dependencies]
no_std_io = "0.5"
Add the crate, use the things you would usually want from std::io
, but instead from no_std_io::io
, and
use no_std_io::error::Error
in place of std::error::Error
.
Features
- std: enables
std
pass-throughs for the polyfilled types, but allows accessing the new types - alloc: enable aspects of the
Read
andWrite
traits that requirealloc
support (WIP) - nightly: enables nightly-only features, such as
BufReader
andBufWriter
with const generic buffers.
Differences to std::io
- No
std::io::Error
, so we have our own copy without anyOs
error functions IoSlice
and the*_vectored
family of functions are not implemented.BufReader
andBufWriter
have a different signature, as they now use a const generic bounded array for the internal buffer. (Requires nightly feature)
Other than items perhaps being entirely missing or certain functions unavailable on some traits, no function signatures have been changed.
Limitations
- Using the buffer types currently requires nightly due to the use of const generics.
- Using
copy
or the buffer types withstd
support currently requires nightly due to theinitializer
API.
License
Licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Almost all of the code in this repository is a copy of the Rust language codebase with minor modifications.
For attributions, see https://thanks.rust-lang.org/.
Dependencies
~250KB