Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: Add panic for compiler error described in #6620 #6621

Merged
merged 5 commits into from
Nov 26, 2024
Merged
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
49 changes: 49 additions & 0 deletions compiler/noirc_evaluator/src/ssa/opt/flatten_cfg.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1463,4 +1463,53 @@ mod test {
_ => unreachable!("Should have terminator instruction"),
}
}

#[test]
#[should_panic]
fn correctly_handles_branches_merging_into_one_another() {
TomAFrench marked this conversation as resolved.
Show resolved Hide resolved
//! This is a regression test for https://github.com/noir-lang/noir/issues/6620

let separate_return_block_src = "
acir(inline) fn main f0 {
b0(v0: u1):
v1 = allocate -> &mut Field
store Field 0 at v1
jmpif v0 then: b2, else: b1
b2():
jmp b3()
b1():
store Field 2 at v1
jmp b3()
b3():
v5 = load v1 -> Field
constrain v5 == Field 2
return
}
";
let separate_ssa = Ssa::from_str(separate_return_block_src).unwrap();
let separate_ssa = separate_ssa.flatten_cfg();

// This program is much the same as the above except that `b3` has been inlined into `b2`.
// `b2` is both the `then` block and the return block. This means that we don't properly
// switch to handling the `else` block by calling `then_stop` as we do in the above case.
let merged_return_block_src = "
acir(inline) fn main f0 {
b0(v0: u1):
v1 = allocate -> &mut Field
store Field 0 at v1
jmpif v0 then: b2, else: b1
b2():
v5 = load v1 -> Field
constrain v5 == Field 2
return
b1():
store Field 2 at v1
jmp b2()
}
";
let merged_ssa = Ssa::from_str(merged_return_block_src).unwrap();
let merged_ssa = merged_ssa.flatten_cfg();

assert_normalized_ssa_equals(merged_ssa, &separate_ssa.to_string());
}
}