# std-macro-extensions [![](https://img.shields.io/crates/v/std-macro-extensions.svg)](https://crates.io/crates/std-macro-extensions) [![](https://docs.rs/std-macro-extensions/badge.svg)](https://docs.rs/std-macro-extensions) [![](https://img.shields.io/crates/l/std-macro-extensions.svg)](./LICENSE) [![](https://github.com/ltpp-universe/std-macro-extensions/workflows/Rust/badge.svg)](https://github.com/ltpp-universe/std-macro-extensions/actions?query=workflow:Rust) [Official Documentation](https://docs.ltpp.vip/STD-MACRO-EXTENSIONS/) A collection of macro extensions for Rust's standard library data structures, simplifying the creation and manipulation of common collections such as `HashMap`, `Vec`, and more. ## Features - **Simplified Initialization**: Use macros to easily create instances of common data structures. - **Supports Various Data Structures**: Includes macros for `Vec`, `HashMap`, `Arc`, and more. - **Easy to Use**: Intuitive syntax for quick data structure creation. ## Installation To install `std-macro-extensions` run cmd: ```sh cargo add std-macro-extensions ``` ## Usage Here are some examples of how to use the macros provided by this crate: ### Example: Using `arc!` ```rust use std_macro_extensions::*; fn main() { let value = arc!(5); } ``` ### Example: Using `b_tree_map!` ```rust use std_macro_extensions::*; fn main() { let empty_map: BTreeMap = b_tree_map!(); let b_tree_map_a: BTreeMap<&str, &str> = b_tree_map!( "a" => "a", "b" => "b" ); } ``` ### Example: Using `b_tree_set!` ```rust use std_macro_extensions::*; fn main() { let empty_set: BTreeSet = b_tree_set!(); let number_set: BTreeSet = b_tree_set!(1, 2, 3); } ``` ### Example: Using `binary_heap!` ```rust use std_macro_extensions::*; fn main() { let empty_set: BTreeSet = b_tree_set!(); let number_set: BTreeSet = b_tree_set!(1, 2, 3); } ``` ### Example: Using `boxed!` ```rust use std_macro_extensions::*; fn main() { let boxed_value = boxed!(10); } ``` ### Example: Using `cell!` ```rust use std_macro_extensions::*; fn main() { let cell_value: Cell = cell!(5); } ``` ### Example: Using `hash_map!` ```rust use std_macro_extensions::*; fn main() { let my_map: HashMap<&str, i32> = hash_map!(); let my_map: HashMap<&str, i32> = hash_map!("a" => 1, "b" => 2); } ``` ### Example: Using `hash_set!` ```rust use std_macro_extensions::*; fn main() { let my_set: HashSet = hash_set!(); let my_set: HashSet = hash_set!(1, 2, 3); } ``` ### Example: Using `linked_list!` ```rust use std_macro_extensions::*; fn main() { let my_list: LinkedList = linked_list!(); let my_list: LinkedList = linked_list!(1, 2, 3); } ``` ### Example: Using `mutex!` ```rust use std_macro_extensions::*; fn main() { let my_mutex: Mutex = mutex!(5); let lock: MutexGuard<'_, i32> = my_mutex.lock().unwrap(); } ``` ### Example: Using `rc!` ```rust use std_macro_extensions::*; fn main() { let my_rc = rc!(5); } ``` ### Example: Using `refcell!` ```rust use std_macro_extensions::*; fn main() { use std_macro_extensions::*; let my_refcell = refcell!(5); } ``` ### Example: Using `rw_lock!` ```rust use std_macro_extensions::*; fn main() { let my_rwlock = rw_lock!(5); } ``` ### Example: Using `string!` ```rust use std_macro_extensions::*; fn main() { let empty_string = string!(); let hello_string = string!("Hello"); } ``` ### Example: Using `vector!` ```rust use std_macro_extensions::*; fn main() { let empty_vector: Vec = vector!(); let numbers = vector!(1, 2, 3); } ``` ### Example: Using `vector_deque!` ```rust use std_macro_extensions::*; fn main() { let empty_deque: VecDeque = vector_deque!(); let numbers = vector_deque!(1, 2, 3); } ``` ### Example: Using `join_paths!` ```rust let combined_path: String = join_paths!("/home/", "/user/", "/documents", "file.txt"); let another_path: String = join_paths!("C:/", "/Program Files", "App"); ``` ## Available Macros - `arc!`: Creates an `Arc`. - `vector!`: Creates a `Vec`. - `map!`: Creates a `HashMap`. - `set!`: Creates a `HashSet`. - `b_tree_map!`: Creates a `BTreeMap`. - `b_tree_set!`: Creates a `BTreeSet`. - `list!`: Creates a `LinkedList`. - `heap!`: Creates a `BinaryHeap`. - `string!`: Creates a `String`. - `boxed!`: Creates a `Box`. - `rc!`: Creates an `Rc`. - `arc!`: Creates an `Arc`. - `mutex!`: Creates a `Mutex`. - `rw_lock!`: Creates a `RwLock`. - `cell!`: Creates a `Cell`. - `ref_cell!`: Creates a `RefCell`. - `vector_deque!`: Creates a `VecDeque`. - `join_paths!`: Combines multiple paths into a single valid path, handling overlapping slashes. ## License This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details. ## Contributing Contributions are welcome! Please open an issue or submit a pull request. ## Contact For any inquiries, please reach out to the author at [ltpp-universe ](mailto:root@ltpp.vip).