#![warn(missing_docs)]
#![warn(unused_results)]
#![doc(html_root_url="https://docs.rs/maplit/1/")]
#[macro_export(local_inner_macros)]
macro_rules! hashmap {
(@single $($x:tt)*) => (());
(@count $($rest:expr),*) => (<[()]>::len(&[$(hashmap!(@single $rest)),*]));
($($key:expr => $value:expr,)+) => { hashmap!($($key => $value),+) };
($($key:expr => $value:expr),*) => {
{
let _cap = hashmap!(@count $($key),*);
let mut _map = ::std::collections::HashMap::with_capacity(_cap);
$(
let _ = _map.insert($key, $value);
)*
_map
}
};
}
#[macro_export(local_inner_macros)]
macro_rules! hashset {
(@single $($x:tt)*) => (());
(@count $($rest:expr),*) => (<[()]>::len(&[$(hashset!(@single $rest)),*]));
($($key:expr,)+) => { hashset!($($key),+) };
($($key:expr),*) => {
{
let _cap = hashset!(@count $($key),*);
let mut _set = ::std::collections::HashSet::with_capacity(_cap);
$(
let _ = _set.insert($key);
)*
_set
}
};
}
#[macro_export(local_inner_macros)]
macro_rules! btreemap {
($($key:expr => $value:expr,)+) => (btreemap!($($key => $value),+));
( $($key:expr => $value:expr),* ) => {
{
let mut _map = ::std::collections::BTreeMap::new();
$(
let _ = _map.insert($key, $value);
)*
_map
}
};
}
#[macro_export(local_inner_macros)]
macro_rules! btreeset {
($($key:expr,)+) => (btreeset!($($key),+));
( $($key:expr),* ) => {
{
let mut _set = ::std::collections::BTreeSet::new();
$(
_set.insert($key);
)*
_set
}
};
}
#[doc(hidden)]
pub fn __id<T>(t: T) -> T { t }
#[macro_export(local_inner_macros)]
macro_rules! convert_args {
(keys=$kf:expr, $macro_name:ident !($($k:expr),* $(,)*)) => {
$macro_name! { $(($kf)($k)),* }
};
(keys=$kf:expr, values=$vf:expr, $macro_name:ident !($($k:expr),* $(,)*)) => {
$macro_name! { $(($kf)($k)),* }
};
(keys=$kf:expr, values=$vf:expr, $macro_name:ident !( $($k:expr => $v:expr),* $(,)*)) => {
$macro_name! { $(($kf)($k) => ($vf)($v)),* }
};
(keys=$kf:expr, $macro_name:ident !($($rest:tt)*)) => {
convert_args! {
keys=$kf, values=$crate::__id,
$macro_name !(
$($rest)*
)
}
};
(values=$vf:expr, $macro_name:ident !($($rest:tt)*)) => {
convert_args! {
keys=$crate::__id, values=$vf,
$macro_name !(
$($rest)*
)
}
};
($macro_name:ident ! $($rest:tt)*) => {
convert_args! {
keys=::std::convert::Into::into, values=::std::convert::Into::into,
$macro_name !
$($rest)*
}
};
}
#[test]
fn test_hashmap() {
use std::collections::HashMap;
use std::collections::HashSet;
let names = hashmap!{
1 => "one",
2 => "two",
};
assert_eq!(names.len(), 2);
assert_eq!(names[&1], "one");
assert_eq!(names[&2], "two");
assert_eq!(names.get(&3), None);
let empty: HashMap<i32, i32> = hashmap!{};
assert_eq!(empty.len(), 0);
let _nested_compiles = hashmap!{
1 => hashmap!{0 => 1 + 2,},
2 => hashmap!{1 => 1,},
};
let _: HashMap<String, i32> = convert_args!(keys=String::from, hashmap!(
"one" => 1,
"two" => 2,
));
let _: HashMap<String, i32> = convert_args!(keys=String::from, values=__id, hashmap!(
"one" => 1,
"two" => 2,
));
let names: HashSet<String> = convert_args!(hashset!(
"one",
"two",
));
assert!(names.contains("one"));
assert!(names.contains("two"));
let lengths: HashSet<usize> = convert_args!(keys=str::len, hashset!(
"one",
"two",
));
assert_eq!(lengths.len(), 1);
let _no_trailing: HashSet<usize> = convert_args!(keys=str::len, hashset!(
"one",
"two"
));
}
#[test]
fn test_btreemap() {
use std::collections::BTreeMap;
let names = btreemap!{
1 => "one",
2 => "two",
};
assert_eq!(names.len(), 2);
assert_eq!(names[&1], "one");
assert_eq!(names[&2], "two");
assert_eq!(names.get(&3), None);
let empty: BTreeMap<i32, i32> = btreemap!{};
assert_eq!(empty.len(), 0);
let _nested_compiles = btreemap!{
1 => btreemap!{0 => 1 + 2,},
2 => btreemap!{1 => 1,},
};
}