Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | editing source code from within the app | Kartik K. Agaram | 2022-09-03 | 21 | -194/+5157 |
| | | | | integrated from pong.love: https://merveilles.town/@akkartik/108933336531898243 | ||||
* | Merge lines.love | Kartik K. Agaram | 2022-08-24 | 1 | -4/+6 |
|\ | |||||
| * | bugfix: propagate mouse press if any button would | Kartik K. Agaram | 2022-08-24 | 1 | -4/+6 |
| | | | | | | | | | | Before this commit I was propagating press events only if _all_ buttons would. | ||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-24 | 2 | -0/+12 |
|\| | |||||
| * | infrastructure for caching LÖVE text objects | Kartik K. Agaram | 2022-08-24 | 3 | -6/+13 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-23 | 2 | -1/+23 |
|\| | |||||
| * | set color for each fragment | Kartik K. Agaram | 2022-08-23 | 1 | -1/+1 |
| | | | | | | | | | | In general it seems like good practice to minimize assumptions about the current color. | ||||
| * | helper: trimming whitespace from strings | Kartik K. Agaram | 2022-08-23 | 1 | -0/+12 |
| | | |||||
| * | helper: file_exists | Kartik K. Agaram | 2022-08-23 | 1 | -0/+10 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-23 | 4 | -46/+68 |
|\| | |||||
| * | make App.open_for_* look more like io.open | Kartik K. Agaram | 2022-08-23 | 1 | -7/+9 |
| | | | | | | | | Now missing files will result in similar behavior: nil file handles. | ||||
| * | pass all button params to the icon | Kartik K. Agaram | 2022-08-23 | 2 | -2/+3 |
| | | |||||
| * | allow buttons to nest as well | Kartik K. Agaram | 2022-08-23 | 1 | -2/+11 |
| | | |||||
| * | flip return value of button handlers | Kartik K. Agaram | 2022-08-23 | 2 | -6/+4 |
| | | | | | | | | | | | | This is compatible with Javascript, and it also seems like a better default; when people forget to think about return values in click handlers, they should be consumed. | ||||
| * | stop putting button state in a global | Kartik K. Agaram | 2022-08-23 | 3 | -9/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Symptom: a test (test_click_to_create_drawing) started randomly failing after I inserted a `return` 2 commits ago. Cause: my tests call edit.draw, but button handlers only get cleared in app.draw. So my tests weren't clearing button handlers, and every call to edit.draw was accumulating states. Still unclear why those were going to different state objects after the `return`, but anyway. I'm not going to understand every last thing that happens when things go wrong, just guarantee they can't go wrong. And the way to do that is to decentralize button handlers to each state that receives them. The State object in buttons.lua doesn't have to be Editor_state. It just has to be some table that provides a Schelling Point for shared state. | ||||
| * | improve explanation for buttons | Kartik K. Agaram | 2022-08-23 | 1 | -1/+4 |
| | | |||||
| * | allow buttons to interrupt events | Kartik K. Agaram | 2022-08-23 | 2 | -2/+6 |
| | | | | | | | | Most button onpress1 handlers will want to return true. | ||||
| * | indent | Kartik K. Agaram | 2022-08-23 | 1 | -1/+3 |
| | | |||||
| * | distinguish consistently between mouse buttons and other buttons | Kartik K. Agaram | 2022-08-23 | 3 | -30/+30 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-22 | 0 | -0/+0 |
|\| | |||||
| * | include pensieve.love even though it's in development | Kartik K. Agaram | 2022-08-22 | 1 | -0/+5 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-21 | 2 | -1/+4 |
|\| | | | | | | | Bring forks up to date. | ||||
| * | include a fork | Kartik K. Agaram | 2022-08-21 | 1 | -0/+2 |
| | | |||||
| * | correct a comment | Kartik K. Agaram | 2022-08-21 | 1 | -1/+1 |
| | | | | | | | | We no longer have undo history directly in globals. | ||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-19 | 2 | -0/+3 |
|\| | |||||
| * | regression: dropping files on the window | Kartik K. Agaram | 2022-08-19 | 2 | -0/+3 |
| | | | | | | | | Also improve the test to catch this next time. | ||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-19 | 2 | -4/+6 |
|\| | |||||
| * | fix a name | Kartik K. Agaram | 2022-08-19 | 1 | -4/+4 |
| | | |||||
| * | reclaim a couple more functions after tests | Kartik K. Agaram | 2022-08-19 | 1 | -0/+2 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-18 | 1 | -2/+2 |
|\| | |||||
| * | couple of accidental globals | Kartik K. Agaram | 2022-08-18 | 1 | -2/+2 |
| | | | | | | | | Luckily they didn't bite me yet. | ||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-18 | 4 | -52/+41 |
|\| | |||||
| * | get rid of some ridiculous code | Kartik K. Agaram | 2022-08-18 | 1 | -15/+5 |
| | | | | | | | | | | | | I guess I wrote it before I settled into the idiom of: * first change cursor * then scroll if necessary | ||||
| * | spurious args | Kartik K. Agaram | 2022-08-18 | 1 | -18/+18 |
| | | |||||
| * | dead code | Kartik K. Agaram | 2022-08-18 | 1 | -2/+0 |
| | | |||||
| * | generalize a function | Kartik K. Agaram | 2022-08-18 | 3 | -12/+13 |
| | | |||||
| * | drop some obsolete args | Kartik K. Agaram | 2022-08-18 | 1 | -2/+2 |
| | | |||||
| * | subsection headings in a long switch | Kartik K. Agaram | 2022-08-18 | 1 | -0/+2 |
| | | |||||
| * | extract a variable | Kartik K. Agaram | 2022-08-18 | 1 | -2/+3 |
| | | |||||
| * | simplify | Kartik K. Agaram | 2022-08-18 | 1 | -4/+1 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-17 | 1 | -5/+2 |
|\| | |||||
| * | simpler location comparison | Kartik K. Agaram | 2022-08-17 | 1 | -5/+2 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-17 | 1 | -4/+5 |
|\| | |||||
| * | move caching behavior inside compute_fragments | Kartik K. Agaram | 2022-08-17 | 1 | -6/+6 |
| | | |||||
| * | remove some unnecessary work | Kartik K. Agaram | 2022-08-17 | 1 | -1/+3 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-17 | 2 | -14/+12 |
|\| | |||||
| * | standardize scroll check in a few places | Kartik K. Agaram | 2022-08-17 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | I'm taking some lessons from pensieve.love here. It seem like specific pixel thresholds don't matter too much for plain lines.love. I'd probably feel safer if I just used Text.cursor_out_of_screen in these places, but it means we draw the screen twice for most events[1]. Let's see if we can get by with the current approach. [1] Or we have to start scheduling things for the next draw, which is more complex to orchestrate. | ||||
| * | simplify cursor-on-screen check | Kartik K. Agaram | 2022-08-17 | 2 | -11/+9 |
| | | |||||
* | | Merge lines.love | Kartik K. Agaram | 2022-08-17 | 3 | -8/+8 |
|\| | |||||
| * | swap return values | Kartik K. Agaram | 2022-08-17 | 3 | -8/+8 |
| | |