diff options
author | Kartik K. Agaram <vc@akkartik.com> | 2022-07-12 14:18:50 -0700 |
---|---|---|
committer | Kartik K. Agaram <vc@akkartik.com> | 2022-07-12 15:24:56 -0700 |
commit | 8bbc1ffe349a78ed2130e24e0356276ddbb22955 (patch) | |
tree | 8e3f748433d5147e258fd1008e75cf2c41700e28 /drawing_tests.lua | |
parent | a5f725ab3b860b22199036f7ab0d0a0193a5a6ac (diff) | |
download | text.love-8bbc1ffe349a78ed2130e24e0356276ddbb22955.tar.gz |
group all editor globals
We're still accessing them through a global. But we'll change that next.
Diffstat (limited to 'drawing_tests.lua')
-rw-r--r-- | drawing_tests.lua | 496 |
1 files changed, 248 insertions, 248 deletions
diff --git a/drawing_tests.lua b/drawing_tests.lua index c170caa..bc3b654 100644 --- a/drawing_tests.lua +++ b/drawing_tests.lua @@ -5,11 +5,11 @@ function test_creating_drawing_saves() io.write('\ntest_creating_drawing_saves') App.screen.init{width=120, height=60} - Filename = 'foo' - Lines = load_array{} + Editor_state.filename = 'foo' + Editor_state.lines = load_array{} edit.draw() -- click on button to create drawing - App.run_after_mouse_click(8,Margin_top+8, 1) + App.run_after_mouse_click(8,Editor_state.margin_top+8, 1) -- file not immediately saved App.update(0.01) check_nil(App.filesystem['foo'], 'F - test_creating_drawing_saves/early') @@ -23,20 +23,20 @@ end function test_draw_line() io.write('\ntest_draw_line') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - check_eq(#Lines, 2, 'F - test_draw_line/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_line/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_line/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_line/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_line/baseline/#shapes') + check_eq(#Editor_state.lines, 2, 'F - test_draw_line/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_line/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_line/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_line/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_line/baseline/#shapes') -- draw a line - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_line/#shapes') check_eq(#drawing.points, 2, 'F - test_draw_line/#points') check_eq(drawing.shapes[1].mode, 'line', 'F - test_draw_line/shape:1') @@ -51,8 +51,8 @@ function test_draw_line() App.update(0) -- The format on disk isn't perfectly stable. Table fields can be reordered. -- So just reload from disk to verify. - Lines = load_from_disk(Filename) - local drawing = Lines[1] + Editor_state.lines = load_from_disk(Editor_state.filename) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_line/save/#shapes') check_eq(#drawing.points, 2, 'F - test_draw_line/save/#points') check_eq(drawing.shapes[1].mode, 'line', 'F - test_draw_line/save/shape:1') @@ -67,19 +67,19 @@ end function test_draw_horizontal_line() io.write('\ntest_draw_horizontal_line') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'manhattan' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'manhattan' edit.draw() - check_eq(#Lines, 2, 'F - test_draw_horizontal_line/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_horizontal_line/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_horizontal_line/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_horizontal_line/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_horizontal_line/baseline/#shapes') + check_eq(#Editor_state.lines, 2, 'F - test_draw_horizontal_line/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_horizontal_line/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_horizontal_line/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_horizontal_line/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_horizontal_line/baseline/#shapes') -- draw a line that is more horizontal than vertical - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+26, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+26, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_horizontal_line/#shapes') check_eq(#drawing.points, 2, 'F - test_draw_horizontal_line/#points') check_eq(drawing.shapes[1].mode, 'manhattan', 'F - test_draw_horizontal_line/shape_mode') @@ -94,21 +94,21 @@ end function test_draw_circle() io.write('\ntest_draw_circle') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - check_eq(#Lines, 2, 'F - test_draw_circle/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_circle/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_circle/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_circle/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_circle/baseline/#shapes') + check_eq(#Editor_state.lines, 2, 'F - test_draw_circle/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_circle/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_circle/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_circle/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_circle/baseline/#shapes') -- draw a circle - App.mouse_move(Margin_left+4, Margin_top+Drawing_padding_top+4) -- hover on drawing + App.mouse_move(Editor_state.margin_left+4, Editor_state.margin_top+Editor_state.drawing_padding_top+4) -- hover on drawing App.run_after_keychord('C-o') - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.run_after_mouse_release(Margin_left+35+30, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.run_after_mouse_release(Editor_state.margin_left+35+30, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_circle/#shapes') check_eq(#drawing.points, 1, 'F - test_draw_circle/#points') check_eq(drawing.shapes[1].mode, 'circle', 'F - test_draw_horizontal_line/shape_mode') @@ -121,58 +121,58 @@ end function test_cancel_stroke() io.write('\ntest_cancel_stroke') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - check_eq(#Lines, 2, 'F - test_cancel_stroke/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_cancel_stroke/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_cancel_stroke/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_cancel_stroke/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_cancel_stroke/baseline/#shapes') + check_eq(#Editor_state.lines, 2, 'F - test_cancel_stroke/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_cancel_stroke/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_cancel_stroke/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_cancel_stroke/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_cancel_stroke/baseline/#shapes') -- start drawing a line - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) -- cancel App.run_after_keychord('escape') - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 0, 'F - test_cancel_stroke/#shapes') end function test_keys_do_not_affect_shape_when_mouse_up() io.write('\ntest_keys_do_not_affect_shape_when_mouse_up') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() -- hover over drawing and press 'o' without holding mouse - App.mouse_move(Margin_left+4, Margin_top+Drawing_padding_top+4) -- hover on drawing + App.mouse_move(Editor_state.margin_left+4, Editor_state.margin_top+Editor_state.drawing_padding_top+4) -- hover on drawing App.run_after_keychord('o') -- no change to drawing mode - check_eq(Current_drawing_mode, 'line', 'F - test_keys_do_not_affect_shape_when_mouse_up/drawing_mode') + check_eq(Editor_state.current_drawing_mode, 'line', 'F - test_keys_do_not_affect_shape_when_mouse_up/drawing_mode') -- no change to text either because we didn't run the textinput event end function test_draw_circle_mid_stroke() io.write('\ntest_draw_circle_mid_stroke') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - check_eq(#Lines, 2, 'F - test_draw_circle_mid_stroke/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_circle_mid_stroke/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_circle_mid_stroke/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_circle_mid_stroke/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_circle_mid_stroke/baseline/#shapes') + check_eq(#Editor_state.lines, 2, 'F - test_draw_circle_mid_stroke/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_circle_mid_stroke/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_circle_mid_stroke/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_circle_mid_stroke/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_circle_mid_stroke/baseline/#shapes') -- draw a circle - App.mouse_move(Margin_left+4, Margin_top+Drawing_padding_top+4) -- hover on drawing - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) + App.mouse_move(Editor_state.margin_left+4, Editor_state.margin_top+Editor_state.drawing_padding_top+4) -- hover on drawing + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) App.run_after_keychord('o') - App.run_after_mouse_release(Margin_left+35+30, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+35+30, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_circle_mid_stroke/#shapes') check_eq(#drawing.points, 1, 'F - test_draw_circle_mid_stroke/#points') check_eq(drawing.shapes[1].mode, 'circle', 'F - test_draw_horizontal_line/shape_mode') @@ -185,21 +185,21 @@ end function test_draw_arc() io.write('\ntest_draw_arc') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'circle' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'circle' edit.draw() - check_eq(#Lines, 2, 'F - test_draw_arc/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_arc/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_arc/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_arc/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_arc/baseline/#shapes') + check_eq(#Editor_state.lines, 2, 'F - test_draw_arc/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_arc/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_arc/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_arc/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_arc/baseline/#shapes') -- draw an arc - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.mouse_move(Margin_left+35+30, Margin_top+Drawing_padding_top+36) + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.mouse_move(Editor_state.margin_left+35+30, Editor_state.margin_top+Editor_state.drawing_padding_top+36) App.run_after_keychord('a') -- arc mode - App.run_after_mouse_release(Margin_left+35+50, Margin_top+Drawing_padding_top+36+50, 1) -- 45° - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+35+50, Editor_state.margin_top+Editor_state.drawing_padding_top+36+50, 1) -- 45° + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_arc/#shapes') check_eq(#drawing.points, 1, 'F - test_draw_arc/#points') check_eq(drawing.shapes[1].mode, 'arc', 'F - test_draw_horizontal_line/shape_mode') @@ -215,24 +215,24 @@ end function test_draw_polygon() io.write('\ntest_draw_polygon') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} edit.draw() - check_eq(Current_drawing_mode, 'line', 'F - test_draw_polygon/baseline/drawing_mode') - check_eq(#Lines, 2, 'F - test_draw_polygon/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_polygon/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_polygon/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_polygon/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_polygon/baseline/#shapes') + check_eq(Editor_state.current_drawing_mode, 'line', 'F - test_draw_polygon/baseline/drawing_mode') + check_eq(#Editor_state.lines, 2, 'F - test_draw_polygon/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_polygon/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_polygon/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_polygon/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_polygon/baseline/#shapes') -- first point - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) App.run_after_keychord('g') -- polygon mode -- second point - App.mouse_move(Margin_left+65, Margin_top+Drawing_padding_top+36) + App.mouse_move(Editor_state.margin_left+65, Editor_state.margin_top+Editor_state.drawing_padding_top+36) App.run_after_keychord('p') -- add point -- final point - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+26, 1) - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+26, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_polygon/#shapes') check_eq(#drawing.points, 3, 'F - test_draw_polygon/vertices') local shape = drawing.shapes[1] @@ -252,27 +252,27 @@ end function test_draw_rectangle() io.write('\ntest_draw_rectangle') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} edit.draw() - check_eq(Current_drawing_mode, 'line', 'F - test_draw_rectangle/baseline/drawing_mode') - check_eq(#Lines, 2, 'F - test_draw_rectangle/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_rectangle/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_rectangle/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_rectangle/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_rectangle/baseline/#shapes') + check_eq(Editor_state.current_drawing_mode, 'line', 'F - test_draw_rectangle/baseline/drawing_mode') + check_eq(#Editor_state.lines, 2, 'F - test_draw_rectangle/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_rectangle/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_rectangle/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_rectangle/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_rectangle/baseline/#shapes') -- first point - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) App.run_after_keychord('r') -- rectangle mode -- second point/first edge - App.mouse_move(Margin_left+42, Margin_top+Drawing_padding_top+45) + App.mouse_move(Editor_state.margin_left+42, Editor_state.margin_top+Editor_state.drawing_padding_top+45) App.run_after_keychord('p') -- override second point/first edge - App.mouse_move(Margin_left+75, Margin_top+Drawing_padding_top+76) + App.mouse_move(Editor_state.margin_left+75, Editor_state.margin_top+Editor_state.drawing_padding_top+76) App.run_after_keychord('p') -- release (decides 'thickness' of rectangle perpendicular to first edge) - App.run_after_mouse_release(Margin_left+15, Margin_top+Drawing_padding_top+26, 1) - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+15, Editor_state.margin_top+Editor_state.drawing_padding_top+26, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_rectangle/#shapes') check_eq(#drawing.points, 5, 'F - test_draw_rectangle/#points') -- currently includes every point added local shape = drawing.shapes[1] @@ -295,25 +295,25 @@ end function test_draw_rectangle_intermediate() io.write('\ntest_draw_rectangle_intermediate') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} edit.draw() - check_eq(Current_drawing_mode, 'line', 'F - test_draw_rectangle_intermediate/baseline/drawing_mode') - check_eq(#Lines, 2, 'F - test_draw_rectangle_intermediate/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_rectangle_intermediate/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_rectangle_intermediate/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_rectangle_intermediate/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_rectangle_intermediate/baseline/#shapes') + check_eq(Editor_state.current_drawing_mode, 'line', 'F - test_draw_rectangle_intermediate/baseline/drawing_mode') + check_eq(#Editor_state.lines, 2, 'F - test_draw_rectangle_intermediate/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_rectangle_intermediate/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_rectangle_intermediate/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_rectangle_intermediate/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_rectangle_intermediate/baseline/#shapes') -- first point - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) App.run_after_keychord('r') -- rectangle mode -- second point/first edge - App.mouse_move(Margin_left+42, Margin_top+Drawing_padding_top+45) + App.mouse_move(Editor_state.margin_left+42, Editor_state.margin_top+Editor_state.drawing_padding_top+45) App.run_after_keychord('p') -- override second point/first edge - App.mouse_move(Margin_left+75, Margin_top+Drawing_padding_top+76) + App.mouse_move(Editor_state.margin_left+75, Editor_state.margin_top+Editor_state.drawing_padding_top+76) App.run_after_keychord('p') - local drawing = Lines[1] + local drawing = Editor_state.lines[1] check_eq(#drawing.points, 3, 'F - test_draw_rectangle_intermediate/#points') -- currently includes every point added local pending = drawing.pending check_eq(pending.mode, 'rectangle', 'F - test_draw_rectangle_intermediate/shape_mode') @@ -330,27 +330,27 @@ end function test_draw_square() io.write('\ntest_draw_square') -- display a drawing followed by a line of text (you shouldn't ever have a drawing right at the end) - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} edit.draw() - check_eq(Current_drawing_mode, 'line', 'F - test_draw_square/baseline/drawing_mode') - check_eq(#Lines, 2, 'F - test_draw_square/baseline/#lines') - check_eq(Lines[1].mode, 'drawing', 'F - test_draw_square/baseline/mode') - check_eq(Lines[1].y, Margin_top+Drawing_padding_top, 'F - test_draw_square/baseline/y') - check_eq(Lines[1].h, 128, 'F - test_draw_square/baseline/y') - check_eq(#Lines[1].shapes, 0, 'F - test_draw_square/baseline/#shapes') + check_eq(Editor_state.current_drawing_mode, 'line', 'F - test_draw_square/baseline/drawing_mode') + check_eq(#Editor_state.lines, 2, 'F - test_draw_square/baseline/#lines') + check_eq(Editor_state.lines[1].mode, 'drawing', 'F - test_draw_square/baseline/mode') + check_eq(Editor_state.lines[1].y, Editor_state.margin_top+Editor_state.drawing_padding_top, 'F - test_draw_square/baseline/y') + check_eq(Editor_state.lines[1].h, 128, 'F - test_draw_square/baseline/y') + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_draw_square/baseline/#shapes') -- first point - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) App.run_after_keychord('s') -- square mode -- second point/first edge - App.mouse_move(Margin_left+42, Margin_top+Drawing_padding_top+45) + App.mouse_move(Editor_state.margin_left+42, Editor_state.margin_top+Editor_state.drawing_padding_top+45) App.run_after_keychord('p') -- override second point/first edge - App.mouse_move(Margin_left+65, Margin_top+Drawing_padding_top+66) + App.mouse_move(Editor_state.margin_left+65, Editor_state.margin_top+Editor_state.drawing_padding_top+66) App.run_after_keychord('p') -- release (decides which side of first edge to draw square on) - App.run_after_mouse_release(Margin_left+15, Margin_top+Drawing_padding_top+26, 1) - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+15, Editor_state.margin_top+Editor_state.drawing_padding_top+26, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_draw_square/#shapes') check_eq(#drawing.points, 5, 'F - test_draw_square/#points') -- currently includes every point added check_eq(drawing.shapes[1].mode, 'square', 'F - test_draw_square/shape_mode') @@ -372,15 +372,15 @@ end function test_name_point() io.write('\ntest_name_point') -- create a drawing with a line - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() -- draw a line - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_name_point/baseline/#shapes') check_eq(#drawing.points, 2, 'F - test_name_point/baseline/#points') check_eq(drawing.shapes[1].mode, 'line', 'F - test_name_point/baseline/shape:1') @@ -393,35 +393,35 @@ function test_name_point() check_nil(p2.name, 'F - test_name_point/baseline/p2:name') -- enter 'name' mode without moving the mouse App.run_after_keychord('C-n') - check_eq(Current_drawing_mode, 'name', 'F - test_name_point/mode:1') + check_eq(Editor_state.current_drawing_mode, 'name', 'F - test_name_point/mode:1') App.run_after_textinput('A') check_eq(p2.name, 'A', 'F - test_name_point') -- still in 'name' mode - check_eq(Current_drawing_mode, 'name', 'F - test_name_point/mode:2') + check_eq(Editor_state.current_drawing_mode, 'name', 'F - test_name_point/mode:2') -- exit 'name' mode App.run_after_keychord('return') - check_eq(Current_drawing_mode, 'line', 'F - test_name_point/mode:3') + check_eq(Editor_state.current_drawing_mode, 'line', 'F - test_name_point/mode:3') check_eq(p2.name, 'A', 'F - test_name_point') -- wait until save App.wait_fake_time(3.1) App.update(0) -- change is saved - Lines = load_from_disk(Filename) - local p2 = Lines[1].points[drawing.shapes[1].p2] + Editor_state.lines = load_from_disk(Editor_state.filename) + local p2 = Editor_state.lines[1].points[drawing.shapes[1].p2] check_eq(p2.name, 'A', 'F - test_name_point/save') end function test_move_point() io.write('\ntest_move_point') -- create a drawing with a line - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_move_point/baseline/#shapes') check_eq(#drawing.points, 2, 'F - test_move_point/baseline/#points') check_eq(drawing.shapes[1].mode, 'line', 'F - test_move_point/baseline/shape:1') @@ -435,34 +435,34 @@ function test_move_point() App.wait_fake_time(3.1) App.update(0) -- line is saved to disk - Lines = load_from_disk(Filename) - local drawing = Lines[1] - local p2 = Lines[1].points[drawing.shapes[1].p2] + Editor_state.lines = load_from_disk(Editor_state.filename) + local drawing = Editor_state.lines[1] + local p2 = Editor_state.lines[1].points[drawing.shapes[1].p2] check_eq(p2.x, 35, 'F - test_move_point/save/x') check_eq(p2.y, 36, 'F - test_move_point/save/y') edit.draw() -- enter 'move' mode without moving the mouse App.run_after_keychord('C-u') - check_eq(Current_drawing_mode, 'move', 'F - test_move_point/mode:1') + check_eq(Editor_state.current_drawing_mode, 'move', 'F - test_move_point/mode:1') -- point is lifted check_eq(drawing.pending.mode, 'move', 'F - test_move_point/mode:2') check_eq(drawing.pending.target_point, p2, 'F - test_move_point/target') -- move point - App.mouse_move(Margin_left+26, Margin_top+Drawing_padding_top+44) + App.mouse_move(Editor_state.margin_left+26, Editor_state.margin_top+Editor_state.drawing_padding_top+44) App.update(0.05) local p2 = drawing.points[drawing.shapes[1].p2] check_eq(p2.x, 26, 'F - test_move_point/x') check_eq(p2.y, 44, 'F - test_move_point/y') -- exit 'move' mode - App.run_after_mouse_click(Margin_left+26, Margin_top+Drawing_padding_top+44, 1) - check_eq(Current_drawing_mode, 'line', 'F - test_move_point/mode:3') + App.run_after_mouse_click(Editor_state.margin_left+26, Editor_state.margin_top+Editor_state.drawing_padding_top+44, 1) + check_eq(Editor_state.current_drawing_mode, 'line', 'F - test_move_point/mode:3') check_eq(drawing.pending, {}, 'F - test_move_point/pending') -- wait until save App.wait_fake_time(3.1) App.update(0) -- change is saved - Lines = load_from_disk(Filename) - local p2 = Lines[1].points[drawing.shapes[1].p2] + Editor_state.lines = load_from_disk(Editor_state.filename) + local p2 = Editor_state.lines[1].points[drawing.shapes[1].p2] check_eq(p2.x, 26, 'F - test_move_point/save/x') check_eq(p2.y, 44, 'F - test_move_point/save/y') end @@ -470,23 +470,23 @@ end function test_move_point_on_manhattan_line() io.write('\ntest_move_point_on_manhattan_line') -- create a drawing with a manhattan line - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'manhattan' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'manhattan' edit.draw() - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+46, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+46, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_move_point_on_manhattan_line/baseline/#shapes') check_eq(#drawing.points, 2, 'F - test_move_point_on_manhattan_line/baseline/#points') check_eq(drawing.shapes[1].mode, 'manhattan', 'F - test_move_point_on_manhattan_line/baseline/shape:1') edit.draw() -- enter 'move' mode App.run_after_keychord('C-u') - check_eq(Current_drawing_mode, 'move', 'F - test_move_point_on_manhattan_line/mode:1') + check_eq(Editor_state.current_drawing_mode, 'move', 'F - test_move_point_on_manhattan_line/mode:1') -- move point - App.mouse_move(Margin_left+26, Margin_top+Drawing_padding_top+44) + App.mouse_move(Editor_state.margin_left+26, Editor_state.margin_top+Editor_state.drawing_padding_top+44) App.update(0.05) -- line is no longer manhattan check_eq(drawing.shapes[1].mode, 'line', 'F - test_move_point_on_manhattan_line/baseline/shape:1') @@ -495,21 +495,21 @@ end function test_delete_lines_at_point() io.write('\ntest_delete_lines_at_point') -- create a drawing with two lines connected at a point - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.run_after_mouse_release(Margin_left+55, Margin_top+Drawing_padding_top+26, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.run_after_mouse_release(Editor_state.margin_left+55, Editor_state.margin_top+Editor_state.drawing_padding_top+26, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 2, 'F - test_delete_lines_at_point/baseline/#shapes') check_eq(drawing.shapes[1].mode, 'line', 'F - test_delete_lines_at_point/baseline/shape:1') check_eq(drawing.shapes[2].mode, 'line', 'F - test_delete_lines_at_point/baseline/shape:2') -- hover on the common point and delete - App.mouse_move(Margin_left+35, Margin_top+Drawing_padding_top+36) + App.mouse_move(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36) App.run_after_keychord('C-d') check_eq(drawing.shapes[1].mode, 'deleted', 'F - test_delete_lines_at_point/shape:1') check_eq(drawing.shapes[2].mode, 'deleted', 'F - test_delete_lines_at_point/shape:2') @@ -517,27 +517,27 @@ function test_delete_lines_at_point() App.wait_fake_time(3.1) App.update(0) -- deleted points disappear after file is reloaded - Lines = load_from_disk(Filename) - check_eq(#Lines[1].shapes, 0, 'F - test_delete_lines_at_point/save') + Editor_state.lines = load_from_disk(Editor_state.filename) + check_eq(#Editor_state.lines[1].shapes, 0, 'F - test_delete_lines_at_point/save') end function test_delete_line_under_mouse_pointer() io.write('\ntest_delete_line_under_mouse_pointer') -- create a drawing with two lines connected at a point - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.run_after_mouse_release(Margin_left+55, Margin_top+Drawing_padding_top+26, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.run_after_mouse_release(Editor_state.margin_left+55, Editor_state.margin_top+Editor_state.drawing_padding_top+26, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 2, 'F - test_delete_line_under_mouse_pointer/baseline/#shapes') check_eq(drawing.shapes[1].mode, 'line', 'F - test_delete_line_under_mouse_pointer/baseline/shape:1') check_eq(drawing.shapes[2].mode, 'line', 'F - test_delete_line_under_mouse_pointer/baseline/shape:2') -- hover on one of the lines and delete - App.mouse_move(Margin_left+25, Margin_top+Drawing_padding_top+26) + App.mouse_move(Editor_state.margin_left+25, Editor_state.margin_top+Editor_state.drawing_padding_top+26) App.run_after_keychord('C-d') -- only that line is deleted check_eq(drawing.shapes[1].mode, 'deleted', 'F - test_delete_line_under_mouse_pointer/shape:1') @@ -547,27 +547,27 @@ end function test_delete_point_from_polygon() io.write('\ntest_delete_point_from_polygon') -- create a drawing with two lines connected at a point - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() -- first point - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) App.run_after_keychord('g') -- polygon mode -- second point - App.mouse_move(Margin_left+65, Margin_top+Drawing_padding_top+36) + App.mouse_move(Editor_state.margin_left+65, Editor_state.margin_top+Editor_state.drawing_padding_top+36) App.run_after_keychord('p') -- add point -- third point - App.mouse_move(Margin_left+35, Margin_top+Drawing_padding_top+26) + App.mouse_move(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+26) App.run_after_keychord('p') -- add point -- fourth point - App.run_after_mouse_release(Margin_left+14, Margin_top+Drawing_padding_top+16, 1) - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+14, Editor_state.margin_top+Editor_state.drawing_padding_top+16, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_delete_point_from_polygon/baseline/#shapes') check_eq(drawing.shapes[1].mode, 'polygon', 'F - test_delete_point_from_polygon/baseline/mode') check_eq(#drawing.shapes[1].vertices, 4, 'F - test_delete_point_from_polygon/baseline/vertices') -- hover on a point and delete - App.mouse_move(Margin_left+35, Margin_top+Drawing_padding_top+26) + App.mouse_move(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+26) App.run_after_keychord('C-d') -- just the one point is deleted check_eq(drawing.shapes[1].mode, 'polygon', 'F - test_delete_point_from_polygon/shape') @@ -577,24 +577,24 @@ end function test_delete_point_from_polygon() io.write('\ntest_delete_point_from_polygon') -- create a drawing with two lines connected at a point - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() -- first point - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) App.run_after_keychord('g') -- polygon mode -- second point - App.mouse_move(Margin_left+65, Margin_top+Drawing_padding_top+36) + App.mouse_move(Editor_state.margin_left+65, Editor_state.margin_top+Editor_state.drawing_padding_top+36) App.run_after_keychord('p') -- add point -- third point - App.run_after_mouse_release(Margin_left+14, Margin_top+Drawing_padding_top+16, 1) - local drawing = Lines[1] + App.run_after_mouse_release(Editor_state.margin_left+14, Editor_state.margin_top+Editor_state.drawing_padding_top+16, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_delete_point_from_polygon/baseline/#shapes') check_eq(drawing.shapes[1].mode, 'polygon', 'F - test_delete_point_from_polygon/baseline/mode') check_eq(#drawing.shapes[1].vertices, 3, 'F - test_delete_point_from_polygon/baseline/vertices') -- hover on a point and delete - App.mouse_move(Margin_left+65, Margin_top+Drawing_padding_top+36) + App.mouse_move(Editor_state.margin_left+65, Editor_state.margin_top+Editor_state.drawing_padding_top+36) App.run_after_keychord('C-d') -- there's < 3 points left, so the whole polygon is deleted check_eq(drawing.shapes[1].mode, 'deleted', 'F - test_delete_point_from_polygon') @@ -603,15 +603,15 @@ end function test_undo_name_point() io.write('\ntest_undo_name_point') -- create a drawing with a line - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() -- draw a line - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_undo_name_point/baseline/#shapes') check_eq(#drawing.points, 2, 'F - test_undo_name_point/baseline/#points') check_eq(drawing.shapes[1].mode, 'line', 'F - test_undo_name_point/baseline/shape:1') @@ -622,40 +622,40 @@ function test_undo_name_point() check_eq(p2.x, 35, 'F - test_undo_name_point/baseline/p2:x') check_eq(p2.y, 36, 'F - test_undo_name_point/baseline/p2:y') check_nil(p2.name, 'F - test_undo_name_point/baseline/p2:name') - check_eq(#History, 1, 'F - test_undo_name_point/baseline/history:1') + check_eq(#Editor_state.history, 1, 'F - test_undo_name_point/baseline/history:1') -- enter 'name' mode without moving the mouse App.run_after_keychord('C-n') App.run_after_textinput('A') App.run_after_keychord('return') check_eq(p2.name, 'A', 'F - test_undo_name_point/baseline') - check_eq(#History, 3, 'F - test_undo_name_point/baseline/history:2') - check_eq(Next_history, 4, 'F - test_undo_name_point/baseline/next_history') + check_eq(#Editor_state.history, 3, 'F - test_undo_name_point/baseline/history:2') + check_eq(Editor_state.next_history, 4, 'F - test_undo_name_point/baseline/next_history') -- undo App.run_after_keychord('C-z') - local drawing = Lines[1] + local drawing = Editor_state.lines[1] local p2 = drawing.points[drawing.shapes[1].p2] - check_eq(Next_history, 3, 'F - test_undo_name_point/next_history') + check_eq(Editor_state.next_history, 3, 'F - test_undo_name_point/next_history') check_eq(p2.name, '', 'F - test_undo_name_point') -- not quite what it was before, but close enough -- wait until save App.wait_fake_time(3.1) App.update(0) -- undo is saved - Lines = load_from_disk(Filename) - local p2 = Lines[1].points[drawing.shapes[1].p2] + Editor_state.lines = load_from_disk(Editor_state.filename) + local p2 = Editor_state.lines[1].points[drawing.shapes[1].p2] check_eq(p2.name, '', 'F - test_undo_name_point/save') end function test_undo_move_point() io.write('\ntest_undo_move_point') -- create a drawing with a line - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 1, 'F - test_undo_move_point/baseline/#shapes') check_eq(#drawing.points, 2, 'F - test_undo_move_point/baseline/#points') check_eq(drawing.shapes[1].mode, 'line', 'F - test_undo_move_point/baseline/shape:1') @@ -668,28 +668,28 @@ function test_undo_move_point() check_nil(p2.name, 'F - test_undo_move_point/baseline/p2:name') -- move p2 App.run_after_keychord('C-u') - App.mouse_move(Margin_left+26, Margin_top+Drawing_padding_top+44) + App.mouse_move(Editor_state.margin_left+26, Editor_state.margin_top+Editor_state.drawing_padding_top+44) App.update(0.05) local p2 = drawing.points[drawing.shapes[1].p2] check_eq(p2.x, 26, 'F - test_undo_move_point/x') check_eq(p2.y, 44, 'F - test_undo_move_point/y') -- exit 'move' mode - App.run_after_mouse_click(Margin_left+26, Margin_top+Drawing_padding_top+44, 1) - check_eq(Next_history, 4, 'F - test_undo_move_point/next_history') + App.run_after_mouse_click(Editor_state.margin_left+26, Editor_state.margin_top+Editor_state.drawing_padding_top+44, 1) + check_eq(Editor_state.next_history, 4, 'F - test_undo_move_point/next_history') -- undo App.run_after_keychord('C-z') App.run_after_keychord('C-z') -- bug: need to undo twice - local drawing = Lines[1] + local drawing = Editor_state.lines[1] local p2 = drawing.points[drawing.shapes[1].p2] - check_eq(Next_history, 2, 'F - test_undo_move_point/next_history') + check_eq(Editor_state.next_history, 2, 'F - test_undo_move_point/next_history') check_eq(p2.x, 35, 'F - test_undo_move_point/x') check_eq(p2.y, 36, 'F - test_undo_move_point/y') -- wait until save App.wait_fake_time(3.1) App.update(0) -- undo is saved - Lines = load_from_disk(Filename) - local p2 = Lines[1].points[drawing.shapes[1].p2] + Editor_state.lines = load_from_disk(Editor_state.filename) + local p2 = Editor_state.lines[1].points[drawing.shapes[1].p2] check_eq(p2.x, 35, 'F - test_undo_move_point/save/x') check_eq(p2.y, 36, 'F - test_undo_move_point/save/y') end @@ -697,35 +697,35 @@ end function test_undo_delete_point() io.write('\ntest_undo_delete_point') -- create a drawing with two lines connected at a point - Filename = 'foo' - App.screen.init{width=Margin_width+256, height=300} -- drawing coordinates 1:1 with pixels - Lines = load_array{'```lines', '```', ''} - Current_drawing_mode = 'line' + Editor_state.filename = 'foo' + App.screen.init{width=Editor_state.margin_width+256, height=300} -- drawing coordinates 1:1 with pixels + Editor_state.lines = load_array{'```lines', '```', ''} + Editor_state.current_drawing_mode = 'line' edit.draw() - App.run_after_mouse_press(Margin_left+5, Margin_top+Drawing_padding_top+6, 1) - App.run_after_mouse_release(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.run_after_mouse_press(Margin_left+35, Margin_top+Drawing_padding_top+36, 1) - App.run_after_mouse_release(Margin_left+55, Margin_top+Drawing_padding_top+26, 1) - local drawing = Lines[1] + App.run_after_mouse_press(Editor_state.margin_left+5, Editor_state.margin_top+Editor_state.drawing_padding_top+6, 1) + App.run_after_mouse_release(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.run_after_mouse_press(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36, 1) + App.run_after_mouse_release(Editor_state.margin_left+55, Editor_state.margin_top+Editor_state.drawing_padding_top+26, 1) + local drawing = Editor_state.lines[1] check_eq(#drawing.shapes, 2, 'F - test_undo_delete_point/baseline/#shapes') check_eq(drawing.shapes[1].mode, 'line', 'F - test_undo_delete_point/baseline/shape:1') check_eq(drawing.shapes[2].mode, 'line', 'F - test_undo_delete_point/baseline/shape:2') -- hover on the common point and delete - App.mouse_move(Margin_left+35, Margin_top+Drawing_padding_top+36) + App.mouse_move(Editor_state.margin_left+35, Editor_state.margin_top+Editor_state.drawing_padding_top+36) App.run_after_keychord('C-d') check_eq(drawing.shapes[1].mode, 'deleted', 'F - test_undo_delete_point/shape:1') check_eq(drawing.shapes[2].mode, 'deleted', 'F - test_undo_delete_point/shape:2') -- undo App.run_after_keychord('C-z') - local drawing = Lines[1] + local drawing = Editor_state.lines[1] local p2 = drawing.points[drawing.shapes[1].p2] - check_eq(Next_history, 3, 'F - test_undo_move_point/next_history') + check_eq(Editor_state.next_history, 3, 'F - test_undo_move_point/next_history') check_eq(drawing.shapes[1].mode, 'line', 'F - test_undo_delete_point/shape:1') check_eq(drawing.shapes[2].mode, 'line', 'F - test_undo_delete_point/shape:2') -- wait until save App.wait_fake_time(3.1) App.update(0) -- undo is saved - Lines = load_from_disk(Filename) - check_eq(#Lines[1].shapes, 2, 'F - test_undo_delete_point/save') + Editor_state.lines = load_from_disk(Editor_state.filename) + check_eq(#Editor_state.lines[1].shapes, 2, 'F - test_undo_delete_point/save') end |