properly render tab characters in babi
This commit is contained in:
@@ -63,6 +63,16 @@ class Screen:
|
||||
self._prev_screenshot = ret
|
||||
return ret
|
||||
|
||||
def addstr(self, y, x, s, attr):
|
||||
self.lines[y] = self.lines[y][:x] + s + self.lines[y][x + len(s):]
|
||||
|
||||
line_attr = self.attrs[y]
|
||||
new = [attr] * len(s)
|
||||
self.attrs[y] = line_attr[:x] + new + line_attr[x + len(s):]
|
||||
|
||||
self.y = y
|
||||
self.x = x + len(s)
|
||||
|
||||
def insstr(self, y, x, s, attr):
|
||||
line = self.lines[y]
|
||||
self.lines[y] = (line[:x] + s + line[x:])[:self.width]
|
||||
@@ -173,7 +183,8 @@ class CursesError(NamedTuple):
|
||||
|
||||
|
||||
class CursesScreen:
|
||||
def __init__(self, runner):
|
||||
def __init__(self, screen, runner):
|
||||
self._screen = screen
|
||||
self._runner = runner
|
||||
self._bkgd_attr = (-1, -1, 0)
|
||||
|
||||
@@ -197,20 +208,26 @@ class CursesScreen:
|
||||
pass
|
||||
|
||||
def nodelay(self, val):
|
||||
self._runner.screen.nodelay = val
|
||||
self._screen.nodelay = val
|
||||
|
||||
def addstr(self, y, x, s, attr=0):
|
||||
self._screen.addstr(y, x, s, self._to_attr(attr))
|
||||
|
||||
def insstr(self, y, x, s, attr=0):
|
||||
self._runner.screen.insstr(y, x, s, self._to_attr(attr))
|
||||
self._screen.insstr(y, x, s, self._to_attr(attr))
|
||||
|
||||
def clrtoeol(self):
|
||||
s = self._runner.screen.width * ' '
|
||||
self.insstr(self._runner.screen.y, self._runner.screen.x, s)
|
||||
s = self._screen.width * ' '
|
||||
self.insstr(self._screen.y, self._screen.x, s)
|
||||
|
||||
def chgat(self, y, x, n, attr):
|
||||
self._runner.screen.chgat(y, x, n, self._to_attr(attr))
|
||||
self._screen.chgat(y, x, n, self._to_attr(attr))
|
||||
|
||||
def move(self, y, x):
|
||||
self._runner.screen.move(y, x)
|
||||
self._screen.move(y, x)
|
||||
|
||||
def getyx(self):
|
||||
return self._screen.y, self._screen.x
|
||||
|
||||
def get_wch(self):
|
||||
return self._runner._get_wch()
|
||||
@@ -399,7 +416,10 @@ class DeferredRunner:
|
||||
|
||||
def _curses_initscr(self):
|
||||
self._curses_update_lines_cols()
|
||||
return CursesScreen(self)
|
||||
return CursesScreen(self.screen, self)
|
||||
|
||||
def _curses_newwin(self, height, width):
|
||||
return CursesScreen(Screen(width, height), self)
|
||||
|
||||
def _curses_not_implemented(self, fn):
|
||||
def fn_inner(*args, **kwargs):
|
||||
|
||||
@@ -411,3 +411,30 @@ def test_sequence_handling(run_only_fake):
|
||||
h.press(' test7')
|
||||
h.await_text('test1 test2 test3 test4 test5 test6 test7')
|
||||
h.await_text(r'\x1b[1;')
|
||||
|
||||
|
||||
def test_indentation_using_tabs(run, tmpdir):
|
||||
f = tmpdir.join('f')
|
||||
f.write(f'123456789\n\t12\t{"x" * 20}\n')
|
||||
|
||||
with run(str(f), width=20) as h, and_exit(h):
|
||||
h.await_text('123456789\n 12 xxxxxxxxxxx»\n')
|
||||
|
||||
h.press('Down')
|
||||
h.await_cursor_position(x=0, y=2)
|
||||
h.press('Up')
|
||||
h.await_cursor_position(x=0, y=1)
|
||||
|
||||
h.press('Right')
|
||||
h.await_cursor_position(x=1, y=1)
|
||||
h.press('Down')
|
||||
h.await_cursor_position(x=0, y=2)
|
||||
h.press('Up')
|
||||
h.await_cursor_position(x=1, y=1)
|
||||
|
||||
h.press('Down')
|
||||
h.await_cursor_position(x=0, y=2)
|
||||
h.press('Right')
|
||||
h.await_cursor_position(x=4, y=2)
|
||||
h.press('Up')
|
||||
h.await_cursor_position(x=4, y=1)
|
||||
|
||||
@@ -122,3 +122,34 @@ def test_syntax_highlighting_to_edge_of_screen(run, tmpdir):
|
||||
with run(str(f), term='screen-256color', width=20) as h, and_exit(h):
|
||||
h.await_text('# xxx')
|
||||
h.assert_screen_attr_equals(1, [(243, 40, 0)] * 20)
|
||||
|
||||
|
||||
def test_syntax_highlighting_with_tabs(run, tmpdir):
|
||||
f = tmpdir.join('f.demo')
|
||||
f.write('\t# 12345678901234567890\n')
|
||||
|
||||
with run(str(f), term='screen-256color', width=20) as h, and_exit(h):
|
||||
h.await_text('1234567890')
|
||||
expected = 4 * [(236, 40, 0)] + 15 * [(243, 40, 0)] + [(236, 40, 0)]
|
||||
h.assert_screen_attr_equals(1, expected)
|
||||
|
||||
|
||||
def test_syntax_highlighting_tabs_after_line_creation(run, tmpdir):
|
||||
f = tmpdir.join('f')
|
||||
# trailing whitespace is used to trigger highlighting
|
||||
f.write('foo\n\txx \ny \n')
|
||||
|
||||
with run(str(f), term='screen-256color') as h, and_exit(h):
|
||||
# this looks weird, but it populates the width cache
|
||||
h.press('Down')
|
||||
h.press('Down')
|
||||
h.press('Down')
|
||||
|
||||
# press enter after the tab
|
||||
h.press('Up')
|
||||
h.press('Up')
|
||||
h.press('Right')
|
||||
h.press('Right')
|
||||
h.press('Enter')
|
||||
|
||||
h.await_text('foo\n x\nx\ny\n')
|
||||
|
||||
Reference in New Issue
Block a user