(hide-ifdef-env, hif-outside-read-only):
[bpt/emacs.git] / etc / tasks.texi
... / ...
CommitLineData
1\input texinfo @c -*-texinfo-*-
2@c %**start of header
3@setfilename tasks.info
4@settitle GNU Task List
5@c This date is automagically updated when you save this file:
6@set lastupdate September 22, 1998
7@c %**end of header
8
9@setchapternewpage off
10
11@titlepage
12@title GNU Task List
13@author Free Software Foundation
14@author last updated @value{lastupdate}
15@end titlepage
16
17@ifinfo
18@node Top, Intro, (dir), (dir)
19@top GNU Task List
20
21This file is updated automatically from @file{tasks.texi}, which was
22last updated on @value{lastupdate}.
23@end ifinfo
24
25@menu
26* Intro::
27* Highest Priority::
28* Documentation::
29* Unix-Related Projects::
30* Kernel Projects::
31* Extensions::
32* X Windows Projects::
33* Encryption Projects::
34* Other Projects::
35* Compilers::
36* Games and Recreations::
37@end menu
38
39@node Intro
40@chapter About the GNU Task List
41
42If you did not obtain this file directly from the GNU project and
43recently, please check for a newer version. You can ftp the task list
44from any GNU FTP host in directory @file{/pub/gnu/tasks/}. The task
45list is available there in several different formats: @file{tasks.text},
46@file{tasks.texi}, @file{tasks.info}, and @file{tasks.dvi}. The GNU
47HURD task list is also there in file @file{tasks.hurd}.
48@c to fix an overfill, join the paragraphs -len
49The task list is also available on the GNU World Wide Web server:
50@uref{http://www.gnu.org/prep/tasks_toc.html}.
51
52If you start working steadily on a project, please let @email{gvc@@gnu.org}
53know. We might have information that could help you; we'd also like to
54send you the GNU coding standards.
55
56Because of the natural tendency for most volunteers to write programming
57tools or programming languages, we have a comparative shortage of
58applications useful for non-programmer users. Therefore, we ask you to
59consider writing such a program.
60
61Typically, a new program that does a completely new job advances
62the GNU project, and the free software community, more than an
63improvement to an existing program.
64
65Typically, new features or new programs advance the free software
66community more, in the long run, than porting existing programs. One
67reason is that portable new features and programs benefit people on many
68platforms, not just one. At the same time, there tend to be many
69volunteers for porting---so your help will be more valuable in other
70areas, where volunteers are more scarce.
71
72Typically, it is more useful to extend a program in functionality than
73to improve performance. Users who use the new functionality will
74appreciate it very much, if they use it; but even when they benefit from
75a performance improvement, they may not consider it very important.
76
77@node Highest Priority
78@chapter Highest Priority
79
80This task list mentions a large number of tasks that would be more or
81less useful. With luck, at least one of them will inspire you to start
82writing. It's better for you to work on any task that inspires you than
83not write free software at all.
84
85But if you would like to work on what we need most, here is a list of
86high priority projects.
87
88@itemize @bullet
89@item
90If you are good at writing documentation, please do that.
91
92@item
93If you are very good at C programming and interested in kernels, you can
94help develop the GNU HURD, the kernel for the GNU system. Please have a
95look at @uref{http://www.gnu.org/software/hurd/hurd.html}, and
96then get a copy of the latest HURD task list from:
97
98@itemize @bullet
99
100@item
101@uref{http://www.gnu.org/prep/tasks.hurd.html}, via the World Wide
102Web.
103
104@item
105@uref{ftp://ftp.gnu.org/pub/gnu/tasks/tasks.hurd}, via anonymous FTP.
106
107@item
108@email{gnu@@gnu.org} via e-mail.
109
110@end itemize
111
112@item
113If you are a Scheme fan, you can help develop Guile. Please have a look
114at the URL @uref{http://www.gnu.org/software/guile/guile.html}
115and then contact the Guile developers at @email{guile@@gnu.org}.
116
117@item
118Help develop XmHTML.
119
120@item
121Help develop software to emulate Windows NT on top of GNU systems.
122For example, you could help work on Willows Twin.
123
124@item
125Implement the Kermit data transfer protocol. (See below.)
126
127@ignore This is being done (Harmony)
128@item
129Develop a free compatible replacement for Qt, a GUI toolkit library. Qt
130is not free software, because users are prohibited from distributing
131modified versions. Thus, Qt cannot be included in a free operating
132system (adding it would make the system as a whole non-free).
133
134But some developers are writing free applications that use Qt and cannot
135run without it. These programs, although free software, are useless for
136free operating systems because there is no way to make them run.
137
138This is leading to a serious problem, and a free replacement for Qt is
139the only solution. Hence the high degree of urgency of this project.
140@end ignore
141
142@item
143Develop a free replacement for a semi-free program such as Xv or POV.
144These semi-free programs are less restricted than typical proprietary
145programs, but too restricted to be part of any free operating system.
146
147@item
148Develop a substitute, which runs on GNU systems, for some very popular
149or very important application that many non-programmers use on Windows,
150and which has no comparable free equivalent now.
151@end itemize
152
153@node Documentation
154@chapter Documentation
155
156We very urgently need documentation for many existing parts of the
157system.
158
159Note that there are proprietary manuals for many of these topics, but
160proprietary manuals do not count, because we are not free to copy and
161modify them along with the software they document. For this reason,
162we do not recommend any non-free manuals.
163
164@itemize @bullet
165@item
166A C reference manual. (RMS made a try at one, which you could start
167with).
168
169@item
170Reference manuals for C++, Pascal, Fortran 77, and Java.
171
172@item
173A manual for Ghostscript.
174
175@item
176A manual for TCSH.
177
178@item
179A good free reference manual for Perl. The free Perl on-line reference
180documentation is good, for what it is--a list of functions and a
181description of each--but that is not the same as a reference manual.
182(Compare, for example, the Emacs Lisp Reference Manual with the
183collection of documentation strings of Emacs Lisp functions.)
184
185@item
186A good free Perl language tutorial introduction. The existing Perl
187introductions are published with restrictions on copying and
188modification, so that they cannot be part of a GNU system.
189
190@item
191A manual for PIC (the graphics formatting language).
192
193@item
194A book on how GCC works and why various machine descriptions
195are written as they are.
196
197@item
198A manual for programming X-window applications.
199
200@item
201Manuals for various X window managers.
202
203@item
204Reference cards for those manuals that don't have them: C
205Compiler, Make, Texinfo, Termcap, and maybe the C Library.
206
207@item
208Many utilities need documentation, including @code{grep} and others.
209@end itemize
210
211@node Unix-Related Projects
212@chapter Unix-Related Projects
213
214@itemize @bullet
215@ignore
216@item
217Modify the GNU @code{dc} program to use the math routines of GNU
218@code{bc}.
219@end ignore
220
221@item
222A @code{grap} preprocessor program for @code{troff}.
223
224@item
225Less urgent: make a replacement for the ``writer's workbench'' program
226@code{style}, or something to do the same kind of job. Compatibility
227with Unix is not especially important for this programs.
228@end itemize
229
230@node Kernel Projects
231@chapter Kernel-Related Projects
232
233@itemize @bullet
234@item
235An over-the-ethernet debugger stub that will allow the kernel to be
236debugged from GDB running on another machine.
237
238This stub needs its own self-contained implementation of all protocols
239to be used, since the GNU system will use user processes to implement
240all but the lowest levels, and the stub won't be able to use those
241processes. If a simple self-contained implementation of IP and TCP is
242impractical, it might be necessary to design a new, simple protocol
243based directly on ethernet. It's not crucial to support high speed or
244communicating across gateways.
245
246It might be possible to use the Mach ethernet driver code, but it would
247need some changes.
248
249@item
250A shared memory X11 server to run under MACH is very desirable. The
251machine specific parts should be kept well separated.
252
253@item
254An implementation of CIFS, the ``Common Internet File System,'' for the
255HURD. This protocol is an offshoot of SMB.
256@end itemize
257
258@node Extensions
259@chapter Extensions to Existing GNU Software
260
261@itemize @bullet
262@item
263Enhance GCC. See files @file{PROJECTS} and @file{PROBLEMS} in the GCC
264distribution.
265
266@item
267Interface GDB to Guile, so that users can write debugging commands in
268Scheme. This would also make it possible to write, in Scheme, a
269graphical interface that uses GTK and is tightly integrated into GDB.
270
271@item
272Extend Octave to support programs that were written
273to run on Khoros.
274
275@item
276Rewrite Automake in Scheme, so it can run in Guile. Right now it is
277written in Perl. There are also other programs, not terribly long,
278which we would also like to have rewritten in Scheme.
279
280@item
281Finish the partially-implemented C interpreter project.
282
283@item
284Help with the development of GNUstep, a GNU implementation of the
285OpenStep specification.
286
287@item
288Add features to GNU Make to record the precise rule with which each file
289was last recompiled; then recompile any file if its rule in the makefile
290has changed.
291
292@item
293Add a few features to GNU @code{diff}, such as handling large input
294files without reading entire files into core.
295
296@item
297An @code{nroff} macro package to simplify @code{texi2roff}.
298
299@item
300An implementation of XML (see @uref{http://www.w3.org/XML/}).
301
302@item
303A queueing system for the mailer Smail that groups pending work by
304destination rather than by original message. This makes it possible
305to schedule retries coherently for each destination. Talk to
306@email{tron@@veritas.com} about this.
307
308Smail also needs a new chief maintainer.
309
310@item
311Enhanced cross-reference browsing tools. (We now have something at
312about the level of @code{cxref}.) We also could use something like
313@code{ctrace}. (Some people are now working on this project.)
314@end itemize
315
316@node X Windows Projects
317@chapter X Windows Projects
318
319@itemize @bullet
320@item
321An emulator for Macintosh graphics calls on top of X Windows.
322
323@item
324A music playing and editing system. This should work with LilyPond, a
325GNU program for music typesetting.
326
327@item
328An ephemeris program to replace xephem (which is, alas, too restricted
329to qualify as free software).
330
331@item
332A program to edit dance notation (such as labanotation) and display
333dancers moving on the screen.
334
335@item
336Make sure the Vibrant toolkit works with LessTif instead of Motif.
337
338@item
339A program to display and edit Hypercard stacks.
340
341@item
342A program for graphic morphing of scanned photographs.
343@end itemize
344
345@node Encryption Projects
346@chapter Encryption Projects
347
348These projects need to be written outside the US by people who are not
349US citizens, to avoid problems with US export control law.
350
351@itemize @bullet
352@item
353A free library for public-key encryption.
354
355This library should use the Diffie-Helman algorithm for public key
356encryption, not the RSA algorithm, because the Diffie-Helman patent in
357the US expired in 1997. This library can probably be developed from
358the code for the GNU Privacy Guard (now in development).
359
360@item
361A free secure telnet program more or less like ssh/sshd. Since this
362requires a public key encryption algorithm, it should be based
363on the library above.
364
365This program should follow the draft standard for ssh. As always, it
366cannot implement the RSA algorithm, but must instead support the
367alternatives that will be patent-free in late 1997. It cannot support
368IDEA, but can use triple-DES and/or Blowfish or other non-patented
369alternatives.
370
371@item
372Free software for doing secure commercial transactions on the web.
373This too needs public key encryption.
374@end itemize
375
376A free replacement for PGP is no longer listed here because the GNU
377Privacy Guard will do that job.
378
379@node Other Projects
380@chapter Other Projects
381
382If you think of others that should be added, please
383send them to @email{gnu@@gnu.org}.
384
385@itemize @bullet
386
387@item
388A program to reformat HTML source to make it easier to read as HTML.
389
390@item
391A simple PC BIOS. On most new PCs, the BIOS is stored in writable
392memory (misleadingly known as ``flash ROM''). In order to have a wholly
393free system on these PCs, we need a free BIOS.
394
395This task is made simpler by the fact that this BIOS need only support
396enough features to enable a boot-loader such as LILO or GRUB to finish
397loading the kernel. Neither Linux nor Mach actually uses the BIOS once
398it starts up. Also, it is not absolutely necessary to do all the many
399diagnostics that an ordinary BIOS does (though it would be useful to do
400some of them). However, there may be a need to configure certain data
401in the computer in a way that is specific to each model of computer.
402
403@item
404A free program that can transfer files on a serial line
405using the same protocol that Kermit uses.
406
407@item
408An imitation of Page Maker or Ventura Publisher.
409
410@item
411An imitation of @code{dbase2} or @code{dbase3} (How dbased!)
412
413@item
414A general ledger program, including support for accounts payable,
415account receivables, payroll, inventory control, order processing, etc.
416
417@item
418A teleconferencing program which does the job of CU-SeeMe (which is,
419alas, not free software).
420
421@item
422A free replacement for Glimpse, which is not free software.
423
424@item
425A program to typeset C code for printing, to make it easier to read on
426paper. For ideas on what to do, see the book,
427
428@display
429Human Factors and Typography for More Readable Programs,
430Ronald M. Baecker and Aaron Marcus,
431Addison-Wesley, ISBN 0-201-10745-7
432@end display
433
434But you don't have to do exactly what they propose.
435
436@ignore
437@c This is now being worked on -- rms, 22 June 1998
438@item
439A program to convert Microsoft Word documents to text/enriched, TeX,
440LaTeX, Texinfo, or some other format that free software can edit.
441@end ignore
442
443@ignore
444@c People are helping the developer of siff release it as free software.
445
446@item
447A free replacement for siff (sometimes called sif). This would be a
448program to find similar files in a large file system, ``similar''
449meaning that the files contain a significant number of common substrings
450that are of a certain size or greater. You can find some information
451about siff (which is, unfortunately, not free software) at
452@uref{ftp://ftp.cs.arizona.edu/reports/1993/TR93-33.ps.Z}.
453@end ignore
454
455@ignore
456@c This is being developed -- rms, 3 May 1998
457@item
458A free replacement for the semi-free Qt library.
459@end ignore
460
461@item
462High-quality music compression software.
463(Talk with @email{phr@@netcom.com} for relevant suggestions.)
464
465@item
466A program to play sound distributed in ``Real Audio'' format.
467
468@item
469A program to generate ``Real Audio'' format from audio input.
470
471@item
472Programs to handle audio in RTSP format.
473
474@ignore @c Software patents have made this domain off limits to free software.
475@item
476An MPEG III audio encoder/decoder (but it is necessary to check, first,
477whether patents make this impossible).
478@end ignore
479
480@item
481Speech-generation programs (there is a program from Brown U that you
482could improve).
483
484@item
485Speech-recognition programs (single-speaker, disconnected speech is sufficient).
486
487@ignore Being done
488@item
489A program to display text word by word, always showing just one word at
490a time. This method permits much faster reading than ordinary text
491display. If you want to work on this, contact @email{stutz@@dsl.org} to
492learn more.
493@end ignore
494
495@item
496More scientific mathematical subroutines.
497(A clone of SPSS is being written already.)
498
499@item
500Statistical tools.
501
502@item
503A scientific data collection and processing tool,
504perhaps something like Scientific Workbench and/or Khoros,
505
506@item
507Software to replace card catalogues in libraries.
508
509@item
510A project-scheduling package that accepts a list of project sub-tasks
511with their interdependencies, and generates Gantt charts and Pert charts
512and all the other standard project progress reports.
513
514@item
515Grammar and style checking programs.
516
517@item
518A translator from Scheme to C.
519
520@item
521A fast emulator for the i386 which works by translating
522machine instructions into the machine language of the host machine.
523(Support for emulation of other machines would enhance the program
524but might make it much more difficult.)
525
526@item
527A map display or geographic information system.
528
529@item
530Optical character recognition programs; especially if suitable for
531scanning documents with multiple fonts and capturing font info as well
532as character codes. Work is being done on this, but more help is needed.
533
534@item
535A program to scan a line drawing and convert it to Postscript.
536
537@item
538A program to recognize handwriting.
539
540@item
541A pen based interface.
542
543@item
544CAD software, such as a vague imitation of Autocad.
545
546@item
547A program to receive data from a serial-line tap to facilitate the
548reverse-engineering of communication protocols.
549@end itemize
550
551@node Compilers
552@chapter Compilers for Other Batch Languages
553
554Volunteers are needed to write parsers/front ends for languages such as
555Algol 60, Algol 68, PL/I, Cobol, Fortran 90, or whatever, to be
556used with the code generation phases of the GNU C compiler.
557
558@c Fortran status is here so gnu@gnu.org and the volunteer coordinators
559@c don't have to answer the question -len
560You can get the status of the Fortran front end with this command:
561
562@example
563finger -l fortran@@gnu.org
564@end example
565
566@node Games and Recreations
567@chapter Games and Recreations
568
569Video-oriented games that work with the X window system.
570
571@itemize @bullet
572@item
573Empire (there is a free version but it needs upgrading)
574
575@item
576An ``empire builder'' system that makes it easy to write various kinds of
577simulation games.
578
579@item
580Improve GnuGo, which is not yet very sophisticated.
581
582@item
583A Hierarchical Task Network package which can be used
584to program play the computer's side in various strategic games.
585
586@item
587Write imitations of some popular video games:
588
589@itemize -
590@item
591Space war, Asteroids, Pong, Columns.
592@item
593Defending cities from missiles.
594@item
595Plane shoots at lots of other planes, tanks, etc.
596@item
597Wizard fights fanciful monsters.
598@item
599A golf game.
600@ignore Being done by jhall1@isd.net
601@item
602Program a robot by sticking building blocks together,
603then watch it explore a world.
604@end ignore
605@item
606Biomorph evolution (as in Scientific American and @cite{The Blind
607Watchmaker}).
608@item
609A program to display effects of moving at relativistic speeds.
610@end itemize
611@end itemize
612
613We do not need @code{rogue}, as we have @code{hack}.
614
615@contents
616
617@bye
618Local variables:
619update-date-leading-regexp: "@c This date is automagically updated when you save this file:\n@set lastupdate "
620update-date-trailing-regexp: ""
621eval: (load "/gd/gnuorg/update-date.el")
622eval: (add-hook 'write-file-hooks 'update-date)
623End: