From 489fd0db1bf7f1de31a043e315179e83b77921aa Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Sat, 8 Jan 2022 00:28:37 -0500 Subject: add basic variable parsing --- src/shell.pest | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) (limited to 'src/shell.pest') diff --git a/src/shell.pest b/src/shell.pest index ffb0f42..b1bcae5 100644 --- a/src/shell.pest +++ b/src/shell.pest @@ -3,11 +3,17 @@ escape_char = @{ "\\" ~ ANY } bareword_char = @{ escape_char | - !("|" | ";" | "\"" | "'" | WHITESPACE | COMMENT) ~ ANY + !("|" | ";" | "\"" | "'" | "$" | WHITESPACE | COMMENT) ~ ANY } single_string_char = @{ basic_escape_char | (!"'" ~ ANY) } double_string_char = @{ escape_char | (!"\"" ~ ANY) } +var = @{ + ("$" ~ XID_START ~ XID_CONTINUE*) | + ("$" ~ ("?" | "$" | "*" | ASCII_DIGIT)) | + ("${" ~ (!"}" ~ ANY)+ ~ "}") +} + redir_prefix = @{ ASCII_DIGIT* ~ (">>" | ">" | "<") ~ WHITESPACE* } bareword = @{ bareword_char+ } single_string = @{ single_string_char+ } @@ -15,17 +21,17 @@ double_string = @{ double_string_char+ } word = ${ redir_prefix? ~ - (bareword | + (var | bareword | "'" ~ single_string ~ "'" | "\"" ~ double_string ~ "\"") } exe = ${ word ~ (w ~ word)* } -pipeline = ${ exe ~ (w ~ "|" ~ w ~ exe)* } -commands = ${ pipeline ~ (w ~ ";" ~ w ~ pipeline)* } +pipeline = ${ exe ~ (w? ~ "|" ~ w? ~ exe)* } +commands = ${ pipeline ~ (w? ~ ";" ~ w? ~ pipeline)* } -line = ${ SOI ~ w ~ commands ~ w ~ EOI } +line = ${ SOI ~ w? ~ commands ~ w? ~ EOI } -w = _{ (WHITESPACE | COMMENT)* } +w = _{ (WHITESPACE | COMMENT)+ } WHITESPACE = _{ (" " | "\t" | "\n") } COMMENT = _{ "#" ~ ANY* } -- cgit v1.2.3-54-g00ecf