diff --git a/noir/noir-repo/compiler/noirc_evaluator/src/ssa/function_builder/data_bus.rs b/noir/noir-repo/compiler/noirc_evaluator/src/ssa/function_builder/data_bus.rs index 38895bb977e..3056fb5973d 100644 --- a/noir/noir-repo/compiler/noirc_evaluator/src/ssa/function_builder/data_bus.rs +++ b/noir/noir-repo/compiler/noirc_evaluator/src/ssa/function_builder/data_bus.rs @@ -9,7 +9,7 @@ use serde::{Deserialize, Serialize}; use super::FunctionBuilder; -#[derive(Clone, Debug, Eq, PartialEq)] +#[derive(Clone, Copy, Debug, Eq, PartialEq)] pub(crate) enum DatabusVisibility { None, CallData(u32), @@ -214,34 +214,27 @@ impl FunctionBuilder { fn deflatten_databus_visibilities( &self, ssa_params: &[ValueId], - flattened_params_databus_visibility: Vec, + mut flattened_params_databus_visibility: Vec, ) -> Vec { - // To do so, create a vec the size of the flattened arguments where the items are the ssa param index they correspond to - let ssa_param_indices: Vec<_> = ssa_params + let ssa_param_sizes: Vec<_> = ssa_params .iter() - .enumerate() - .flat_map(|(ssa_param_index, ssa_param)| { - let flattened_size = - self.current_function.dfg[*ssa_param].get_type().flattened_size(); - std::iter::repeat(ssa_param_index).take(flattened_size) - }) + .map(|ssa_param| self.current_function.dfg[*ssa_param].get_type().flattened_size()) .collect(); let mut is_ssa_params_databus = Vec::with_capacity(ssa_params.len()); - assert!(flattened_params_databus_visibility.len() == ssa_param_indices.len()); - for (databus_visibility, ssa_index) in - flattened_params_databus_visibility.into_iter().zip(ssa_param_indices) - { - if let Some(previous_databus_visibility) = is_ssa_params_databus.get(ssa_index) { - assert!( - *previous_databus_visibility == databus_visibility, - "inconsistent databus visibility for ssa param" - ); - } else { - assert!(ssa_index == is_ssa_params_databus.len()); - is_ssa_params_databus.push(databus_visibility); - } + for size in ssa_param_sizes { + let visibilities: Vec = + flattened_params_databus_visibility.drain(0..size).collect(); + let visibility = visibilities.get(0).copied().unwrap_or(DatabusVisibility::None); + assert!( + visibilities.iter().all(|v| *v == visibility), + "inconsistent databus visibility for ssa param" + ); + is_ssa_params_databus.push(visibility); } + + assert_eq!(is_ssa_params_databus.len(), ssa_params.len()); + is_ssa_params_databus } } diff --git a/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/Nargo.toml b/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/Nargo.toml new file mode 100644 index 00000000000..7c5caf7c771 --- /dev/null +++ b/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/Nargo.toml @@ -0,0 +1,6 @@ +[package] +name = "databus_in_fn_with_empty_arr" +type = "bin" +authors = [""] + +[dependencies] diff --git a/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/Prover.toml b/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/Prover.toml new file mode 100644 index 00000000000..e84e0dd7eec --- /dev/null +++ b/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/Prover.toml @@ -0,0 +1,3 @@ +_empty = [] +value_1 = "1" +value_2 = "2" diff --git a/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/src/main.nr b/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/src/main.nr new file mode 100644 index 00000000000..85671978a33 --- /dev/null +++ b/noir/noir-repo/test_programs/execution_success/databus_in_fn_with_empty_arr/src/main.nr @@ -0,0 +1,3 @@ +fn main(_empty: [u32; 0], value_1: u32, value_2: call_data(0) u32) { + assert_eq(value_1 + 1, value_2); +}