Skip to content

Commit

Permalink
Adds a literal macro for each of the range types.
Browse files Browse the repository at this point in the history
  • Loading branch information
xfbs committed Jan 31, 2024
1 parent 8b2ee44 commit a0fd788
Show file tree
Hide file tree
Showing 4 changed files with 106 additions and 0 deletions.
30 changes: 30 additions & 0 deletions src/inclusive_map.rs
Original file line number Diff line number Diff line change
Expand Up @@ -847,11 +847,41 @@ where
}
}

/// Create a [`RangeInclusiveMap`] from key-value pairs.
///
/// # Example
///
/// ```rust
/// # use rangemap::range_inclusive_map;
/// let map = range_inclusive_map!{
/// 0..=100 => "abc",
/// 100..=200 => "def",
/// 200..=300 => "ghi"
/// };
/// ```
#[macro_export]
macro_rules! range_inclusive_map {
($($k:expr => $v:expr),* $(,)?) => {{
<$crate::RangeInclusiveMap<_, _> as core::iter::FromIterator<_>>::from_iter([$(($k, $v),)*])
}};
}

#[cfg(test)]
mod tests {
use super::*;
use alloc::{format, vec, vec::Vec};

#[test]
fn test_macro() {
assert_eq!(
range_inclusive_map!(0..=100 => "abc", 100..=200 => "def", 200..=300 => "ghi"),
[(0..=100, "abc"), (100..=200, "def"), (200..=300, "ghi")]
.iter()
.cloned()
.collect(),
);
}

trait RangeInclusiveMapExt<K, V> {
fn to_vec(&self) -> Vec<(RangeInclusive<K>, V)>;
}
Expand Down
23 changes: 23 additions & 0 deletions src/inclusive_set.rs
Original file line number Diff line number Diff line change
Expand Up @@ -415,11 +415,34 @@ where
}
}

/// Create a [`RangeInclusiveSet`] from a list of ranges.
///
/// # Example
///
/// ```rust
/// # use rangemap::range_inclusive_set;
/// let set = range_inclusive_set![0..=100, 200..=300, 400..=500];
/// ```
#[macro_export]
macro_rules! range_inclusive_set {
($($range:expr),* $(,)?) => {{
<$crate::RangeInclusiveSet<_> as core::iter::FromIterator<_>>::from_iter([$($range,)*])
}};
}

#[cfg(test)]
mod tests {
use super::*;
use alloc::{format, vec, vec::Vec};

#[test]
fn test_macro() {
assert_eq!(
range_inclusive_set![0..=100, 200..=300, 400..=500],
[0..=100, 200..=300, 400..=500].iter().cloned().collect(),
);
}

trait RangeInclusiveSetExt<T> {
fn to_vec(&self) -> Vec<RangeInclusive<T>>;
}
Expand Down
30 changes: 30 additions & 0 deletions src/map.rs
Original file line number Diff line number Diff line change
Expand Up @@ -742,11 +742,41 @@ where
}
}

/// Create a [`RangeMap`] from key-value pairs.
///
/// # Example
///
/// ```rust
/// # use rangemap::range_map;
/// let map = range_map!{
/// 0..100 => "abc",
/// 100..200 => "def",
/// 200..300 => "ghi"
/// };
/// ```
#[macro_export]
macro_rules! range_map {
($($k:expr => $v:expr),* $(,)?) => {{
<$crate::RangeMap<_, _> as core::iter::FromIterator<_>>::from_iter([$(($k, $v),)*])
}};
}

#[cfg(test)]
mod tests {
use super::*;
use alloc::{format, vec, vec::Vec};

#[test]
fn test_macro() {
assert_eq!(
range_map!(0..100 => "abc", 100..200 => "def", 200..300 => "ghi"),
[(0..100, "abc"), (100..200, "def"), (200..300, "ghi")]
.iter()
.cloned()
.collect(),
);
}

trait RangeMapExt<K, V> {
fn to_vec(&self) -> Vec<(Range<K>, V)>;
}
Expand Down
23 changes: 23 additions & 0 deletions src/set.rs
Original file line number Diff line number Diff line change
Expand Up @@ -383,11 +383,34 @@ where
}
}

/// Create a [`RangeSet`] from a list of ranges.
///
/// # Example
///
/// ```rust
/// # use rangemap::range_set;
/// let set = range_set![0..100, 200..300, 400..500];
/// ```
#[macro_export]
macro_rules! range_set {
($($range:expr),* $(,)?) => {{
<$crate::RangeSet<_> as core::iter::FromIterator<_>>::from_iter([$($range,)*])
}};
}

#[cfg(test)]
mod tests {
use super::*;
use alloc::{format, vec, vec::Vec};

#[test]
fn test_macro() {
assert_eq!(
range_set![0..100, 200..300, 400..500],
[0..100, 200..300, 400..500].iter().cloned().collect(),
);
}

trait RangeSetExt<T> {
fn to_vec(&self) -> Vec<Range<T>>;
}
Expand Down

0 comments on commit a0fd788

Please sign in to comment.