Remove old, unused code from the parser
This commit is contained in:
parent
3f8b554a86
commit
1c8e8b35b9
@ -48,7 +48,6 @@ pub struct Parser<'src> {
|
|||||||
previous_position: Span,
|
previous_position: Span,
|
||||||
|
|
||||||
parsed_expression: bool,
|
parsed_expression: bool,
|
||||||
latest_value_type: Option<Type>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'src> Parser<'src> {
|
impl<'src> Parser<'src> {
|
||||||
@ -71,7 +70,6 @@ impl<'src> Parser<'src> {
|
|||||||
previous_token: Token::Eof,
|
previous_token: Token::Eof,
|
||||||
previous_position: Span(0, 0),
|
previous_position: Span(0, 0),
|
||||||
parsed_expression: false,
|
parsed_expression: false,
|
||||||
latest_value_type: None,
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -160,7 +158,7 @@ impl<'src> Parser<'src> {
|
|||||||
self.minimum_register = next_register;
|
self.minimum_register = next_register;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_staged_operations<const COUNT: usize>(&self) -> Option<[(Operation, Span); COUNT]> {
|
fn get_statement_operations<const COUNT: usize>(&self) -> Option<[(Operation, Span); COUNT]> {
|
||||||
if self.current_statement.len() < COUNT {
|
if self.current_statement.len() < COUNT {
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
@ -176,7 +174,7 @@ impl<'src> Parser<'src> {
|
|||||||
Some(operations)
|
Some(operations)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_staged_jump_mut(&mut self) -> Option<&mut Instruction> {
|
fn get_previous_jump_mut(&mut self) -> Option<&mut Instruction> {
|
||||||
self.current_statement
|
self.current_statement
|
||||||
.iter_mut()
|
.iter_mut()
|
||||||
.rev()
|
.rev()
|
||||||
@ -185,8 +183,6 @@ impl<'src> Parser<'src> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn emit_constant(&mut self, value: Value, position: Span) -> Result<(), ParseError> {
|
fn emit_constant(&mut self, value: Value, position: Span) -> Result<(), ParseError> {
|
||||||
self.latest_value_type = Some(value.r#type());
|
|
||||||
|
|
||||||
let constant_index = self.chunk.push_constant(value, position)?;
|
let constant_index = self.chunk.push_constant(value, position)?;
|
||||||
let register = self.next_register();
|
let register = self.next_register();
|
||||||
|
|
||||||
@ -239,8 +235,6 @@ impl<'src> Parser<'src> {
|
|||||||
position,
|
position,
|
||||||
);
|
);
|
||||||
|
|
||||||
self.latest_value_type = Some(Type::Boolean);
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
} else {
|
} else {
|
||||||
Err(ParseError::ExpectedToken {
|
Err(ParseError::ExpectedToken {
|
||||||
@ -566,7 +560,7 @@ impl<'src> Parser<'src> {
|
|||||||
fn parse_comparison_binary(&mut self) -> Result<(), ParseError> {
|
fn parse_comparison_binary(&mut self) -> Result<(), ParseError> {
|
||||||
if let Some(
|
if let Some(
|
||||||
[(Operation::Jump, _), (Operation::Equal, _) | (Operation::Less, _) | (Operation::LessEqual, _)],
|
[(Operation::Jump, _), (Operation::Equal, _) | (Operation::Less, _) | (Operation::LessEqual, _)],
|
||||||
) = self.get_staged_operations()
|
) = self.get_statement_operations()
|
||||||
{
|
{
|
||||||
return Err(ParseError::CannotChainComparison {
|
return Err(ParseError::CannotChainComparison {
|
||||||
position: self.current_position,
|
position: self.current_position,
|
||||||
@ -640,8 +634,18 @@ impl<'src> Parser<'src> {
|
|||||||
self.push_instruction(right_instruction, right_position);
|
self.push_instruction(right_instruction, right_position);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let register = self.next_register();
|
||||||
|
|
||||||
self.push_instruction(instruction, operator_position);
|
self.push_instruction(instruction, operator_position);
|
||||||
self.push_instruction(Instruction::jump(1, true), operator_position);
|
self.push_instruction(Instruction::jump(1, true), operator_position);
|
||||||
|
self.push_instruction(
|
||||||
|
Instruction::load_boolean(register, true, true),
|
||||||
|
operator_position,
|
||||||
|
);
|
||||||
|
self.push_instruction(
|
||||||
|
Instruction::load_boolean(register, false, false),
|
||||||
|
operator_position,
|
||||||
|
);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
@ -795,7 +799,7 @@ impl<'src> Parser<'src> {
|
|||||||
self.chunk.begin_scope();
|
self.chunk.begin_scope();
|
||||||
|
|
||||||
while !self.allow(Token::RightCurlyBrace)? && !self.is_eof() {
|
while !self.allow(Token::RightCurlyBrace)? && !self.is_eof() {
|
||||||
self.parse_statement(allowed, Context::None)?;
|
self.parse_statement(allowed)?;
|
||||||
}
|
}
|
||||||
|
|
||||||
self.chunk.end_scope();
|
self.chunk.end_scope();
|
||||||
@ -844,6 +848,14 @@ impl<'src> Parser<'src> {
|
|||||||
self.advance()?;
|
self.advance()?;
|
||||||
self.parse_expression()?;
|
self.parse_expression()?;
|
||||||
|
|
||||||
|
if let Some(
|
||||||
|
[(Operation::LoadBoolean, _), (Operation::LoadBoolean, _), (Operation::Jump, _), (Operation::Equal | Operation::Less | Operation::LessEqual, _)],
|
||||||
|
) = self.get_statement_operations()
|
||||||
|
{
|
||||||
|
self.current_statement.pop();
|
||||||
|
self.current_statement.pop();
|
||||||
|
}
|
||||||
|
|
||||||
let block_allowed = Allowed {
|
let block_allowed = Allowed {
|
||||||
assignment: allowed.assignment,
|
assignment: allowed.assignment,
|
||||||
explicit_return: allowed.explicit_return,
|
explicit_return: allowed.explicit_return,
|
||||||
@ -903,6 +915,15 @@ impl<'src> Parser<'src> {
|
|||||||
let jump_start = self.chunk.len() + self.current_statement.len();
|
let jump_start = self.chunk.len() + self.current_statement.len();
|
||||||
|
|
||||||
self.parse_expression()?;
|
self.parse_expression()?;
|
||||||
|
|
||||||
|
if let Some(
|
||||||
|
[(Operation::LoadBoolean, _), (Operation::LoadBoolean, _), (Operation::Jump, _), (Operation::Equal | Operation::Less | Operation::LessEqual, _)],
|
||||||
|
) = self.get_statement_operations()
|
||||||
|
{
|
||||||
|
self.current_statement.pop();
|
||||||
|
self.current_statement.pop();
|
||||||
|
}
|
||||||
|
|
||||||
self.parse_block(Allowed {
|
self.parse_block(Allowed {
|
||||||
assignment: true,
|
assignment: true,
|
||||||
explicit_return: allowed.explicit_return,
|
explicit_return: allowed.explicit_return,
|
||||||
@ -913,7 +934,7 @@ impl<'src> Parser<'src> {
|
|||||||
let jump_distance = jump_end.abs_diff(jump_start) as u8;
|
let jump_distance = jump_end.abs_diff(jump_start) as u8;
|
||||||
let jump_back = Instruction::jump(jump_distance, false);
|
let jump_back = Instruction::jump(jump_distance, false);
|
||||||
|
|
||||||
if let Some(jump_over) = self.get_staged_jump_mut() {
|
if let Some(jump_over) = self.get_previous_jump_mut() {
|
||||||
*jump_over = Instruction::jump(jump_distance - 1, true);
|
*jump_over = Instruction::jump(jump_distance - 1, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -924,7 +945,7 @@ impl<'src> Parser<'src> {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse_statement(&mut self, allowed: Allowed, context: Context) -> Result<(), ParseError> {
|
fn parse_statement(&mut self, allowed: Allowed) -> Result<(), ParseError> {
|
||||||
self.parse(
|
self.parse(
|
||||||
Precedence::None,
|
Precedence::None,
|
||||||
Allowed {
|
Allowed {
|
||||||
@ -939,25 +960,6 @@ impl<'src> Parser<'src> {
|
|||||||
self.current_token,
|
self.current_token,
|
||||||
Token::Eof | Token::RightCurlyBrace | Token::Semicolon
|
Token::Eof | Token::RightCurlyBrace | Token::Semicolon
|
||||||
);
|
);
|
||||||
|
|
||||||
if end_of_statement || context == Context::Assignment {
|
|
||||||
if let Some(
|
|
||||||
[(Operation::Jump, _), (Operation::Equal | Operation::Less | Operation::LessEqual, comparison_position)],
|
|
||||||
) = self.get_staged_operations()
|
|
||||||
{
|
|
||||||
let register = self.next_register();
|
|
||||||
|
|
||||||
self.push_instruction(
|
|
||||||
Instruction::load_boolean(register, true, true),
|
|
||||||
comparison_position,
|
|
||||||
);
|
|
||||||
self.push_instruction(
|
|
||||||
Instruction::load_boolean(register, false, false),
|
|
||||||
comparison_position,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let has_semicolon = self.allow(Token::Semicolon)?;
|
let has_semicolon = self.allow(Token::Semicolon)?;
|
||||||
let returned = self
|
let returned = self
|
||||||
.current_statement
|
.current_statement
|
||||||
@ -1064,14 +1066,7 @@ impl<'src> Parser<'src> {
|
|||||||
let register = self.next_register();
|
let register = self.next_register();
|
||||||
|
|
||||||
self.expect(Token::Equal)?;
|
self.expect(Token::Equal)?;
|
||||||
self.parse_statement(
|
self.parse_expression()?;
|
||||||
Allowed {
|
|
||||||
assignment: false,
|
|
||||||
explicit_return: true,
|
|
||||||
implicit_return: false,
|
|
||||||
},
|
|
||||||
Context::Assignment,
|
|
||||||
)?;
|
|
||||||
|
|
||||||
let local_index = self
|
let local_index = self
|
||||||
.chunk
|
.chunk
|
||||||
@ -1165,14 +1160,11 @@ impl<'src> Parser<'src> {
|
|||||||
function_parser.expect(Token::LeftCurlyBrace)?;
|
function_parser.expect(Token::LeftCurlyBrace)?;
|
||||||
|
|
||||||
while function_parser.current_token != Token::RightCurlyBrace {
|
while function_parser.current_token != Token::RightCurlyBrace {
|
||||||
function_parser.parse_statement(
|
function_parser.parse_statement(Allowed {
|
||||||
Allowed {
|
|
||||||
assignment: true,
|
assignment: true,
|
||||||
explicit_return: true,
|
explicit_return: true,
|
||||||
implicit_return: true,
|
implicit_return: true,
|
||||||
},
|
})?;
|
||||||
Context::None,
|
|
||||||
)?;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function_parser.advance()?;
|
function_parser.advance()?;
|
||||||
|
Loading…
Reference in New Issue
Block a user