Reduce explicit Block state

This doesn't have any effect on the size of the struct (due to alignment
requirements and padding) but reduces the complexity by turning
Block::wants_pop_env into an emergent property dependent on the type rather than
something we have to manually manage.
This commit is contained in:
Mahmoud Al-Qudsi 2024-06-01 13:16:24 -05:00
parent 2e52d51af2
commit ac40807309

View file

@ -66,9 +66,6 @@ pub struct Block {
/// [`BlockType`]-specific data. /// [`BlockType`]-specific data.
/// ///
/// Ideally this would be coalesced into `BlockType` but we currently require that to implement
/// `Copy`, so now we have to awkwardly deal with a discriminant stored separately.
///
/// None of these data fields are accessed on a regular basis (only for shell introspection), so /// None of these data fields are accessed on a regular basis (only for shell introspection), so
/// we store them in a `Box` to reduce the size of the `Block` itself. /// we store them in a `Box` to reduce the size of the `Block` itself.
pub data: Option<Box<BlockData>>, pub data: Option<Box<BlockData>>,
@ -86,10 +83,6 @@ pub struct Block {
/// ///
/// This will saturate at the 65,535th line of a single fish script. I think that's ok! /// This will saturate at the 65,535th line of a single fish script. I think that's ok!
pub src_lineno: Option<NonZeroU16>, pub src_lineno: Option<NonZeroU16>,
/// Whether we should pop the environment variable stack when we're popped off of the block
/// stack.
pub wants_pop_env: bool,
} }
impl Block { impl Block {
@ -97,6 +90,11 @@ impl Block {
pub fn data(&self) -> Option<&BlockData> { pub fn data(&self) -> Option<&BlockData> {
self.data.as_deref() self.data.as_deref()
} }
#[inline(always)]
pub fn wants_pop_env(&self) -> bool {
self.typ() != BlockType::top
}
} }
impl Default for BlockType { impl Default for BlockType {
@ -837,7 +835,6 @@ impl Parser {
if block.typ() != BlockType::top { if block.typ() != BlockType::top {
let new_scope = block.typ() == BlockType::function_call { shadows: true }; let new_scope = block.typ() == BlockType::function_call { shadows: true };
self.vars().push(new_scope); self.vars().push(new_scope);
block.wants_pop_env = true;
} }
let mut block_list = self.block_list.borrow_mut(); let mut block_list = self.block_list.borrow_mut();
@ -852,7 +849,7 @@ impl Parser {
assert!(expected == block_list.len() - 1); assert!(expected == block_list.len() - 1);
block_list.pop().unwrap() block_list.pop().unwrap()
}; };
if block.wants_pop_env { if block.wants_pop_env() {
self.vars().pop(); self.vars().pop();
} }
} }