|
|
|
@ -10,7 +10,7 @@ use std::io;
|
|
|
|
|
|
|
|
|
|
enum Scope {
|
|
|
|
|
File,
|
|
|
|
|
Module,
|
|
|
|
|
Target,
|
|
|
|
|
DepList,
|
|
|
|
|
SourceList,
|
|
|
|
|
}
|
|
|
|
@ -44,7 +44,7 @@ impl Parser {
|
|
|
|
|
while let Some(result) = self.lexer.next() {
|
|
|
|
|
let token = result?;
|
|
|
|
|
let node = match token.kind {
|
|
|
|
|
token::Kind::ModuleKeyword => self.parse_module(),
|
|
|
|
|
token::Kind::TargetKeyword => self.parse_target(),
|
|
|
|
|
token::Kind::SetKeyword => self.parse_set_expr(),
|
|
|
|
|
_ => self.syntax_error(format!("Unexpected token {}", token.kind), &token),
|
|
|
|
|
}?;
|
|
|
|
@ -57,8 +57,8 @@ impl Parser {
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn parse_module(&mut self) -> Result<tree::Node, Error> {
|
|
|
|
|
self.scope.push(Scope::Module);
|
|
|
|
|
fn parse_target(&mut self) -> Result<tree::Node, Error> {
|
|
|
|
|
self.scope.push(Scope::Target);
|
|
|
|
|
let name_token = self.lexer.expect_kind(token::Kind::Ident)?;
|
|
|
|
|
self.lexer.expect_kind(token::Kind::OBrace)?;
|
|
|
|
|
|
|
|
|
@ -79,7 +79,7 @@ impl Parser {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
self.scope.pop();
|
|
|
|
|
Ok(tree::Node::Module {
|
|
|
|
|
Ok(tree::Node::Target {
|
|
|
|
|
name: Box::new(tree::Node::Ident(name_token.raw)),
|
|
|
|
|
content: children,
|
|
|
|
|
})
|
|
|
|
|