Commit Graph

148 Commits

Author SHA1 Message Date
Kartik K. Agaram 8fc1365abd Merge template-carousel-mobile 2024-09-05 14:01:58 -07:00
Kartik K. Agaram acf3bc3dae Merge carousel.love 2024-09-05 13:59:18 -07:00
Kartik K. Agaram 1343f73053 Merge template-live-editor-mobile 2024-09-05 13:57:41 -07:00
Kartik K. Agaram 81341a458c Merge text0 2024-09-05 13:53:57 -07:00
Kartik K. Agaram 4dffba4700 Merge text.love 2024-09-05 13:53:18 -07:00
Kartik K. Agaram 78e84fbf03 Merge lines.love 2024-09-05 13:47:15 -07:00
Kartik K. Agaram 9448f9b04e fine, I'll add a badge 2024-09-05 13:23:23 -07:00
Kartik K. Agaram 32313ddb17 Merge template-carousel-mobile 2024-09-01 01:36:37 -07:00
Kartik K. Agaram ee4b405203 Merge carousel.love 2024-09-01 01:35:32 -07:00
Kartik K. Agaram 95b75e159b Merge template-live-editor-mobile 2024-09-01 01:34:43 -07:00
Kartik K. Agaram d17491205d Merge text0 2024-09-01 01:31:05 -07:00
Kartik K. Agaram 3f19464715 Merge text.love 2024-09-01 01:29:39 -07:00
Kartik K. Agaram af0d177d57 Merge lines.love 2024-09-01 01:17:22 -07:00
Kartik K. Agaram 52f876302f clean up some issues I now feel confident about 2024-08-31 19:16:20 -07:00
Kartik K. Agaram af72cb4452 Merge template-carousel-mobile 2024-07-22 21:55:18 -07:00
Kartik K. Agaram 6524eb056e Merge carousel.love 2024-07-22 21:53:05 -07:00
Kartik K. Agaram a6bceb9756 Merge template-live-editor-mobile 2024-07-22 21:52:13 -07:00
Kartik K. Agaram 54fdecbbf8 Merge text0 2024-07-22 21:49:23 -07:00
Kartik K. Agaram f73d8ad206 Merge text.love 2024-07-22 21:48:49 -07:00
Kartik K. Agaram b2279f8368 Merge lines.love 2024-07-22 21:44:02 -07:00
Kartik K. Agaram 21e2d8cf3b clarify that PRs and patches are both welcome 2024-07-22 21:29:34 -07:00
Kartik K. Agaram f4137cc55f add a fork 2024-07-22 21:28:41 -07:00
Kartik K. Agaram 57deb762f0 register a new add-on tool
Thanks eril!
2024-07-12 21:01:13 -07:00
Kartik K. Agaram 9501f01ca0 fix a crash involving mouse and drawings
Thanks Alex Schroeder for reporting this crash. The scenario:
  * Edit a file like say this repo's Readme.
  * The second line is empty and there's a '+' to insert a drawing.
    Click on that.
  * Resize the window so just the first line of text and the drawing are
    visible.
  * Close the window.
  * Reopen lines.love, it will reopen the same file.
  * Click on the left margin to the left of the drawing.

Before this commit these steps yielded the following crash:

  Error: bad argument #1 to 'len' (string expected, got nil)
  text.lua:626: in function 'pos_at_end_of_screen_line'
  edit.lua:298: in function 'mouse_press'

There were two distinct problems here:

1. State.screen_bottom1 is not required to point to a text line, it
   could just as well be a drawing. I have been sloppy in handling that.
