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)