about summary refs log tree commit diff stats
path: root/todo
blob: 79e5fb2e2f91fd1ed287fa491f9a16a9ac691589 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
compilation:
- reduce binary size (maybe gzip data/*?)
- improve compilation times (it's sloooow... we could probably speed up the js
  macros somehow, also the html parser/tokenizer?)
charsets:
- set up some fuzzer
- use appropriate charsets in forms, urls, etc.
- JS TextEncoder interface
docs:
- manpage
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
- working js interface
buffer:
- important: incremental html parsing
	* also, do not needlessly copy in onload
- 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
- buffer cloning: fork buffer process instead of piping source
- disable "reinterpret as html" for the log buffer
- 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 highlighting, copy
- 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:
- ftp/sftp
- gopher
- gemini? (not a fan, but quite a bit of interesting content is on gemini)
- uBO integration? (or at least implement filter lists)
- websockets (curl supports ws)
- integrate curl-impersonate (LD_PRELOAD works, but still...)
external:
- something like EXTERN
- mime type handling and external viewers (e.g. open sound with mpv...)
- local cgi, external filters (e.g. rdrview, pandoc convert, ...)
- history, bookmarks (w3m format)
- save buffer (source, output)
- edit buffer (local file, or whatever we downloaded)
javascript:
- important: check where to use defineProperty and setProperty
- important: callbacks leak memory, I think. fix this (e.g. have a ref
  JSCallback or something)
- add support for JS mixins
- distinguish double from unrestricted double
- "javascript:" urls
- better dom support, events
	* more concretely: get jQuery and basic click events to work
- implement ReadableStream, XHR
- make document accessible from client console? (maybe a bad idea
  security-wise, but it would sure be convenient...)
	* alternative idea: separate console for each buffer
- implement JS access to non-ref object members (with a ptr opaque + GC_ref
  on parent object or something)
- buffer selection
layout engine:
- important: floats (way too many websites look very ugly without them)
- make background-color a property of inline boxes, not words. (this would
  require implementing actual inline boxes)
- table rowspan
	* there's already a `growing' list in table context, just use that...
- 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:
	* go through copyMem & c library calls and add prepareMutation
	  where necessary (for orc)
- maybe windows support? (blocker: needs a windows machine)