about summary refs log tree commit diff stats
path: root/drawing_tests.lua
diff options
context:
space:
mode:
authorKartik K. Agaram <vc@akkartik.com>2022-07-12 14:18:50 -0700
committerKartik K. Agaram <vc@akkartik.com>2022-07-12 15:24:56 -0700
commit8bbc1ffe349a78ed2130e24e0356276ddbb22955 (patch)
tree8e3f748433d5147e258fd1008e75cf2c41700e28 /drawing_tests.lua
parenta5f725ab3b860b22199036f7ab0d0a0193a5a6ac (diff)
downloadtext.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.lua496
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