A viewer for plain text with color markup
Go to file
Kartik K. Agaram 7fbcc0f8e5 Merge notebook.love 2024-10-02 10:26:24 -07:00
assets Merge notebook.love 2024-10-02 10:26:24 -07:00
LICENSE.txt add a license 2022-05-16 18:51:28 -07:00
README.md Merge notebook.love 2024-09-27 23:24:11 -07:00
array.lua turn move.lua back into its own center without any globals 2024-09-17 16:00:36 -07:00
edit.lua Merge notebook.love 2024-10-02 10:26:24 -07:00
font_height.lua split up edit.lua without introducing globals 2024-09-17 15:22:56 -07:00
json.lua forgot to add json.lua 2022-05-15 14:36:25 -07:00
loc.lua turn move.lua back into its own center without any globals 2024-09-17 16:00:36 -07:00
main.lua Merge notebook.love 2024-10-02 10:26:24 -07:00
move.lua new fork: a text file viewer with color markup 2024-09-27 23:07:49 -07:00
my_string.lua start printing out result of eval 2024-09-20 23:44:33 -07:00
my_table.lua topologically sort and eval all code lines every time file changes 2024-09-21 23:59:40 -07:00
my_utf8.lua Merge fractions.love 2024-09-17 18:10:36 -07:00
prose.lua Merge notebook.love 2024-10-02 10:26:24 -07:00
rects.lua new fork: a text file viewer with color markup 2024-09-27 23:07:49 -07:00
subtle_color.lua experiment: separate colors for LHS and RHS 2024-09-24 14:54:17 -07:00
utils.lua basic arithmetic seems done 2024-09-20 23:44:33 -07:00

README.md

A viewer for plain text with color markup

0 dependencies!

Current syntax:

  • Inline styling using <...|...> syntax, where you can currently specify fg (foreground color) or bg (background color). For example, <heat|fg=1,0,0>. Colors are triples of 3 numbers between 0 and 1, separated by commas. Use spaces only to separate fg and bg, thus: <heat|fg=1,0,0 bg=0,0,1>.

Getting started

Install LÖVE. It's just a 5MB download, open-source and extremely well-behaved.

To run from the terminal, pass this directory to LÖVE, optionally with a file path to edit.

Alternatively, turn it into a .love file you can double-click on:

$ zip -r /tmp/highlight.love *.lua

By default, highlight.love reads/writes the file lines.txt in a directory relative to this app.

To open a different file, drop it on the highlight.love window.

Keyboard shortcuts

While editing text:

  • 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

  • No support yet for Unicode graphemes spanning multiple codepoints.

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

  • If you ever see a crash when clicking on the mouse, it might be because a mouse press and release need to happen in separate frames. Try pressing and releasing more slowly and let me know if that helps or not. This is klunky, sorry.

  • 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. Its immediate upstream is notebook.love, a notebook UI that first implemented the markup syntax for styling. 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. Messages, PRs, patches, forks, it's all good.