compilation:
- reduce binary size (maybe gzip data/*?)
charsets:
- set up some fuzzer
- use appropriate charsets in forms, urls, etc.
display:
- important: add a virtual cursor (in some terminals, the real cursor is
often obscured by white background color)
- important: buffer list
* either a buffer list buffer, or a buffer list popup menu. ideally
both.
- dark mode (basically max Y)
- do not assume default background color
* instead, add an "override-default-color" option that is set to
true by default and replaces default bgcolor/fgcolor with
default-background/foreground-color
- allow overriding ansi colors
config:
- important: config editor
- completely replace siteconf; the new solution should:
* not be based on table arrays
* allow overriding pretty much every global value per URL
* allow better URL matching (regexes aren't great for this task)
* be called url-config
* allow matching $TERM string, buffer groups (but maybe this should
be a separate setting?)
- add per-scheme configuration (e.g. proto.gemini.known-hosts = '/some/path')
- add RPC for CGI scripts e.g. toggle settings/issue downloads/etc
* also some way to set permissions for RPC calls
buffer:
- important: incremental html parsing
- important: validate returned values
* do not block container when receiving buffer data; if invalid, kill
buffer
* this also includes not crashing when the buffer dies while
container is reading...
- important: add sandboxing
* also, other security stuff:
- configurable/better url filtering in loader
- make peekCursor show the entire url
- when the log buffer crashes, print its contents to stderr
* make console.err a TeeStream, and tee it to a StringStream that
buffers up to 4KB
- add buffer groups
- add option to write source to a file, instead of keeping it in memory
- hex viewer
- xhtml
- better horizontal line handling: allow viewing content positioned before page
start, handle long lines, etc
- do not prompt when submitting forms (it's annoying)
* this is mostly fixed, but not completely
network:
- uBO integration? (or at least implement filter lists)
- websockets (curl supports ws)
external:
- history, bookmarks (w3m format)
- save buffer (source, output)
- edit buffer (local file, or whatever we downloaded)
javascript:
- important: callbacks should not leak memory
- add support for JS mixins
- distinguish double from unrestricted double
- better dom support, more events
* more concretely: get jQuery to work. this needs innerHTML, CSS
properties in DOM, ...
- implement ReadableStream, XHR
- separate console for each buffer
- buffer selection
layout engine:
- box borders
* will probably need special treatment, as borders must round to
1ch in x direction and 1em in y direction.
- fix conflict in renderdocument Y error correction and floats
* if too many line breaks are done because of floats, Y error
correction will happily arrange the lines on top of the floating box
- make table width calculation consistent with FF etc.
* unfortunately, most websites are designed for auto table layouts
where w3m's space distribution algorithm does not work really well :/
- table layout: include caption in width calculation
- details element
- overflow
- incremental layout & layout caching
* first for tree generation, then for layout.
- iframe
- writing-mode, flexbox, grid, ruby, ... (i.e. cool new stuff)
images:
- sixel encoding (eventually also kitty)
- more formats (apng, gif: write own decoders, jpeg: use libjpeg, webp: ?)
- incremental decoding (maybe implement streams first?)
- separate image decoder process? or just run on a different thread?
etc:
- important: replace fastRuneAt with qjs libunicode (fastRuneAt has no error handling...)
- tests (including aforementioned fuzzer)
- orc support
- maybe windows support? (blocker: needs a windows machine)