musli_common/
lib.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
//! [<img alt="github" src="https://img.shields.io/badge/github-udoprog/musli-8da0cb?style=for-the-badge&logo=github" height="20">](https://github.com/udoprog/musli)
//! [<img alt="crates.io" src="https://img.shields.io/crates/v/musli-common.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20">](https://crates.io/crates/musli-common)
//! [<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-musli--common-66c2a5?style=for-the-badge&logoColor=white&logo=" height="20">](https://docs.rs/musli-common)
//!
//! Common utilities shared by [Müsli] encodings.
//!
//! The [Reader] and [Writer] traits are defined in here which determined the
//! types that can be used in collaboration with [Müsli].
//!
//! Please refer to <https://docs.rs/musli> for documentation.
//!
//! [Müsli]: <https://docs.rs/musli>
//! [Reader]: https://docs.rs/musli-common/latest/musli-common/reader/trait.Reader.html
//! [Writer]: https://docs.rs/musli-common/latest/musli-common/writer/trait.Writer.html

#![deny(missing_docs)]
#![no_std]
#![cfg_attr(doc_cfg, feature(doc_cfg))]

#[cfg_attr(test, macro_use)]
#[cfg(feature = "std")]
extern crate std;

#[cfg(feature = "alloc")]
extern crate alloc;

pub(crate) mod context;
pub(crate) mod fixed;
#[macro_use]
pub(crate) mod options;
pub(crate) mod buf;
pub(crate) mod reader;
pub(crate) mod wrap;
pub(crate) mod writer;

#[doc(hidden)]
pub mod exports {
    pub mod context {
        //! Helper types to set up a basic Müsli [`Context`].
        //!
        //! [`Context`]: musli::Context

        #[doc(inline)]
        pub use crate::context::*;
    }

    pub mod fixed {
        //! A container which can store up to a fixed number of uninitialized bytes on
        //! the stack and read into and from it.

        #[doc(inline)]
        pub use crate::fixed::FixedBytes;
    }

    pub mod options {
        //! Serialization options.

        #[doc(inline)]
        pub use crate::options::*;
    }

    pub mod buf {
        //! Utilitioes for working with buffers.

        #[doc(inline)]
        pub use crate::buf::*;
    }

    pub mod reader {
        //! Trait for governing how a particular source of bytes is read.
        //!
        //! `musli` requires all sources to reference the complete data being read from
        //! it which allows it to make the assumption the bytes are always returned with
        //! the `'de` lifetime.

        #[doc(inline)]
        pub use crate::reader::*;
    }

    pub mod wrap {
        //! Helpers for integrating musli with I/O types like [std::io] and
        //! [std::io::Write].
        //!
        //! The central function in this module is the [wrap] function which constructs
        //! an adapter around an I/O type to work with musli.

        #[doc(inline)]
        pub use crate::wrap::*;
    }

    pub mod writer {
        //! Trait for governing how a particular sink of bytes is written to.
        //!
        //! To adapt [std::io::Write] types, see the [wrap][crate::wrap::wrap] function.

        #[doc(inline)]
        pub use crate::writer::*;
    }

    #[doc(inline)]
    pub use musli_allocator as allocator;
}

#[doc(hidden)]
pub mod buffered_writer;

#[doc(hidden)]
pub mod int;

#[doc(hidden)]
pub mod str;

#[macro_use]
mod macros;

#[cfg_attr(feature = "std", path = "system/std.rs")]
#[cfg_attr(not(feature = "std"), path = "system/no_std.rs")]
mod system;