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)