2023-07-13 10:49:07 +02:00
|
|
|
/*
|
2024-10-04 13:19:50 +02:00
|
|
|
* Copyright (c) 2023, Andreas Kling <andreas@ladybird.org>
|
2023-07-13 10:49:07 +02:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <LibJS/Bytecode/RegexTable.h>
|
|
|
|
|
|
|
|
|
|
namespace JS::Bytecode {
|
|
|
|
|
|
2025-12-12 06:17:37 -06:00
|
|
|
RegexTableIndex RegexTable::insert(ParsedRegex parsed_regex)
|
2023-07-13 10:49:07 +02:00
|
|
|
{
|
2025-12-12 06:17:37 -06:00
|
|
|
Regex<ECMA262> regex(parsed_regex.regex, parsed_regex.pattern.to_byte_string(), parsed_regex.flags);
|
2023-07-13 10:49:07 +02:00
|
|
|
m_regexes.append(move(regex));
|
|
|
|
|
return m_regexes.size() - 1;
|
|
|
|
|
}
|
|
|
|
|
|
2025-12-12 06:17:37 -06:00
|
|
|
Regex<ECMA262> const& RegexTable::get(RegexTableIndex index) const
|
2023-07-13 10:49:07 +02:00
|
|
|
{
|
|
|
|
|
return m_regexes[index.value()];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void RegexTable::dump() const
|
|
|
|
|
{
|
|
|
|
|
outln("Regex Table:");
|
|
|
|
|
for (size_t i = 0; i < m_regexes.size(); i++)
|
2025-12-12 06:17:37 -06:00
|
|
|
outln("{}: {}", i, m_regexes[i].pattern_value);
|
2023-07-13 10:49:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|