non_std 0.1.4

Collection of general purpose tools for solving problems. Fundamentally extend the language without spoiling, so may be used solely or in conjunction with another module of such kind.
Documentation
#![ cfg_attr( not( feature = "use_std" ), no_std ) ]
#![ doc( html_logo_url = "https://raw.githubusercontent.com/Wandalen/wTools/master/asset/img/logo_v3_trans_square.png" ) ]
#![ doc( html_favicon_url = "https://raw.githubusercontent.com/Wandalen/wTools/alpha/asset/img/logo_v3_trans_square_icon_small_v2.ico" ) ]
#![ doc( html_root_url = "https://docs.rs/diagnostics_tools/latest/diagnostics_tools/" ) ]
#![ warn( rust_2018_idioms ) ]
#![ warn( missing_debug_implementations ) ]
#![ warn( missing_docs ) ]

//!
//! Diagnostics tools.
//!

#![ doc = include_str!( concat!( env!( "CARGO_MANIFEST_DIR" ), "/Readme.md" ) ) ]

/// Compile-time asserting.
pub mod diagnostics;
/// Compile-time asserting of memory layout.
pub mod layout;

/// Dependencies.
pub mod dependencies
{
  #[ cfg( feature = "runtime_assertions" ) ]
  pub use ::pretty_assertions;
}

/// Protected namespace of the module.
pub mod protected
{
  pub use super::orphan::*;
  #[ doc( inline ) ]
  pub use super::diagnostics::orphan::*;
  #[ doc( inline ) ]
  pub use super::layout::orphan::*;
}

#[ doc( inline ) ]
pub use protected::*;

/// Orphan namespace of the module.
pub mod orphan
{
  pub use super::exposed::*;
}

/// Exposed namespace of the module.
pub mod exposed
{
  pub use super::prelude::*;
  #[ doc( inline ) ]
  pub use super::diagnostics::exposed::*;
  #[ doc( inline ) ]
  pub use super::layout::exposed::*;
}

/// Prelude to use essentials: `use my_module::prelude::*`.
pub mod prelude
{
  #[ doc( inline ) ]
  pub use super::diagnostics::prelude::*;
  #[ doc( inline ) ]
  pub use super::layout::prelude::*;
}