Fix for parsing an indented top_block that starts with a comment and has

code after it.
This commit is contained in:
Bruce Hill 2019-01-18 15:18:49 -08:00
parent d92685ab95
commit 32b258868c
5 changed files with 10 additions and 8 deletions

View File

@ -15,7 +15,7 @@ file_chunks (FileChunks) <-
ws* unexpected_chunk?
top_block (Block) <-
comment? blank_lines? statement (nl_nodent statement)*
(comment nl_nodent)? statement (nl_nodent statement)*
empty_block (Block) <-
comment? blank_lines?

View File

@ -15,7 +15,7 @@ file_chunks (FileChunks) <-
ws* unexpected_chunk?
top_block (Block) <-
comment? blank_lines? statement (nl_nodent statement)*
(comment nl_nodent)? statement (nl_nodent statement)*
empty_block (Block) <-
comment? blank_lines?

View File

@ -17,7 +17,7 @@ file_chunks (FileChunks) <-
ws* unexpected_chunk?
top_block (Block) <-
comment? blank_lines? statement (nl_nodent statement)*
(comment nl_nodent)? statement (nl_nodent statement)*
empty_block (Block) <-
comment? blank_lines?

View File

@ -17,7 +17,7 @@ file_chunks (FileChunks) <-
ws* unexpected_chunk?
top_block (Block) <-
comment? blank_lines? statement (nl_nodent statement)*
(comment nl_nodent)? statement (nl_nodent statement)*
empty_block (Block) <-
comment? blank_lines?

View File

@ -2,9 +2,8 @@
file <-
{:curr_indent: ' '* :}
(((methodchain / action / expression / inline_block) eol !.)
/ file_chunks / comment? blank_lines?)
/ file_chunks / comment? (blank_lines ws*)?)
{:curr_indent: %nil :}
(unexpected_code .+)?
!.
shebang <- "#!" (!"nomsu" [^%nl])* "nomsu" ws+ "-V" ws* [0-9.]+ [^%nl]* (%nl / !.)
@ -20,7 +19,7 @@ section_division <- ("~")^+3 eol
eof <- !.
eol <- ws* (&%nl / !.)
nodent <- (unexpected_indent [^%nl]* / =curr_indent)
indent <- {~ =curr_indent " " ~}
indent <- {=curr_indent " "}
blank_lines <- %nl ((nodent comment / ws*) %nl)*
nl_nodent <- blank_lines nodent
nl_indent <- blank_lines tab_error? {:curr_indent: indent :} (comment nl_nodent)*
@ -31,7 +30,7 @@ comment (Comment) <-
top_block (Block) <-
comment? blank_lines? statement (nl_nodent statement)*
(comment nl_nodent)? statement (nl_nodent statement)*
inline_block (Block) <-
":" ws* (inline_statement (ws* ";" ws* inline_statement)*)?
@ -244,6 +243,9 @@ _unexpected_code (Error) <-
{:error: {~ [^%nl]+ -> "Couldn't parse this code" ~} :}
unexpected_chunk (Error) <-
{:error: {~ .+ -> "Couldn't parse this code" ~} :}
unexpected_space (Error) <-
{:error: {~ ws+ -> "Messed up indentation" ~} :}
{:hint: {~ '' -> 'Either make sure this line is aligned with the one above it, or make sure the previous line ends with something that uses indentation, like ":" or "(..)"' ~} :}
unexpected_indent (Error) <-
{:error: {~ (=curr_indent ws+) -> "Messed up indentation" ~} :}
{:hint: {~ '' -> 'Either make sure this line is aligned with the one above it, or make sure the previous line ends with something that uses indentation, like ":" or "(..)"' ~} :}