mirror of
https://github.com/RGBCube/uutils-coreutils
synced 2025-07-28 03:27:44 +00:00
expr: short-circuit evaluation for &
This commit is contained in:
parent
5f4305df6f
commit
ae1c4ccfd2
1 changed files with 19 additions and 9 deletions
|
@ -166,16 +166,26 @@ impl AstNode {
|
|||
{
|
||||
let mut out = Vec::with_capacity(operands.len());
|
||||
let mut operands = operands.iter();
|
||||
// check the first value before `|`, stop evaluate and return directly if it is true.
|
||||
// push dummy to pass the check of `len() == 2`
|
||||
if op_type == "|" {
|
||||
if let Some(value) = operands.next() {
|
||||
let value = value.evaluate()?;
|
||||
out.push(value.clone());
|
||||
if value_as_bool(&value) {
|
||||
out.push(String::from("dummy"));
|
||||
return Ok(out);
|
||||
|
||||
if let Some(value) = operands.next() {
|
||||
let value = value.evaluate()?;
|
||||
out.push(value.clone());
|
||||
// short-circuit evaluation for `|` and `&`
|
||||
// push dummy to pass `assert!(values.len() == 2);`
|
||||
match op_type.as_ref() {
|
||||
"|" => {
|
||||
if value_as_bool(&value) {
|
||||
out.push(String::from("dummy"));
|
||||
return Ok(out);
|
||||
}
|
||||
}
|
||||
"&" => {
|
||||
if !value_as_bool(&value) {
|
||||
out.push(String::from("dummy"));
|
||||
return Ok(out);
|
||||
}
|
||||
}
|
||||
_ => {}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue