Skip to content

Commit

Permalink
Terminate :statement parsing at newlines
Browse files Browse the repository at this point in the history
Addresses a portion of #316
  • Loading branch information
timholy committed Aug 11, 2024
1 parent 0a0aa04 commit dfbff26
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 2 deletions.
5 changes: 4 additions & 1 deletion src/hooks.jl
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,10 @@ function core_parser_hook(code, filename::String, lineno::Int, offset::Int, opti
end
parse!(stream; rule=options)
if options === :statement
bump_trivia(stream)
bump_trivia(stream; skip_newlines=false)
if peek(stream) == K"NewlineWs"
bump(stream)
end
end

if any_error(stream)
Expand Down
12 changes: 11 additions & 1 deletion test/hooks.jl
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ function _unwrap_parse_error(core_hook_result)
end

@testset "Hooks for Core integration" begin
@testset "whitespace parsing" begin
@testset "whitespace and comment parsing" begin
@test JuliaSyntax.core_parser_hook("", "somefile", 1, 0, :statement) == Core.svec(nothing, 0)
@test JuliaSyntax.core_parser_hook("", "somefile", 1, 0, :statement) == Core.svec(nothing, 0)

Expand All @@ -20,6 +20,16 @@ end

@test JuliaSyntax.core_parser_hook(" x \n", "somefile", 1, 0, :statement) == Core.svec(:x,4)
@test JuliaSyntax.core_parser_hook(" x \n", "somefile", 1, 0, :atom) == Core.svec(:x,2)

# https://github.com/JuliaLang/JuliaSyntax.jl/issues/316#issuecomment-1870294857
stmtstr =
"""
plus(a, b) = a + b
# Issue #81
f() = nothing
"""
@test JuliaSyntax.core_parser_hook(stmtstr, "somefile", 1, 0, :statement)[2] 19:21
end

@testset "filename and lineno" begin
Expand Down

0 comments on commit dfbff26

Please sign in to comment.