mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-28 23:39:02 +00:00
LibWeb: Fix assertion failure when tokenizing JS regex literals
This fixes parsing the following regular expression: /</g; It also adds a simple script element to the HTMLTokenizer regression test, which also contains that specific regex.
This commit is contained in:
parent
c82c652ee4
commit
2404ad6897
Notes:
sideshowbarker
2024-07-18 09:00:07 +09:00
Author: https://github.com/MaxWipfli
Commit: 2404ad6897
Pull-request: https://github.com/SerenityOS/serenity/pull/8761
3 changed files with 10 additions and 1 deletions
|
@ -2561,6 +2561,8 @@ _StartOfFunction:
|
|||
{
|
||||
m_queued_tokens.enqueue(HTMLToken::make_character('<'));
|
||||
m_queued_tokens.enqueue(HTMLToken::make_character('/'));
|
||||
// NOTE: The spec doesn't mention this, but it seems that m_current_token (an end tag) is just dropped in this case.
|
||||
m_current_builder.clear();
|
||||
for (auto code_point : m_temporary_buffer)
|
||||
m_queued_tokens.enqueue(HTMLToken::make_character(code_point));
|
||||
RECONSUME_IN(ScriptData);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue