]> code.delx.au - gnu-emacs/blob - etc/TODO
Merged in changes from CVS trunk.
[gnu-emacs] / etc / TODO
1 -*-outline-*-
2
3 If you are ready to start working on any of these TODO items, we
4 appreciate your help; please write to emacs-devel@gnu.org so we can be
5 aware that the problem is being addressed, and talk with you how to do
6 it best. Since Emacs is an FSF-copyrighted package, please be
7 prepared to sign legal papers to transfer the copyright on your work
8 to the FSF.
9
10 * Small but important fixes needed in existing features:
11
12 ** Fix the kill/yank treatment of invisible text. At the moment,
13 invisible text is placed in the kill-ring, so that the contents of
14 the ring may not correspond to the text as displayed to the user. It
15 ought to be possible to omit text which is invisible (due to a
16 text-property, overlay, or selective display) from the kill-ring.
17
18 * Important features:
19
20 ** Provide user-friendly ways to list all available font families,
21 display a font as a sample, etc. [fx is looking at multilingual
22 font selection for Emacs 22.]
23
24 ** Program Enriched mode to read and save in RTF. [Is there actually a
25 decent single definition of RTF? Maybe see info at
26 http://latex2rtf.sourceforge.net/.]
27
28 ** Implement something better than the current Refill mode. This
29 probably needs some primitive support.
30
31 ** Implement primitive and higher-level functions to allow filling
32 properly with variable-pitch faces.
33
34 ** Implement a smoother vertical scroll facility, one that allows
35 C-v to scroll through a tall image. The primitive operations
36 posn-at-point and posn-at-x-y should now make it doable in elisp.
37
38 ** Implement intelligent search/replace, going beyond query-replace
39 (see http://graphics.csail.mit.edu/~rcm/chi04.pdf).
40
41 ** Implement other text formatting properties.
42 *** Footnotes that can appear either in place or at the end of the page.
43 *** text property that says "don't break line in middle of this".
44 Don't break the line between two characters that have the
45 same value of this property.
46 *** Discretionary hyphens that are not visible when they are at end of line.
47
48 ** Make movemail work with IMAP.
49
50 ** Internationalize Emacs's messages. [Note that this is of limited
51 use until the menus can display multilingual text. It also doesn't
52 address important issues like using the names of symbols essentially
53 as documentation, e.g. in command names and Custom. -- fx]
54
55 ** Make the Lucid menu widget display multilingual text. [This
56 probably needs to be done from actual Emacs buffers, either directly
57 in the menu or by rendering in an unmapped window and copying the
58 pixels. Note that the relevant Xlib functions assume a specific
59 locale; that isn't good enough even if X can render the arbitrary
60 text, which it often can't as far as I can tell. -- fx] [The gtk
61 port now displays multilingual text in menus, but only insofar as
62 Emacs can encode it as utf-8 and gtk can display the result.]
63
64 ** Remove the limitation that window and frame widths and heights can
65 be only full columns/lines.
66
67 * Other features we would like:
68
69 ** ange-ftp
70 *** understand sftp
71 *** Use MLS for ange-ftp-insert-directory if a list of files is specified.
72
73 ** Ability to map a key, including all modified-combinations.
74 E.g map mouse-4 to wheel-up as well as M-mouse-4 -> M-wheel-up
75 M-C-mouse-4 -> M-C-wheel-up, H-S-C-M-s-double-mouse-4 ->
76 H-S-C-M-s-double-wheel-up, ...
77
78 ** Beefed-up syntax-tables.
79 *** recognize multi-character syntactic entities like `begin' and `end'.
80 *** nested string-delimiters (for Postscript's (foo(bar)baz) strings).
81 *** support for infix operators (with precedence).
82 *** support for the $ (paired delimiter) in parse-partial-sexp.
83 *** support for hook-chars whose effect on the parsing-state is specified
84 by elisp code. Thus a char could both close a string and open a comment
85 at the same time and do it in a context-sensitive way.
86 *** ability to add mode-specific data to the partial-parse-state.
87
88 ** Add a way to convert a keyboard macro to equivalent Lisp code.
89
90 ** Have a command suggestion help system that recognizes patterns
91 of commands which could be replaced with a simpler common command.
92 It should not make more than one suggestion per 10 minutes.
93
94 ** Add a way to define input methods by computing them (when first used)
95 from other input methods. Then redefine C-x 8 to use a
96 user-selected input method, with the default being the union of
97 latin-1-prefix and latin-1-postfix.
98
99 ** Implement a clean way to use different major modes for
100 different parts of a buffer. This could be useful in editing
101 Bison input files, for instance, or other kinds of text
102 where one language is embedded in another language.
103
104 ** Give start-process the ability to direct standard-error
105 output to a different filter.
106
107 ** Make desktop.el save the "frame configuration" of Emacs (in some
108 useful sense).
109
110 ** Give desktop.el a feature to switch between different named
111 desktops.
112
113 ** Replace finder.el with something that generates an Info file
114 which gives the same information through a menu structure. [Dave
115 Love started on this.]
116
117 ** Implement a variant of uncompress.el or jka-compr.el that works with
118 GNU Privacy Guard for encryption. [Code exists but isn't assigned.
119 See the Gnus development sources for assigned code concerning GPG
120 use with mail, which is probably a good start.]
121
122 ** Save undo information in special temporary files, and reload it
123 when needed for undoing. This could extend undo capacity.
124
125 ** Change the Windows NT menu code
126 so that it handles the deep_p argument and avoids
127 regenerating the whole menu bar menu tree except
128 when the user tries to use the menubar.
129
130 This requires the RIT to forward the WM_INITMENU message to
131 the main thread, and not return from that message until the main
132 thread has processed the MENU_BAR_ACTIVATE_EVENT and regenerated
133 the whole menu bar. In the mean time, it should process other messages.
134
135 ** Get some major packages installed: W3/url (development version needs
136 significant work), PSGML. Check the assignments file for other
137 packages which might go in and have been missed.
138
139 ** Make keymaps a first-class Lisp object (this means a rewrite of
140 keymap.c). What should it do apart from being opaque ?
141 multiple inheritance ? faster where-is ? no more fix_submap_inheritance ?
142 what else ?
143
144 ** Provide real menus on ttys. The MS-DOS implementation can serve as
145 an example how to do part of this.
146
147 ** Implement popular parts of the rest of the CL functions as compiler
148 macros in cl-macs.
149
150 ** Make compiler warnings about functions that might be undefined at run time
151 smarter, so that they know which files are required by the file being
152 compiled and don't warn about functions defined in them.
153
154 ** Highlight rectangles (`mouse-track-rectangle-p' in XEmacs). Already in CUA,
155 but it's a valuable feature worth making more general.
156
157 ** Support simultaneous tty and X frames. [For a partial
158 implementation, see tla branch
159 lorentey@elte.hu--2004/emacs--multi-tty--0 at
160 http://lorentey.hu/arch/2004]
161
162 ** Provide MIME support for Rmail using the Gnus MIME library. [Maybe
163 not now feasible, given Gnus maintenance decisions. fx looked at
164 this and can say where some of the problems are.]
165
166 ** Eliminate the storm of warnings concerning char/unsigned char
167 mismatches that we get with proprietary compilers on various systems.
168 They make it difficult to spot the important warnings.
169
170 ** Fix anything necessary to use `long long' EMACS_INTs with GCC.
171
172 ** Split out parts of lisp.h and generate Makefile dependencies
173 automatically.
174
175 ** Update the FAQ.
176
177 ** Allow auto-compression-mode to use zlib calls if zlib is available.
178 [It's required for PNG, so may be linked anyhow.]
179
180 ** Add a --pristine startup flag which does -q --no-site-file plus
181 ignoring X resources (Doze equivalents?) and most of the
182 environment. What should not be ignored needs consideration.
183
184 ** Investigate using the language environment (or locale?) to set up
185 more things, such as the default Ispell dictionary, calendar
186 holidays, quoting characters?,...
187
188 ** Improve the GC (generational, incremental). (We may be able to use
189 the Boehm collector.) [See the Boehm-GC branch in CVS for work on
190 this.]
191
192 ** Check what hooks would help Emacspeak -- see the defadvising in W3.
193
194 ** Add horizontal scroll bars.
195
196 ** Provide an optional feature which computes a scroll bar slider's
197 size and its position from lines instead of characters.
198
199 ** Make the Custom themes support do useful things.
200
201 ** Add support for SVG (Scalable Vector Graphics) rendering to
202 Emacs.
203
204 ** Allow unknown image types to be rendered via an external program
205 converting them to, say, PBM (in the same way as PostScript?).
206
207 ** Allow displaying an X window from an external program in a buffer,
208 e.g. to render graphics from Java applets. [gerd and/or wmperry
209 thought this was feasible.]
210
211 ** Allow images (not just text) in the margin to be mouse-sensitive.
212 (Requires recursing through display properties). Provide some way
213 to simulate mouse-clicks on marginal text without a mouse.
214
215 ** Implement Lisp functions to determine properly whether a character
216 is displayable (particularly needed in XFree 4, sigh). Use it to
217 define useful glyphs that may be displayed as images or unicodes
218 (with ASCIIfied fallback via latin1-disp). Examples include
219 box-drawing graphics in Custom buffers, W3 rules and tables, and
220 tree displays generally, mode-line mail indicator. [See work done
221 already for Emacs 22 and consult fx.]
222
223 ** Do something to make rms happy with fx's dynamic loading, and use it
224 to implement things like auto-loaded buffer parsers and database
225 access in cases which need more than Lisp.
226
227 ** Extend ps-print to deal with multiple font sizes, images, and extra
228 encodings.
229
230 ** Provide portable undumping using mmap (per gerd design).
231
232 ** Use the XIE X extension, if available, for image display.
233
234 ** Make monochrome images display using the foreground and background
235 colors of the applicable faces.
236
237 ** Add support for rendering antialiased text, probably using
238 XRender/Freetype.
239
240 ** Port the conservative stack marking code of Emacs' garbage collector
241 to more systems, so that we can completely get rid of GCPROs.
242
243 ** Reorder defcustom's in each package so that the more important
244 options come first in the Customize buffers. This could be done by
245 either rearranging the file (since options are shown in the order
246 they appear in the *.el files), or by adding a few :set-after
247 attributes.
248
249 ** Maybe document the features of libraries missing from the manual (or
250 ancillary manuals, including the Lisp manual in some cases).
251 This is not worth doing for all of these packages and we need not
252 aim for completeness, but some may be worth documenting.
253
254 Here's a list which is probably not complete/correct: align, allout,
255 artist, ansi-color, array, battery, calculator, cdl, cmuscheme,
256 completion, cua, delim-col, dirtrack, double, echistory, elide-head,
257 easymenu, expand, flow-ctrl, format [format-alist],
258 generic/generic-x [various modes], kermit, log-edit, ledit
259 [obsolete?], makesum, midnight [other than in Kill Buffer node],
260 mouse-copy [?], mouse-drag, mouse-sel, net-utils, rcompile,
261 snmp-mode [?], soundex [should be interactive?], strokes [start from
262 the web page], talk, thingatpt [interactive functions?], type-break,
263 vcursor, xscheme, zone-mode [?], mlconvert [?], iso-cvt, iso-swed,
264 swedish, feedmail [?], uce, bruce, gametree, meese, page-ext,
265 refbib, refer, scribe, sgml-mode, spell, texinfo, underline,
266 cmacexp, hideif, mantemp [obsolete?], pcomplete, assoc, xml,
267 cvs-status (should be described in PCL-CVS manual); other progmodes,
268 probably in separate manual.
269
270 ** Convert the XPM bitmaps to PPM, replace the PBMs with them and scrap
271 the XPMs so that the colour versions work generally. (Requires care
272 with the colour used for the transparent regions.)
273
274 ** Convenient access to the `values' variable. It would be nice to have an
275 interface that would show you the printed reps of the elements of the
276 list in a menu, let you select one of the values, and put it into some
277 other variable, without changing the value of `values'.
278
279 ** (Controlled by a flag) make open and close syntax match exactly,
280 i.e. `(' doesn't match `]'.
281
282 ** Specify parameter ID-FORMAT in all calls to `file-attributes' and
283 `directory-files-and-attributes' where attributes UID or GID are used.
284 Whenever possible, use value 'string.
285 When done, change meaning of default value from 'integer to 'string.
286 If value 'integer is used nowhere, remove the parameter ID-FORMAT from
287 the definition of `file-attributes' and `directory-files-and-attributes'
288 and from the calls.
289
290 ** Make language-info-alist customizable. Currently a user can customize
291 only the variable `current-language-environment'.
292
293 ** Improve language environment handling so that Emacs can fit
294 better to a users locale. Currently Emacs uses utf-8 language
295 environment for all utf-8 locales, thus a user in ja_JP.UTF-8 locale
296 are also put in utf-8 lang. env. In such a case, it is
297 better to use Japanese lang. env. but prefer utf-8 coding system.
298
299 ** Eliminate the current restriction on header printing by ps-print.
300 Currently, a header can contain only single 1-byte charset in
301 addition to ASCII.
302
303 ** In ps-print, provide an user friendly interface to specify fonts.
304
305 ** OpenType font support for various complex scripts (e.g. Devanagari).
306 As X protocal doesn't provide a way to access OpenType Layout Tables
307 in a OpenType font of a server side, we need a way to utilize local
308 fonts (perhaps by directly using the Freetype library or indirectly
309 via Xft library).
310
311 ** Enhance word boundary detection for such a script that doesn't use
312 space at word boundary (e.g. Thai).
313
314 ** Implement interface programs with major Japanese conversion server
315 in lib-src so that they can be used from the input method
316 "japanese". Currently, most Japanese users are using external
317 packages (e.g. tamago, anthy) or an input method via XIM.
318
319 * Internal changes
320
321 ** Replace gmalloc.c with the modified Doug Lea code from the current
322 GNU libc so that the special mmapping of buffers can be removed --
323 that apparently loses under Solaris, at least. [fx has mostly done
324 this.]
325
326 ** Rewrite make-docfile to be clean and maintainable.
327
328 ** Add an inferior-comint-minor-mode to capture the common set of operations
329 offered by major modes that offer an associated inferior
330 comint-derived mode. I.e. basically make cmuscheme.el/inf-lisp.el generic.
331 For use by sml-mode, python-mode, tex-mode, scheme-mode, lisp-mode,
332 haskell-mode, tuareg-mode, ...
333
334 ;;; arch-tag: b0a3e40b-726a-457d-9999-ba848321b036