Client for playing 300 publicly available Sokoban puzzles on a computer or phone.
Go to file
Kartik K. Agaram 9f21230005 Merge template-live-editor-mobile 2023-11-19 12:07:16 -08:00
assets
0000-freewheeling-start
0001-on
0002-Debug_animations_in_progress
0003-refresh_debug_animations
0004-on.update implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0005-animate
0006-loiter
0007-save_callstack
0008-Debug_animation_period
0009-Editor_state
0010-Line_height
0011-on.initialize implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0012-on.draw implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0013-on.keychord_press
0014-on.text_input
0015-on.key_release
0016-on.mouse_press implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0017-on.mouse_release implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0019-Line_number_padding
0020-draw_editor_border
0021-draw_menu implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0023-Menu_top
0024-Menu_left
0025-Menu_height
0026-Menu_bottom
0027-Menu_background
0028-draw_output_border
0029-Safe_width
0030-Safe_height
0031-on.resize implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0032-update_font_settings
0033-Normal_color
0034-draw_scrollbar implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0035-compute_scrollbar
0036-adjust_scrollbar implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0038-on_editor_scrollbar implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0040-on_editor_scrollbar_area implement second, 'output' editor 2023-11-18 21:18:09 -08:00
0041-Canvas implement 'Run' button 2023-11-18 19:42:26 -08:00
0042-draw_canvas implement 'Run' button 2023-11-18 19:42:26 -08:00
0043-map implement 'Run' button 2023-11-18 19:42:26 -08:00
0044-Output_editor_state implement second, 'output' editor 2023-11-18 21:18:09 -08:00
LICENSE.txt
Manual_tests.md
MemoryReferenceInfo.lua.0
MemoryReferenceInfo.lua.unused
README.md
app.lua bugfix: initial textinput event on iOS 2023-11-19 10:57:10 -08:00
button.lua
colorize.lua
default_map
edit.lua Merge template-live-editor-mobile 2023-11-18 12:59:35 -08:00
file.lua
json.lua
keychord.lua
live.lua
main.lua Merge template-live-editor-mobile 2023-11-19 12:07:16 -08:00
nativefs.lua
reference.md
search.lua Merge text0 2023-11-18 12:53:21 -08:00
select.lua Merge template-live-editor-mobile 2023-11-18 12:59:35 -08:00
test.lua
text.lua Merge template-live-editor-mobile 2023-11-18 12:59:35 -08:00
text_tests
text_tests.lua
undo.lua

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?).

Some reference documentation on how to create your own apps.

This repo is an example of a Freewheeling App, designed above all to be easy to run, easy to modify and easy to share.

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

If you run a .love file, your changes will go into the save directory. If you unzip the .love file into a new directory and run the directory instead, your changes will go straight into the same directory.

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.

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.