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
// Rust language amplification library providing multiple generic trait
// implementations, type wrappers, derive macros and other language enhancements
//
// Written in 2019-2022 by
// Dr. Maxim Orlovsky <orlovsky@ubideco.org>
// Martin Habovstiak <martin.habovstiak@gmail.com>
//
// To the extent possible under law, the author(s) have dedicated all
// copyright and related and neighboring rights to this software to
// the public domain worldwide. This software is distributed without
// any warranty.
//
// You should have received a copy of the MIT License
// along with this software.
// If not, see <https://opensource.org/licenses/MIT>.
//! Amplifying Rust language capabilities: multiple generic trait
//! implementations, type wrappers, derive macros.
//!
//! Minimum supported rust compiler version (MSRV): 1.46 (stable channel)
#![cfg_attr(not(feature = "std"), no_std)]
#[cfg(feature = "alloc")]
pub extern crate alloc;
extern crate core;
#[cfg(feature = "derive")]
extern crate amplify_derive;
#[cfg(feature = "derive")]
pub use amplify_derive::{Wrapper, WrapperMut, Display, AsAny, From, Getters, Error};
#[cfg(feature = "serde")]
#[macro_use]
extern crate serde_crate as serde;
extern crate amplify_num;
#[cfg(any(test, feature = "hex"))]
pub use num::hex;
#[cfg(feature = "stringly_conversions")]
pub use stringly_conversions;
#[cfg(feature = "stringly_conversions")]
pub use stringly_conversions::*;
#[cfg(feature = "proc_attr")]
pub use amplify_syn as proc_attr;
#[cfg(feature = "proc_attr")]
pub use proc_attr::ident;
pub use ascii;
#[macro_use]
mod macro_default;
#[cfg(feature = "std")]
#[macro_use]
mod macro_std;
#[cfg(all(feature = "alloc", not(feature = "std")))]
#[macro_use]
mod macro_alloc;
#[cfg(feature = "std")]
mod io_util;
pub mod strategy;
mod collection;
pub use collection::*;
mod traits;
pub use traits::*;
pub mod num {
//! Custom-sized numeric types
//!
//! Implementation of a various integer types with custom bit dimension.
//! These includes:
//! * large signed and unsigned integers, named *gib int types* (256, 512,
//! 1024-bit)
//! * custom sub-8 bit unsigned integers, named *small int types (5-, 6-,
//! 7-bit)
//! * 24-bit signed integer.
//!
//! The functions here are designed to be fast.
pub use amplify_num::*;
#[cfg(feature = "apfloat")]
pub use amplify_apfloat as apfloat;
}
#[cfg(feature = "std")]
pub use crate::io_util::{IoError, WriteCounter, ConfinedIo};
pub use crate::strategy::Holder;