diff --git a/src/run_program.rs b/src/run_program.rs index 1c9ad831..ef8235bf 100644 --- a/src/run_program.rs +++ b/src/run_program.rs @@ -475,8 +475,7 @@ impl<'a, D: Dialect> RunProgramContext<'a, D> { if cost > effective_max_cost { return err(max_cost_ptr, "cost exceeded"); } - let top = self.op_stack.pop(); - let op = match top { + let op = match self.op_stack.pop() { Some(f) => f, None => break, }; diff --git a/src/traverse_path.rs b/src/traverse_path.rs index 592a7774..30a3c362 100644 --- a/src/traverse_path.rs +++ b/src/traverse_path.rs @@ -52,12 +52,12 @@ pub fn traverse_path(allocator: &Allocator, node_index: &[u8], args: NodePtr) -> let mut byte_idx = node_index.len() - 1; let mut bitmask = 0x01; while byte_idx > first_bit_byte_index || bitmask < last_bitmask { - let is_bit_set: bool = (node_index[byte_idx] & bitmask) != 0; match allocator.sexp(arg_list) { SExp::Atom => { return Err(EvalErr(arg_list, "path into atom".into())); } SExp::Pair(left, right) => { + let is_bit_set = (node_index[byte_idx] & bitmask) != 0; arg_list = if is_bit_set { right } else { left }; } }