compilation:
- reduce binary size
* remove the null columns in EUC-KR decoding
* fbf for unifont
* maybe use system wcwidth?
charsets:
- set up some fuzzer
- use appropriate charsets in forms, urls, etc.
display:
- important: buffer list
* either a buffer list buffer, or a buffer list popup menu. ideally
both.
- dark mode (basically max Y)
- override bgcolor ourselves when terminal fails to report it
- 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: 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: improve sandboxing
* sandbox more built-in CGI protocol handlers
* fix newFormData with seccomp
- configurable/better url filtering in loader
- when the log buffer crashes, print its contents to stderr
* easiest way seems to be to just dump its cache file
- add buffer groups
- xhtml
pager:
- better horizontal line handling: allow viewing content positioned before page
start, handle long lines, etc
- figure out a way to show long messages on the status line
- history, bookmarks (w3m format?)
- save/edit buffer output
- alert on external command failure
network:
- uBO integration? (or at least implement filter lists)
- websockets (curl supports ws)
javascript:
- add support for JS mixins
- distinguish double from unrestricted double
- better dom support: more events, CSSOM, ...
- 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.
- 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 :/
- do not break inline boxes with out-of-flow block boxes (float, absolute, etc.)
* this seems hard to fix properly :(
* reminder: this does *not* apply to flexbox; in fact it has the inverse
problem AFAICT.
- table layout: include caption in width calculation
- flexbox: align-self, align-items, justify-content, proper margin handling,
proper flex base size resolution
- details element
- overflow
- partial layout, layout caching
- iframe
- writing-mode, grid, ruby, ... (i.e. cool new stuff)
images:
- more efficient kitty display (use IDs)
- more efficient sixel display (store encoded images)
- more efficient display in general (why are we repainting 3-4 times per
keypress?)
- document it (when performance is acceptable)
- proper sixel color register allocation (current one is a hack)
- fix race condition where images decoded after buffer load won't display until
reshape
- remove in-buffer decoder; instead, decode images in fully locked down CGI
scripts
* then, the pager can just read the output from the cache on-demand
instead of copying it from buffers
- incremental decoding, interlaced images, animation
man:
- add a DOM -> man page converter so that we do not depend on pandoc
for man page conversion
gmifetch:
- rewrite in Nim
etc:
- orc support
- maybe windows support? (blocker: needs a windows machine)