From 0932b0e81591bb77e25a4faf9eb5981e60337841 Mon Sep 17 00:00:00 2001 From: Ethan Uppal <113849268+ethanuppal@users.noreply.github.com> Date: Thu, 19 Dec 2024 08:59:27 -0500 Subject: [PATCH] Cleanup and update names (#2) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Cleanup and update names * Add deprecation notice * remove deprecated functions * fix clippy warning --------- Co-authored-by: Kevin Läufer --- Cargo.toml | 6 +++--- src/{array/mod.rs => array.rs} | 0 src/array/owned.rs | 6 +++--- src/{bv/mod.rs => bv.rs} | 0 src/bv/arithmetic.rs | 5 +---- src/bv/borrowed.rs | 4 ++-- src/bv/indexed.rs | 4 ++-- src/bv/{io/mod.rs => io.rs} | 0 src/bv/io/strings.rs | 18 +++++++++--------- src/bv/ops.rs | 4 ++-- src/bv/owned.rs | 28 +++++++++++++++++++--------- 11 files changed, 41 insertions(+), 34 deletions(-) rename src/{array/mod.rs => array.rs} (100%) rename src/{bv/mod.rs => bv.rs} (100%) rename src/bv/{io/mod.rs => io.rs} (100%) diff --git a/Cargo.toml b/Cargo.toml index c888f36..cc7607f 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "baa" -version = "0.14.7" +version = "0.15.0" edition = "2021" authors = ["Kevin Laeufer "] description = "BitVector and Array Arithmetic" @@ -14,8 +14,8 @@ rust-version = "1.73.0" [dependencies] # optional dependencies for crate interop -fraction = { version = "0.11", optional = true } -num-bigint = { version = "0.4", optional = true} +fraction = { version = "0.15", optional = true } +num-bigint = { version = "0.4", optional = true } serde = { version = "1.0", features = ["derive"], optional = true } diff --git a/src/array/mod.rs b/src/array.rs similarity index 100% rename from src/array/mod.rs rename to src/array.rs diff --git a/src/array/owned.rs b/src/array/owned.rs index 5606ac0..8c1c703 100644 --- a/src/array/owned.rs +++ b/src/array/owned.rs @@ -290,10 +290,10 @@ impl DenseArrayValue { let elements = 1usize << index_width; let data = if data_width == 1 { - if default.is_tru() { + if default.is_true() { DenseArrayImpl::Bit(BitVecValue::ones(elements as WidthInt)) } else { - debug_assert!(default.is_fals()); + debug_assert!(default.is_false()); DenseArrayImpl::Bit(BitVecValue::zero(elements as WidthInt)) } } else if data_width <= u8::BITS { @@ -388,7 +388,7 @@ impl ArrayMutOps for DenseArrayValue { let words_per_element = self.words_per_element(); match &mut self.data { DenseArrayImpl::Bit(value) => { - if data.is_tru() { + if data.is_true() { value.set_bit(index as WidthInt); } else { value.clear_bit(index as WidthInt); diff --git a/src/bv/mod.rs b/src/bv.rs similarity index 100% rename from src/bv/mod.rs rename to src/bv.rs diff --git a/src/bv/arithmetic.rs b/src/bv/arithmetic.rs index 4d2a225..b15b552 100644 --- a/src/bv/arithmetic.rs +++ b/src/bv/arithmetic.rs @@ -256,10 +256,7 @@ pub(crate) fn shift_right( clear(dst); // check to see if we are shifting for more than our width - let shift_amount = match get_shift_amount(b, width) { - None => return None, - Some(value) => value, - }; + let shift_amount = get_shift_amount(b, width)?; // otherwise we actually perform the shift by converting it to a slice let hi = width - 1; diff --git a/src/bv/borrowed.rs b/src/bv/borrowed.rs index 2e835ae..352c2ff 100644 --- a/src/bv/borrowed.rs +++ b/src/bv/borrowed.rs @@ -94,7 +94,7 @@ impl BitVecOps for BitVecValueRef<'_> { match &self.0 { BitVecValueRefImpl::Word(_, value) => std::slice::from_ref(value), BitVecValueRefImpl::Double(_, value) => value.as_slice(), - BitVecValueRefImpl::Big(_, value) => value.as_ref(), + BitVecValueRefImpl::Big(_, value) => value, } } } @@ -130,7 +130,7 @@ mod tests { use std::hash::{DefaultHasher, Hash, Hasher}; /// Signature is copied from HashTable::get - fn get_hash(key: &Q) -> u64 + fn get_hash(key: &Q) -> u64 where BitVecValue: Borrow, Q: Hash + Eq, diff --git a/src/bv/indexed.rs b/src/bv/indexed.rs index 3dd0bd9..126d5ab 100644 --- a/src/bv/indexed.rs +++ b/src/bv/indexed.rs @@ -330,8 +330,8 @@ mod tests { #[test] fn test_interner() { let mut i = ValueInterner::new(); - assert_eq!(i.get_index(&BitVecValue::tru()).index, 1); - assert_eq!(i.get_index(&BitVecValue::fals()).index, 0); + assert_eq!(i.get_index(&BitVecValue::new_true()).index, 1); + assert_eq!(i.get_index(&BitVecValue::new_false()).index, 0); assert_eq!(i.get_index(&BitVecValue::from_u64(0, 4)).index, 0); assert!(ValueInterner::is_zero( i.get_index(&BitVecValue::from_u64(0, 4)) diff --git a/src/bv/io/mod.rs b/src/bv/io.rs similarity index 100% rename from src/bv/io/mod.rs rename to src/bv/io.rs diff --git a/src/bv/io/strings.rs b/src/bv/io/strings.rs index 533b54c..d198aeb 100644 --- a/src/bv/io/strings.rs +++ b/src/bv/io/strings.rs @@ -396,8 +396,8 @@ mod tests { fn test_to_bit_str_with_extra_words() { let value = BitVecValue::zero(7); let input = value.words(); - assert_eq!(to_bit_str(&input, 7), "0000000"); - assert_eq!(to_bit_str(&input, 33), "0".repeat(33)); + assert_eq!(to_bit_str(input, 7), "0000000"); + assert_eq!(to_bit_str(input, 33), "0".repeat(33)); } #[test] @@ -410,27 +410,27 @@ mod tests { fn test_to_hex_str() { let mut value = BitVecValue::zero(64); let input = value.words_mut(); - assert_eq!(to_hex_str(&input, 7), "00"); - assert_eq!(to_hex_str(&input, 33), "0".repeat(9)); + assert_eq!(to_hex_str(input, 7), "00"); + assert_eq!(to_hex_str(input, 33), "0".repeat(9)); input[0] = 0xa4aa78; - assert_eq!(to_hex_str(&input, 6 * 4), "a4aa78"); + assert_eq!(to_hex_str(input, 6 * 4), "a4aa78"); let mut value = BitVecValue::zero(128); let input = value.words_mut(); input[0] = 0xaaaaaaaaaaaaaaaa; - assert_eq!(to_hex_str(&input, 7 + Word::BITS), "00aaaaaaaaaaaaaaaa"); + assert_eq!(to_hex_str(input, 7 + Word::BITS), "00aaaaaaaaaaaaaaaa"); assert_eq!( - to_hex_str(&input, 33 + Word::BITS), + to_hex_str(input, 33 + Word::BITS), format!("{}aaaaaaaaaaaaaaaa", "0".repeat(9)) ); input[1] = 0xa4aa78; assert_eq!( - to_hex_str(&input, 6 * 4 + Word::BITS), + to_hex_str(input, 6 * 4 + Word::BITS), "a4aa78aaaaaaaaaaaaaaaa" ); // regressions test let mut value = BitVecValue::zero(64); let input = value.words_mut(); input[0] = 768603298337958570; - assert_eq!(to_hex_str(&input, 64), "0aaaa0a0aaa0aaaa"); + assert_eq!(to_hex_str(input, 64), "0aaaa0a0aaa0aaaa"); } } diff --git a/src/bv/ops.rs b/src/bv/ops.rs index a19e120..5224ecf 100644 --- a/src/bv/ops.rs +++ b/src/bv/ops.rs @@ -185,11 +185,11 @@ pub trait BitVecOps { } } - fn is_tru(&self) -> bool { + fn is_true(&self) -> bool { self.width() == 1 && self.words()[0] == 1 } - fn is_fals(&self) -> bool { + fn is_false(&self) -> bool { self.width() == 1 && self.words()[0] == 0 } diff --git a/src/bv/owned.rs b/src/bv/owned.rs index 7fdee78..96052f2 100644 --- a/src/bv/owned.rs +++ b/src/bv/owned.rs @@ -77,8 +77,8 @@ impl From for W { } } -const FALS_VALUE: BitVecValueImpl = BitVecValueImpl::new_word(0, 1); -const TRU_VALUE: BitVecValueImpl = BitVecValueImpl::new_word(1, 1); +const FALSE_VALUE: BitVecValueImpl = BitVecValueImpl::new_word(0, 1); +const TRUE_VALUE: BitVecValueImpl = BitVecValueImpl::new_word(1, 1); impl BitVecValue { /// Parse a string of 1s and 0s. The width of the resulting value is the number of digits. @@ -155,9 +155,9 @@ impl BitVecValue { pub fn from_bool(value: bool) -> Self { if value { - Self::tru() + Self::new_true() } else { - Self::fals() + Self::new_false() } } @@ -200,11 +200,21 @@ impl BitVecValue { } #[inline] + pub fn new_true() -> Self { + Self(TRUE_VALUE.clone()) + } + #[inline] + pub fn new_false() -> Self { + Self(FALSE_VALUE.clone()) + } + + #[deprecated(since = "0.15.0", note = "please use `new_true` instead")] pub fn tru() -> Self { - Self(TRU_VALUE.clone()) + Self::new_true() } + #[deprecated(since = "0.15.0", note = "please use `new_false` instead")] pub fn fals() -> Self { - Self(FALS_VALUE.clone()) + Self::new_false() } #[cfg(feature = "bigint")] @@ -334,9 +344,9 @@ mod tests { } #[test] - fn test_tru_fals() { - assert!(BitVecValue::tru().to_bool().unwrap()); - assert!(!BitVecValue::fals().to_bool().unwrap()); + fn test_true_false() { + assert!(BitVecValue::new_true().to_bool().unwrap()); + assert!(!BitVecValue::new_false().to_bool().unwrap()); } #[test]