2. The bug was partially masked (the need to close and reopen the
   window) by a second bug: inserting a drawing was not invalidating the
   cache I save of starty coordinates for each line. (I've inserted and
   deleted starty invalidations a few times in the past, but it looks
   like I'd never had one in this particular location edit.draw before.)

How did these issues get missed for years?
  - Even though I use lines.love on a daily basis, it turns out I don't
    actually create line drawings all that often.
  - When I do, I'm still living in files that are mostly text with only
    an occasional drawing.
  - I keep my windows fairly large.

Between these 3 patterns, the odds of running into a drawing as the
first or bottom-most line on the screen were fairly small. And then I
had to interact with it. I suspect I tend to interact with drawings
after centering them vertically.

---

Bug #1 in particular has some interesting past history.

* Near the start of the project, when I implemented line-wrapping I
  started saving screen_bottom, the bottom-most line displayed on
  screen. I did this so I could scroll down easily just by assigning
  `screen_top = screen_bottom`. (On the other hand, scrolling up still
  required some work. I should perhaps get rid of it and just compute
  scrolls from scratch each time.)

* Also near the start of the project, I supported selecting text by a
  complex state machine spanning keypress, mouse press and mouse
  release:
    mouse click (press and immediate release) moves cursor
    mouse drag (press and much later release) creates selection
    shift-click selects from current cursor to click location
    shift-movement creates/grows a selection

* On 2023-06-01, inscript reported a bug. Opening a window with just a
  little bit of text (lots of unused space in the window), selecting all
  the text and then clicking below all the text would crash the editor.

  To fix this I added code at the bottom of edit.mouse_press which
  computed the final visible line+pos location and used that in the
  cursor-move/text-selection state machine. It did this computation
  based on.. screen_bottom. But I didn't notice that screen_bottom could
  be a drawing (which has no pos). This commit's bug/regression was
  created.

* On 2023-09-20, Matt Wynne encountered a crash which got me to realize
  I need code at the bottom of edit.mouse_release symmetric to the code
  at the bottom of edit.mouse_press. I still didn't notice that
  screen_bottom could be a drawing.

So in fixing inscript's bug report, I introduced (at least) 2
regressions, because I either had no idea or quickly forgot that
screen_bottom could point at a drawing.

While I created regressions, the underlying mental bug feels new. I just
never focused on the fact that screen_bottom could point at a drawing.

This past history makes me suspicious of my mouse_press/mouse_release
code. I think I'm going to get rid of screen_bottom entirely as a
concept. I'll still have to be careful though about the remaining
locations and which of them are allowed to point at drawings:

  - cursor and selection are not allowed to point at drawings
  - screen_top and screen_bottom are allowed to point at drawings

I sometimes copy between these 4 location variables. Auditing shows no
gaps where cursor could ever end up pointing at a drawing. It's just
when I started using screen_bottom for a whole new purpose (in
the mouse_press/release state machine) that I went wrong.

I should also try getting rid of starty entirely. Is it _really_ needed
for a responsive editor? I think I introduced it back when I didn't know
what I was doing with LÖVE and was profligately creating text objects
willy-nilly just to compute widths.

Getting rid of these two fairly global bits of mutable state will
hopefully make lines much more robust when the next person tries it out
in 6 months :-/ X-(

Thanks everyone for the conversation around this bug:
  https://merveilles.town/@akkartik/112567862542495637

---

Bug #2 has some complexity as well, and might lead to some follow-on
cleanup.

When I click on the button to insert a new drawing, the mouse_release
hook triggers and moves the cursor below the new drawing. This is
desirable, but I'd never noticed this happy accident. It stops working
when I invalidate starty for all lines (which gets recomputed and cached
for all visible lines on every frame).

Fixing this caused a couple of unit tests start crashing for 2 reasons
that required their own minor fixes:

  - My emulated mouse press and release didn't have an intervening
    frame and so mouse_release no longer receives starty. Now I've added
    a call to edit.draw() between press and release.

    This might actually bite someone for real someday, if they're
    running on a slow computer or something like that. I've tried to
    click really fast but I can't seem to put mouse_press and release in
    the same frame (assuming 30 frames per second)

  - My tests' window dimensions often violate my constraint that the
    screen always have one line of text for showing the cursor. They're
    unrealistically small or have a really wide aspect ratio (width 2x
    of height). I suspect lines.love will itself crash in those
    situations, but hopefully they're unrealistic. Hmm, I wonder what
    would happen if someone maximized in a 16:9 screen, that's almost
    2x.. Anyways, I've cleaned a couple of tests up, but might need to
    fix up others at some point. I'd have to rejigger all my brittle
    line-wrapping tests if I modify the screen width :-/ X-(
2024-06-09 13:17:55 -07:00
Kartik K. Agaram 7b87a036ad Merge template-carousel-mobile 2024-03-23 09:12:46 -07:00
Kartik K. Agaram 665e80f780 update list of forks 2024-03-23 09:11:11 -07:00
Kartik K. Agaram c413f281cf add to list of forks 2024-03-16 09:30:18 -07:00
Kartik K. Agaram 180e582e58 standardize some copy between forks 2024-03-15 23:44:37 -07:00
Kartik K. Agaram 9e4119acd8 Merge template-carousel-mobile 2024-03-15 23:38:52 -07:00
Kartik K. Agaram 9dfd8fbf3e document gotchas on mobile 2024-03-15 23:03:50 -07:00
Kartik K. Agaram cd278f9a85 new fork: a template for carousel-based apps 2024-03-15 22:52:27 -07:00
Kartik K. Agaram fd2e66c8f0 ugh, I hate making typos in the credits 2024-03-11 23:58:00 -07:00
Kartik K. Agaram 03d0f947c7 correct acknowledgements 2024-03-10 23:39:16 -07:00
Kartik K. Agaram 094b518b08 initial Readme for sokoban.love 2024-03-10 23:19:52 -07:00
Kartik K. Agaram b710439890 Merge template-live-editor-mobile 2024-03-10 22:32:25 -07:00
Kartik K. Agaram 8d3bfa6ba0 stop recommending the terminal
Freewheeling apps have been stable for many months now.
2024-03-10 22:25:28 -07:00
Kartik K. Agaram 960380b880 Merge template-live-editor-mobile 2024-03-10 21:46:51 -07:00
Kartik K. Agaram 01efe059a3 Merge text0 2024-03-10 21:41:24 -07:00
Kartik K. Agaram b281b3ddf4 Merge text.love 2024-03-10 21:40:10 -07:00
Kartik K. Agaram 732ae69382 Merge lines.love 2024-03-10 21:36:01 -07:00
Kartik K. Agaram 093da1e7f8 add a mirror and reorg mirrors 2024-03-10 20:15:46 -07:00
Kartik K. Agaram cda2d45b27 Merge template-live-editor-mobile 2024-01-31 15:27:03 -08:00
Kartik K. Agaram 0477988406 new mirror 2024-01-30 23:43:15 -08:00
Kartik K. Agaram 4d585d6138 Merge template-live-editor-mobile 2023-12-13 18:25:27 -08:00
Kartik K. Agaram d60139bdb5 clarify driver description 2023-12-13 18:19:34 -08:00
Kartik K. Agaram 750ef9d54d remove warning about persistence from Readme 2023-11-26 13:39:26 -08:00
Kartik K. Agaram dc18fb4a87 screenshot 2023-11-23 10:43:13 -08:00
Kartik K. Agaram bbbe3e3e8a credits 2023-11-23 10:40:04 -08:00
Kartik K. Agaram a7ad5e7090 update known issues 2023-11-22 22:54:08 -08:00
Kartik K. Agaram c99bf84363 update Readme and settle on a project name 2023-11-22 22:49:33 -08:00