287
by Martin Pool
- todo: plugins |
1 |
-*- indented-text -*- |
2 |
||
293
by Martin Pool
- todos |
3 |
See also various low-level TODOs in the source code. Try looking in |
284
by Martin Pool
- more TODO items |
4 |
the list archive or on gmane.org for previous discussion of these |
293
by Martin Pool
- todos |
5 |
issues. |
6 |
||
7 |
These are classified by approximate size: an hour or less, a day or |
|
8 |
less, and several days or more. |
|
9 |
||
282
by Martin Pool
- move all TODO items into ./TODO |
10 |
|
11 |
Small things |
|
12 |
------------
|
|
13 |
||
14 |
* Add of a file that was present in the base revision should put back |
|
15 |
the previous file-id. |
|
16 |
||
17 |
* Handle diff of files which do not have a trailing newline; probably |
|
18 |
requires patching difflib to get it exactly right, or otherwise |
|
19 |
calling out to GNU diff. |
|
20 |
||
21 |
* Import ElementTree update patch. |
|
22 |
||
284
by Martin Pool
- more TODO items |
23 |
* Syntax should be "bzr export -r REV". |
282
by Martin Pool
- move all TODO items into ./TODO |
24 |
|
285
by Martin Pool
- update todos |
25 |
* "cat -rREV FILE" |
26 |
||
287
by Martin Pool
- todo: plugins |
27 |
* Plugins that provide commands. By just installing a file into some |
28 |
directory (e.g. /usr/share/bzr/plugins) it should be possible to |
|
29 |
create new top-level commands ("bzr frob"). Extensions can be |
|
30 |
written in either Python (in which case they use the bzrlib API) or |
|
31 |
in a separate process (in sh, C, whatever). It should be possible |
|
32 |
to get help for plugin commands. |
|
33 |
||
288
by Martin Pool
TODO |
34 |
* Smart rewrap text in help messages to fit in $COLUMNS (or equivalent |
35 |
on Windows) |
|
36 |
||
289
by Martin Pool
todo |
37 |
* -r option should take a revision-id as well as a revno. |
38 |
||
290
by Martin Pool
todo |
39 |
* "bzr info" could show space used by working tree, versioned files, |
40 |
unknown and ignored files. |
|
41 |
||
42 |
* "bzr info" should count only people with distinct email addresses as |
|
43 |
different committers. (Or perhaps only distinct userids?) |
|
44 |
||
291
by Martin Pool
todo |
45 |
* Tidier error for EPIPE: should be just "bzr: broken pipe" with no |
46 |
other details because debugging information is rarely interesting. |
|
290
by Martin Pool
todo |
47 |
|
293
by Martin Pool
- todos |
48 |
* On Windows, command-line arguments should be glob-expanded__, |
49 |
because the shell doesn't do this. However, there are probably some |
|
50 |
commands where this shouldn't be done, such as 'bzr ignore', because |
|
51 |
we want to accept globs. |
|
52 |
||
53 |
__ http://mail.python.org/pipermail/python-list/2001-April/037847.html |
|
54 |
||
295
by Martin Pool
todo |
55 |
* 'bzr ignore' command that just adds a line to the .bzrignore file |
56 |
and makes it versioned. |
|
57 |
||
58 |
* 'bzr help commands' should give a one-line summary of each command. |
|
59 |
||
282
by Martin Pool
- move all TODO items into ./TODO |
60 |
Medium things |
61 |
-------------
|
|
62 |
||
295
by Martin Pool
todo |
63 |
* Display command grammar in help messages rather than hardcoding it. |
64 |
||
65 |
* Change command functions into Command() objects, like in hct, and |
|
66 |
then the grammar can be described directly in there. Since all |
|
67 |
option definitions are global we can define them just once and |
|
68 |
reference them from each command. |
|
69 |
||
294
by Martin Pool
todo |
70 |
* Selective commit of only some files. |
71 |
||
282
by Martin Pool
- move all TODO items into ./TODO |
72 |
* Faster diff/status. |
73 |
||
74 |
Status should be handled differently because it needs to report on |
|
75 |
deleted and unknown files. diff only needs to deal with versioned |
|
76 |
files. |
|
77 |
||
78 |
* Merge Aaron's merge code. |
|
79 |
||
80 |
* Merge revert patch. |
|
81 |
||
82 |
* Turn on stat cache code, and add optimization about avoiding |
|
83 |
dangerous cache entries. |
|
84 |
||
85 |
* mv command? |
|
86 |
||
87 |
* More efficient diff of only selected files. |
|
88 |
||
89 |
* Fix up Inventory objects to represent root object as an entry. |
|
90 |
||
91 |
* Don't convert entire entry from |
|
92 |
||
93 |
* Extract changes from one revision to the next to a text form |
|
94 |
suitable for transmission over email. |
|
95 |
||
96 |
* More test cases. |
|
97 |
||
98 |
* Write a reproducible benchmark, perhaps importing various kernel versions. |
|
99 |
||
100 |
* Change test.sh from Bourne shell into something in pure Python so |
|
101 |
that it can be more portable. |
|
102 |
||
103 |
* Directly import diffs! It seems a bit redundant to need to rescan |
|
104 |
the directory to work out what files diff added/deleted/changed when |
|
105 |
all the information is there in the diff in the first place. |
|
106 |
Getting the exact behaviour for added/deleted subdirectories etc |
|
107 |
might be hard. |
|
108 |
||
109 |
At the very least we could run diffstat over the diff, or perhaps |
|
110 |
read the status output from patch. Just knowing which files might |
|
111 |
be modified would be enough to guide the add and commit. |
|
112 |
||
113 |
Given this we might be able to import patches at 1/second or better. |
|
114 |
||
115 |
* Get branch over http. |
|
116 |
||
117 |
* Pull pure updates over http. |
|
118 |
||
119 |
* revfile compression. |
|
120 |
||
121 |
* Split inventory into per-directory files. |
|
122 |
||
284
by Martin Pool
- more TODO items |
123 |
* Fix ignore file parsing: |
124 |
||
125 |
- fnmatch is not the same as unix patterns |
|
126 |
||
127 |
- perhaps add extended globs from rsh/rsync |
|
128 |
||
129 |
- perhaps a pattern that matches only directories or non-directories |
|
130 |
||
294
by Martin Pool
todo |
131 |
* Expansion of $Id$ keywords within working files. Perhaps do this in |
284
by Martin Pool
- more TODO items |
132 |
exports first as a simpler case because then we don't need to deal |
133 |
with removing the tags on the way back in. |
|
134 |
||
282
by Martin Pool
- move all TODO items into ./TODO |
135 |
|
136 |
Large things |
|
137 |
------------
|
|
138 |
||
294
by Martin Pool
todo |
139 |
* Hooks for pre-commit, post-commit, etc. |
140 |
||
141 |
Consider the security implications; probably should not enable hooks |
|
142 |
for remotely-fetched branches by default. |
|
143 |
||
144 |
* Pre-commit check. If this hook is defined, it needs to be handled |
|
145 |
specially: create a temporary directory containing the tree as it |
|
146 |
will be after the commit. This means excluding any ignored/unknown |
|
147 |
files, and respecting selective commits. Run the pre-commit check |
|
148 |
(e.g. compile and run test suite) in there. |
|
149 |
||
282
by Martin Pool
- move all TODO items into ./TODO |
150 |
* Web interface |
151 |
||
152 |
* GUI (maybe in Python GTK+?) |
|
153 |
||
284
by Martin Pool
- more TODO items |
154 |
* C library interface |