X-Git-Url: https://git.distorted.org.uk/~mdw/sgt/agedu/blobdiff_plain/84849cbd12159f7950a5ee35a36f5251a6d8bd3e..13a92302fb25fd835632685f2417fb0c1ad56c34:/TODO diff --git a/TODO b/TODO index fe0cb71..e742e4b 100644 --- a/TODO +++ b/TODO @@ -3,43 +3,8 @@ TODO list for agedu Before it's non-embarrassingly releasable: - - more flexible running modes - + at least some ability to chain actions within the same run: - "agedu -s dirname -w" would seem handy. - - - work out what to do about atimes on directories in the absence of - the Linux syscall magic - * one option is to read them during the scan and reinstate them - after each recursion pop. Race-condition prone. - * marking them in a distinctive colour in the reports is another - option. - * a third option is simply to ignore space taken up by - directories in the first place; inaccurate but terribly simple. - * incidentally, sometimes open(...,O_NOATIME) will fail, and - then we have to fall back to ordinary open. Be prepared to do - this, which probably means getting rid of the icky macro - hackery in du.c and turning it into a more sensible run-time - abstraction layer. - - - polish the plain-text output to make it look more like du - + configurable recursive output depth - + show the right bits last - - - figure out what to do about scans starting in the root directory - + Currently we end up with a double leading slash on the - pathnames, which is ugly, and we also get a zero-length href - in between those slashes which means the web interface doesn't - let you click back up to the top level at all. - + One big problem here is that a lot of the code assumes that - you can find the extent of a pathname by searching for "foo" - and "foo^A", trusting that anything inside the directory will - begin "foo/". So I'd need to consistently fix this everywhere - so that a trailing slash is disregarded while doing it, but - not actually removed. - + The text output gets it all wrong. - + The HTML output is fiddly even at the design stage: where - would I _ideally_ put the link to click on to get back to /? - It's unclear! + - arrange to be able to identify directories and leave them on one + side of the usual age display - cross-Unix portability: + use autoconf @@ -51,11 +16,14 @@ Before it's non-embarrassingly releasable: too, if it's available and O_NOATIME is too. * what do we do elsewhere about _GNU_SOURCE? - - man page, licence. + - man page, --version. -Future directions: +Future possibilities: - IPv6 support in the HTTP server + * of course, Linux magic auth can still work in this context; we + merely have to be prepared to open one of /proc/net/tcp or + /proc/net/tcp6 as appropriate. - run-time configuration in the HTTP server * I think this probably works by having a configuration form, or @@ -75,20 +43,6 @@ Future directions: straight to terminfo: generate lines of attribute-interleaved text and display them, so we only really need the sequences "go here and display stuff", "scroll up", "scroll down". - + I think the attribute-interleaved text might be possible to do - cunningly, as well: we autodetect a basically VT-style - terminal, and add 256-colour sequences on the end. So, for - instance, we might set ANSI-yellow foreground, set ANSI-red - background, _then_ set both foreground and background to the - appropriate xterm 256-colour, and then display some - appropriate character which would have given the right blend - of the ANSI-16 fore and background colours. Then the same - display code should gracefully degrade in the face of a - terminal which doesn't support xterm-256. - * current best plan is to simulate the xterm-256 shading from - 0/5 to 5/5 by doing space, colon and hash in colour A on - colour B background, then hash, colon and space in B on A - background. + Infrastructure work before doing any of this would be to split html.c into two: one part to prepare an abstract data structure describing an HTML-like report (in particular, all