Merge remote-tracking branch 'origin/more-explicit-invalid-syntax' into more-explicit-invalid-syntax

This commit is contained in:
Barf-Vader 2025-02-07 16:27:51 +00:00
commit cf661e6ac7

View File

@ -121,12 +121,17 @@ object parser {
// Statements // Statements
private lazy val `<program>` = Program( private lazy val `<program>` = Program(
"begin" ~> many( "begin" ~> (
atomic(`<type>`.label("function declaration") <~> `<ident>` <~ "(") <**> `<partial-func-decl>` many(
).label("function declaration"), atomic(
(atomic(`<ident>` <~ "(").verifiedExplain("function is missing return type") | `<stmt>`.label( `<type>`.label("function declaration") <~> `<ident>` <~ "("
) <**> `<partial-func-decl>`
).label("function declaration") |
atomic(`<ident>` <~ "(").verifiedExplain("function declaration is missing return type")
),
`<stmt>`.label(
"main program body" "main program body"
)) <~ "end" ) <~ "end"
) )
private lazy val `<partial-func-decl>` = private lazy val `<partial-func-decl>` =
FuncDecl( FuncDecl(