Skip to content

Commit

Permalink
Make local scope for else blocks in try/catch/else (#51785)
Browse files Browse the repository at this point in the history
[Docs](https://docs.julialang.org/en/v1/manual/control-flow/#else-Clauses)
state:

> The try, catch, else, and finally clauses each introduce their own
> scope blocks.

But it is currently not the case for `else` blocks

```julia
julia> try
       catch
       else
           z = 1
       end
1

julia> z
1
```

This change actually makes `else` blocks have their own scope block:

```julia
julia> try
       catch
       else
           z = 1
       end
1

julia> z
ERROR: UndefVarError: `z` not defined
```

(cherry picked from commit 17a36ee)
  • Loading branch information
Pangoraw authored and KristofferC committed Oct 24, 2023
1 parent be97eb7 commit 7ae1535
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/julia-syntax.scm
Original file line number Diff line number Diff line change
Expand Up @@ -1420,7 +1420,7 @@
(scope-block ,finalb)))))
((length> e 3)
(and (length> e 6) (error "invalid \"try\" form"))
(let ((elseb (if (length= e 6) (cdddddr e) '())))
(let ((elseb (if (length= e 6) `((scope-block ,@(cdddddr e))) '())))
(expand-forms
`(,(if (null? elseb) 'trycatch 'trycatchelse)
(scope-block ,tryb)
Expand Down
16 changes: 16 additions & 0 deletions test/syntax.jl
Original file line number Diff line number Diff line change
Expand Up @@ -3187,6 +3187,22 @@ end
end
@test err == 5 + 6
@test x == 1

x = 0
try
catch
else
x = 1
end
@test x == 1

try
catch
else
tryelse_in_local_scope = true
end

@test !@isdefined(tryelse_in_local_scope)
end

@test_parseerror """
Expand Down

0 comments on commit 7ae1535

Please sign in to comment.