From 801f049969be0ca907b74e53597bec33cba97af4 Mon Sep 17 00:00:00 2001 From: Matthias Schiffer Date: Fri, 19 Apr 2024 23:32:57 +0200 Subject: driver: parse: improve some rule and type names, order from high-level to low-level --- crates/rebel-parse/src/lib.rs | 47 +++++++++++++++++-------------------- crates/rebel-resolve/src/context.rs | 2 +- 2 files changed, 23 insertions(+), 26 deletions(-) diff --git a/crates/rebel-parse/src/lib.rs b/crates/rebel-parse/src/lib.rs index 5857efb..fa72b42 100644 --- a/crates/rebel-parse/src/lib.rs +++ b/crates/rebel-parse/src/lib.rs @@ -1,3 +1,9 @@ +#[derive(Debug, Clone, Copy)] +pub struct TaskRef<'a> { + pub id: TaskID<'a>, + pub args: TaskArgs<'a>, +} + #[derive(Debug, Clone, Copy)] pub struct TaskID<'a> { pub recipe: &'a str, @@ -10,12 +16,6 @@ pub struct TaskArgs<'a> { pub target: Option<&'a str>, } -#[derive(Debug, Clone, Copy)] -pub struct Task<'a> { - pub id: TaskID<'a>, - pub args: TaskArgs<'a>, -} - #[derive(Debug, Clone, Copy)] pub struct TaskFlags { pub force_run: bool, @@ -23,14 +23,16 @@ pub struct TaskFlags { peg::parser! { grammar rules() for str { - rule t(tag: rule<()>, value: rule) -> T - = tag() v:value() { v } - - rule name_char() - = ['a'..='z' | 'A' ..='Z' | '0'..='9' | '_' | '-'] + pub rule task_ref_with_flags() -> (TaskRef<'input>, TaskFlags) + = task:task_ref() flags:task_flags() { (task, flags) } - rule name() -> &'input str - = $(name_char()+) + pub rule task_ref() -> TaskRef<'input> + = id:task_id() args:task_args() { + TaskRef { + id, + args, + } + } rule recipe_id() -> &'input str = $(name() ("/" name())?) @@ -41,7 +43,7 @@ peg::parser! { } rule task_args() -> TaskArgs<'input> - = "@" host:name()? target:t(<":">, )? { + = "@" host:name()? target:tagged(<":">, )? { TaskArgs { host, target, @@ -49,23 +51,18 @@ peg::parser! { } / { Default::default() } - pub rule task() -> Task<'input> - = id:task_id() args:task_args() { - Task { - id, - args, - } - } + rule task_flags() -> TaskFlags + = force_run:force_run() { TaskFlags { force_run } } rule force_run() -> bool = "+" { true } / { false } - rule task_flags() -> TaskFlags - = force_run:force_run() { TaskFlags { force_run } } + rule name() -> &'input str + = $(['a'..='z' | 'A' ..='Z' | '0'..='9' | '_' | '-']+) - pub rule task_with_flags() -> (Task<'input>, TaskFlags) - = task:task() flags:task_flags() { (task, flags) } + rule tagged(tag: rule<()>, value: rule) -> T + = tag() v:value() { v } } } diff --git a/crates/rebel-resolve/src/context.rs b/crates/rebel-resolve/src/context.rs index b8090d1..88d5deb 100644 --- a/crates/rebel-resolve/src/context.rs +++ b/crates/rebel-resolve/src/context.rs @@ -363,7 +363,7 @@ impl Context { } pub fn parse(&self, s: &str) -> error::Result<(TaskRef, TaskFlags)> { - let (parsed, flags) = parse::task_with_flags(s) + let (parsed, flags) = parse::task_ref_with_flags(s) .ok() .context("Invalid task syntax")?; -- cgit v1.2.3