Client for playing 300 publicly available Sokoban puzzles on a computer or phone.
Go to file
Kartik K. Agaram f17dd5ec46 Merge text0 2023-05-06 09:15:14 -07:00
assets flesh out Readme 2023-01-08 08:11:15 -08:00
0000-freewheeling-start new file-system format for freewheeling apps 2023-04-16 11:16:47 -07:00
0001-on better comment 2023-04-20 23:39:36 -07:00
LICENSE.txt add a license 2022-05-16 18:51:28 -07:00
Manual_tests.md Merge text0 2023-05-06 09:15:14 -07:00
MemoryReferenceInfo.lua.0 remove some memory leaks from rendered fragments 2022-06-10 11:16:41 -07:00
MemoryReferenceInfo.lua.unused clean up memory leak experiments 2022-06-10 13:46:59 -07:00
README.md Merge text0 2023-04-21 23:36:35 -07:00
app.lua Merge text0 2023-04-19 19:47:42 -07:00
button.lua bugfix: propagate mouse press if any button would 2022-08-24 13:40:36 -07:00
edit.lua Merge text0 2023-04-08 22:03:05 -07:00
file.lua bring back everything from commit a68647ae22 2022-11-06 08:53:46 -08:00
json.lua
keychord.lua make love event names consistent 2022-12-23 18:52:28 -08:00
live.lua send a response when deleting a definition 2023-04-30 22:58:31 -07:00
main.lua bugfix: wasn't recovering from errors 2023-04-21 08:18:00 -07:00
reference.md document the freewheeling protocol 2023-05-01 00:07:56 -07:00
search.lua Merge text0 2023-04-02 16:50:08 -07:00
select.lua Merge lines.love 2023-04-02 09:22:32 -07:00
test.lua show another detail on test failure 2023-01-20 21:48:49 -08:00
text.lua Merge text0 2023-05-06 09:15:14 -07:00
text_tests.lua Merge text0 2023-04-02 16:50:08 -07:00
undo.lua Merge lines.love 2023-04-02 09:22:32 -07:00

README.md

Example "freewheeling" app that can be modified without being restarted

Running this repo in isolation won't be very helpful. If you haven't yet, first check out the driver app. This repo is a template you can copy to create your own live apps that juggle text editor widgets. The editors support copy/paste, search, infinite undo, etc. You can't modify editor functionality live (yet?).

This repo is a fork of lines.love, an editor for plain text where you can also seamlessly insert line drawings. Designed above all to be easy to modify and give you early warning if your modifications break something.

Getting started

Install LÖVE. It's just a 5MB download, open-source and extremely well-behaved. I'll assume below that you can invoke it using the love command, but that might vary depending on your OS.

Run this app from the terminal, passing its directory to LÖVE

Hacking

To modify it live without restarting the app each time, download the driver app. Here's an example session using a fork of this repo:

making changes without restarting the app

To publish your changes:

  • delete all files with a numeric prefix from the repo, and then
  • move all files with a numeric prefix from the save directory to the repo.

Keyboard shortcuts

Up to you! But within the included editor widget if you use it:

  • ctrl+f to find patterns within a file
  • ctrl+c to copy, ctrl+x to cut, ctrl+v to paste
  • ctrl+z to undo, ctrl+y to redo
  • ctrl+= to zoom in, ctrl+- to zoom out, ctrl+0 to reset zoom
  • alt+right/alt+left to jump to the next/previous word, respectively
  • mouse drag or shift + movement to select text, ctrl+a to select all

Exclusively tested so far with a US keyboard layout. If you use a different layout, please let me know if things worked, or if you found anything amiss: http://akkartik.name/contact

Known issues

  • Both freewheeling apps and the driver for them currently benefit from being launched in terminal windows rather than by being clicked on in a desktop OS. See the driver app for details.

  • No support yet for Unicode graphemes spanning multiple codepoints.

  • No support yet for right-to-left languages.

  • Undo/redo may be sluggish in editor windows containing large files. Large files may grow sluggish in other ways.

  • If you kill the process, say by force-quitting because things things get sluggish, you can lose data.

  • Can't scroll while selecting text with mouse.

  • No scrollbars yet. That stuff is hard.

Mirrors and Forks

This repo is a fork of lines.love, an editor for plain text where you can also seamlessly insert line drawings. Its immediate upstream is text.love, a version without support for line drawings. Updates to it can be downloaded from the following mirrors:

Further forks are encouraged. If you show me your fork, I'll link to it here.

Feedback

Most appreciated.