Skip to content

Conversation

@RobinMalfait
Copy link
Member

@RobinMalfait RobinMalfait commented May 26, 2025

This PR fixes a Haml pre-processing issue where a crash occurs if there is no trailing \n at the end of the file and the code before it was considered Ruby code.

This happens in situations where Ruby code was used. E.g.:

- index = 0
- index += 1

In this situation when we see the - on the second line, then we will find the whole indented block and parse it as Ruby code instead. The block ands at the last \n, but since we reach the end of the file, there is no \n. Right now we incorrectly reset the internal cursor to the last known \n position. This means that the start of the Ruby block will be after the end of the Ruby block and the Haml parser will crash.

To solve this, once we reach the end of the file, we don't reset the cursor to the wrong position.

Fixes: #17379 (comment)

Test plan

  1. Added a regression test that did fail before the fix, and doesn't anymore

@RobinMalfait RobinMalfait requested a review from a team as a code owner May 26, 2025 16:31
@RobinMalfait RobinMalfait merged commit 1d4c263 into main May 26, 2025
7 checks passed
@RobinMalfait RobinMalfait deleted the fix/crash-haml-eof branch May 26, 2025 16:52
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

cli hangs on version 4.0.16

2 participants