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
/// Internal namespace.
pub( crate ) mod private
{

  /// Result of generics analyze.
  #[ derive( Debug ) ]
  pub struct GenericsAnalysis
  {
    /// Original generics.
    pub generics : syn::Generics,
    /// Array of names.
    pub names : Vec< syn::Ident >,
  }

  /// To analyze generics.
  pub trait GenericsAnalyze
  {

    /// Analyze generic.
    fn generics_analyze( &self ) -> GenericsAnalysis;

  }

  impl GenericsAnalyze for syn::ItemTrait
  {
    fn generics_analyze( &self ) -> GenericsAnalysis
    {
      let mut names = vec![];
      let generics = self.generics.clone();

      for param in &generics.params
      {
        match param
        {
          syn::GenericParam::Type( type_param ) => names.push( type_param.ident.clone() ),
          syn::GenericParam::Lifetime( lifetime_def ) => names.push( lifetime_def.lifetime.ident.clone() ),
          syn::GenericParam::Const( const_param ) => names.push( const_param.ident.clone() ),
        }
      }

      GenericsAnalysis
      {
        generics,
        names,
      }
    }
  }

}

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

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::*,
    private::GenericsAnalysis,
  };
}

/// Prelude to use essentials: `use my_module::prelude::*`.
pub mod prelude
{
  pub use super::
  {
    private::GenericsAnalyze,
  };
}