From f099bf21c2a72c1670961694d136d16dd0a3241f Mon Sep 17 00:00:00 2001 From: DavePearce Date: Mon, 11 Nov 2024 12:43:16 +0700 Subject: [PATCH] Support checking when domain=-1 Previously, there was no proper checking for failing constraints when the domain of the constraint was `-1`. This is an unexpected bug within the tool. --- Cargo.lock | 2 +- src/check.rs | 13 ++++++++++--- src/column.rs | 7 ++++--- 3 files changed, 15 insertions(+), 7 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 3f280b3..bcd14f6 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -511,7 +511,7 @@ checksum = "06ea2b9bc92be3c2baa9334a323ebca2d6f074ff852cd1d7b11064035cd3868f" [[package]] name = "corset" -version = "9.7.15" +version = "9.7.16" dependencies = [ "anyhow", "ark-bls12-377", diff --git a/src/check.rs b/src/check.rs index 629261a..2555566 100644 --- a/src/check.rs +++ b/src/check.rs @@ -193,7 +193,6 @@ fn fail( .collect(), ) } - let mut trace = String::new(); for ii in 0..m_columns[0].len() { for (j, col) in m_columns.iter().enumerate() { @@ -218,7 +217,6 @@ fn fail( trace.push('\n'); } trace.push('\n'); - bail!( trace + &expr.debug( @@ -299,7 +297,16 @@ fn check_constraint( match domain { Some(is) => { for i in is.iter() { - check_constraint_at(cs, expr, i, true, true, &mut cache, settings)?; + let err = check_constraint_at(cs, expr, i, true, true, &mut cache, settings) + .map_err(|e| CheckingError::FailingConstraint(name.clone(), e.to_string())); + + if err.is_err() { + if settings.continue_on_error { + eprintln!("{:?}", err); + } else { + bail!(err.err().unwrap()); + } + } } } None => { diff --git a/src/column.rs b/src/column.rs index 376353c..6869592 100644 --- a/src/column.rs +++ b/src/column.rs @@ -645,10 +645,11 @@ impl ValueBacking { if i < 0 { if wrap { let new_i = v.len() as isize + i; - if new_i < 0 || new_i >= v.len() as isize { - panic!("abnormal wrapping value {}", new_i) + if new_i < 0 { + Some(v.get(0).unwrap()) + } else { + v.get(new_i as usize) } - v.get((v.len() as isize + i) as usize) } else if i < -spilling { Some(v.get(0).unwrap()) } else {