First version.
This commit is contained in:
parent
def142d9eb
commit
935dcfeb6a
55
TODO
Normal file
55
TODO
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
$Id: TODO,v 1.1 2006/03/01 16:19:26 ianmacd Exp $
|
||||||
|
|
||||||
|
bash completion needs to be rewritten from the ground up.
|
||||||
|
---------------------------------------------------------
|
||||||
|
|
||||||
|
bash completion really needs to be rewritten from the ground up, using all of
|
||||||
|
the features available in bash 3.1 and without regard for compatibility with
|
||||||
|
the 2.x line.
|
||||||
|
|
||||||
|
At that time, it should be split into multiple files for easier source
|
||||||
|
management. Whether or not it is actually installed on the destination
|
||||||
|
computer as separate files is a matter for future debate.
|
||||||
|
|
||||||
|
If it were installed as tens or even hundreds of files, each of which had to
|
||||||
|
be opened to decide whether it should be sourced in its entirety, that could
|
||||||
|
prove very expensive on some systems.
|
||||||
|
|
||||||
|
Alternatively, a master file could decide which of the individual completion
|
||||||
|
files should be sourced. In that way, we wouldn't need to open extra files
|
||||||
|
just to ascertain that the commands for those functions aren't on the system,
|
||||||
|
anyway.
|
||||||
|
|
||||||
|
A further alternative is that a build process be created, which would
|
||||||
|
concatenate the various files into a single completion file, similar to what
|
||||||
|
we have now. This option is my least favourite, because a system with a lot of
|
||||||
|
packages installed currently has to deal with sourcing over 200 kB of bash
|
||||||
|
code for each invocation of an interactive shell.
|
||||||
|
|
||||||
|
An even better alternative would be if bash supported dynamic loading of shell
|
||||||
|
functions (in the manner of zsh), but I don't believe there are any plans to
|
||||||
|
add this feature.
|
||||||
|
|
||||||
|
|
||||||
|
bash completion needs a better development environment.
|
||||||
|
-------------------------------------------------------
|
||||||
|
|
||||||
|
Currently, the bash completion project is managed by a single person: me. This
|
||||||
|
is how it has been since its inception back in the first half of 2000.
|
||||||
|
|
||||||
|
This way of working is now showing signs of severe strain. For quite some time
|
||||||
|
already, I have been unable to devote enough time to the project and, as a
|
||||||
|
result, it has suffered. In particular, releases in the past twelve months
|
||||||
|
have been few and far between. The 20060301 release is the first in more than
|
||||||
|
six months.
|
||||||
|
|
||||||
|
Whilst there have been good reasons for my inability to devote more time to
|
||||||
|
the project, it shouldn't actually matter whether or not I am available. For
|
||||||
|
that reason, I am going to look at transferring the project to public CVS some
|
||||||
|
time in 2006. Patches will then no longer find that I am a single point of
|
||||||
|
failure, but will instead find their way into the code base via a small team
|
||||||
|
of core developers.
|
||||||
|
|
||||||
|
--
|
||||||
|
Ian Macdonald
|
||||||
|
Amsterdam, March 2006
|
Loading…
x
Reference in New Issue
Block a user