6 releases (3 stable)

2.0.0 Jul 11, 2024
2.0.0-rc1 Jul 10, 2024
1.0.1 Jan 18, 2022
1.0.0 Oct 23, 2021
0.1.0-rc2 Oct 23, 2021

#1577 in Procedural macros

Download history 13517/week @ 2024-07-20 14509/week @ 2024-07-27 10006/week @ 2024-08-03 13611/week @ 2024-08-10 17350/week @ 2024-08-17 19140/week @ 2024-08-24 18609/week @ 2024-08-31 16731/week @ 2024-09-07 15721/week @ 2024-09-14 18571/week @ 2024-09-21 19368/week @ 2024-09-28 18389/week @ 2024-10-05 19813/week @ 2024-10-12 22994/week @ 2024-10-19 21207/week @ 2024-10-26 17730/week @ 2024-11-02

84,102 downloads per month
Used in 49 crates (via ext-trait)

Zlib OR MIT OR Apache-2.0

9KB
219 lines

::ext-trait

Annotation to easily define ad-hoc / one-shot extension traits.

Repository Latest version Documentation MSRV unsafe forbidden License CI

Examples

  • Also

    #[macro_use]
    extern crate ext_trait;
    
    #[extension(trait Also)]
    impl<T> T {
        fn also (mut self, f: impl FnOnce(&mut Self))
          -> Self
        {
            f(&mut self);
            self
        }
    }
    
    fn main ()
    {
        use ::std::{collections::HashMap, ops::Not};
    
        let /* immut */ map = HashMap::with_capacity(2).also(|m| {
            m.insert("foo", 42);
            m.insert("bar", 27);
        });
        assert!(map.contains_key("foo"));
        assert!(map.contains_key("bar"));
        assert!(map.contains_key("baz").not());
    }
    
  • WithPath

    #[macro_use]
    extern crate ext_trait;
    
    use ::std::{error::Error, path::{Path, PathBuf}};
    
    #[extension(trait WithPath)]
    impl PathBuf {
        fn with (mut self, segment: impl AsRef<Path>)
          -> PathBuf
        {
            self.push(segment);
            self
        }
    }
    
    fn main ()
      -> Result<(), Box<dyn Error>>
    {
        let some_dir = PathBuf::from(::std::env::var("MY_LIB_SOME_DIR")?);
        // Contrary to chaining `.join()`, this reuses the memory!
        let some_subdir = some_dir.with("some").with("sub").with("dir");
        //
        Ok(())
    }
    
  • Context

    #[macro_use]
    extern crate ext_trait;
    
    use ::std::{error::Error, fmt::Display};
    
    #[extension(trait Context)]
    impl<Ok, Err : Display> Result<Ok, Err> {
        fn context (self, prefix: impl Display)
          -> Result<Ok, String>
        {
            self.map_err(|err| format!("{}: {}", prefix, err))
        }
    }
    
    fn main ()
      -> Result<(), Box<dyn Error>>
    {
        let file_contents =
            ::std::fs::read_to_string("some/file")
                .context("Error when opening some/file")?
        ;
        //
        Ok(())
    }
    

Similar to https://docs.rs/extension-trait, but for the following:

Features

  • Supports generics (see Context)

  • search/grep 'trait TraitName'-friendly!


lib.rs:

Crate not intended for direct use. Use https:://docs.rs/ext-trait instead.

Dependencies

~1.5MB
~37K SLoC