From 8854aa4d7f12eef2a34604ba8546f0ddf88c879f Mon Sep 17 00:00:00 2001 From: "Jip J. Dekker" Date: Tue, 16 Apr 2024 15:47:13 +1000 Subject: [PATCH] Add additional helper methods for VarRange --- crates/pindakaas/src/helpers.rs | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/crates/pindakaas/src/helpers.rs b/crates/pindakaas/src/helpers.rs index 7fa1206542..72f74685d6 100644 --- a/crates/pindakaas/src/helpers.rs +++ b/crates/pindakaas/src/helpers.rs @@ -214,6 +214,23 @@ impl VarRange { Self { start, end } } + /// Returns the lower bound of the variable range (inclusive). + /// + /// Note: the value returned by this method is unspecified after the range + /// has been iterated to exhaustion. + pub fn start(&self) -> Var { + self.start + } + + /// Returns the upper bound of the variable range (inclusive). + /// + /// Note: the value returned by this method is unspecified after the range + /// has been iterated to exhaustion. + pub fn end(&self) -> Var { + self.end + } + + /// Create an empty variable range pub fn empty() -> Self { Self { start: Var(NonZeroI32::new(2).unwrap()), @@ -221,6 +238,17 @@ impl VarRange { } } + /// Returns `true` if the range contains no items. + /// + /// # Examples + /// + /// ``` + /// assert!(VarRange::empty().is_empty()); + /// ``` + pub fn is_empty(&self) -> bool { + self.start > self.end + } + /// Performs the indexing operation into the variable range pub fn index(&self, index: usize) -> Var { if index >= self.len() {