mirror of
https://github.com/isledecomp/isle.git
synced 2025-10-24 17:04:17 +00:00
74 lines
2.1 KiB
Python
74 lines
2.1 KiB
Python
# nyuk nyuk nyuk
|
|
import pytest
|
|
from isledecomp.parser.parser import CurlyManager
|
|
from isledecomp.parser.util import sanitize_code_line
|
|
|
|
|
|
@pytest.fixture(name="curly")
|
|
def fixture_curly():
|
|
return CurlyManager()
|
|
|
|
|
|
def test_simple(curly):
|
|
curly.read_line("namespace Test {")
|
|
assert curly.get_prefix() == "Test"
|
|
curly.read_line("}")
|
|
assert curly.get_prefix() == ""
|
|
|
|
|
|
def test_oneliner(curly):
|
|
"""Should not go down into a scope for a class forward reference"""
|
|
curly.read_line("class LegoEntity;")
|
|
assert curly.get_prefix() == ""
|
|
# Now make sure that we still would not consider that class name
|
|
# even after reading the opening curly brace
|
|
curly.read_line("if (true) {")
|
|
assert curly.get_prefix() == ""
|
|
|
|
|
|
def test_ignore_comments(curly):
|
|
curly.read_line("namespace Test {")
|
|
curly.read_line("// }")
|
|
assert curly.get_prefix() == "Test"
|
|
|
|
|
|
@pytest.mark.xfail(reason="todo: need a real lexer")
|
|
def test_ignore_multiline_comments(curly):
|
|
curly.read_line("namespace Test {")
|
|
curly.read_line("/*")
|
|
curly.read_line("}")
|
|
curly.read_line("*/")
|
|
assert curly.get_prefix() == "Test"
|
|
curly.read_line("}")
|
|
assert curly.get_prefix() == ""
|
|
|
|
|
|
def test_nested(curly):
|
|
curly.read_line("namespace Test {")
|
|
curly.read_line("namespace Foo {")
|
|
assert curly.get_prefix() == "Test::Foo"
|
|
curly.read_line("}")
|
|
assert curly.get_prefix() == "Test"
|
|
|
|
|
|
sanitize_cases = [
|
|
("", ""),
|
|
(" ", ""),
|
|
("{", "{"),
|
|
("// comments {", ""),
|
|
("{ // why comment here", "{"),
|
|
("/* comments */ {", "{"),
|
|
('"curly in a string {"', '""'),
|
|
('if (!strcmp("hello { there }", g_test)) {', 'if (!strcmp("", g_test)) {'),
|
|
("'{'", "''"),
|
|
("weird_function('\"', hello, '\"')", "weird_function('', hello, '')"),
|
|
]
|
|
|
|
|
|
@pytest.mark.parametrize("start, end", sanitize_cases)
|
|
def test_sanitize(start: str, end: str):
|
|
"""Make sure that we can remove curly braces in places where they should
|
|
not be considered as part of the semantic structure of the file.
|
|
i.e. inside strings or chars, and inside comments"""
|
|
assert sanitize_code_line(start) == end
|