Open jobs for finishing GNU libc:
---------------------------------
-Status: July 1996
+Status: October 2004
If you have time and talent to take over any of the jobs below please
-contact <bug-glibc@prep.ai.mit.edu>
+contact <bug-glibc@gnu.org>.
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
\f
[ 1] Port to new platforms or test current version on formerly supported
platforms.
+**** See http://www.gnu.org/software/libc/porting.html for more details.
+
[ 2] Test compliance with standards. If you have access to recent
standards (IEEE, ISO, ANSI, X/Open, ...) and/or test suites you
standards if they do not contradict each other.
-[ 3] Write translations for the GNU libc message for the so far
+[ 3] The IMHO opinion most important task is to write a more complete
+ test suite. We cannot get too many people working on this. It is
+ not difficult to write a test, find a definition of the function
+ which I normally can provide, if necessary, and start writing tests
+ to test for compliance. Beside this, take a look at the sources
+ and write tests which in total test as many paths of execution as
+ possible.
+
+
+[ 4] Write translations for the GNU libc message for the so far
unsupported languages. GNU libc is fully internationalized and
users can immediately benefit from this.
Take a look at the matrix in
- ftp://prep.ai.mit.edu/pub/gnu/ABOUT-NLS
- for the current status (of course better use a mirror of prep).
-
-
-[ 4] Write wordexp() function; this is described in POSIX.2, The
- header <wordexp.h> already exists.
-
- Implementation idea: use some functions from bash.
-
+ ftp://ftp.gnu.org/pub/gnu/ABOUT-NLS
+ for the current status (of course better use a mirror of ftp.gnu.org).
-[ 5] Write reentrant versions of crypt() et.al.
- Implementation idea: Define in <crypt.h>
-
- struct crypt_data
- {
- <... all the needed data ...>
- };
-
- and define additional functions
-
- char *crypt_r (__const char *__key, __const char *__salt,
- struct crypt_data *__data);
-
- void setkey_r (__const char *__key, struct crypt_data *__data);
-
- void encrypt_r (char *__block, int __edflag,
- struct crypt_data *__data);
+[ 8] If you enjoy assembler programming (as I do --drepper :-) you might
+ be interested in writing optimized versions for some functions.
+ Especially the string handling functions can be optimized a lot.
- If possible the non-reentrant functions should use the reentrant
- ones.
+ Take a look at
- Because of the US export restrictions it might be a good idea if
- some non-american person does this job.
+ Faster String Functions
+ Henry Spencer, University of Toronto
+ Usenix Winter '92, pp. 419--428
+ or just ask. Currently mostly i?86 and Alpha optimized versions
+ exist. Please ask before working on this to avoid duplicate
+ work.
-[ 6] Write `long double' versions of the math functions. This should be
- done in collaboration with the NetBSD and FreeBSD people.
- The libm is in fact fdlibm (not the same as in Linux libc).
+[11] Write access function for netmasks, bootparams, and automount
+ databases for nss_files, nss_nis, and nss_nisplus modules.
+ The functions should be embedded in the nss scheme. This is not
+ hard and not all services must be supported at once.
-**** Partly done.
+[15] Cleaning up the header files. Ideally, each header style should
+ follow the "good examples". Each variable and function should have
+ a short description of the function and its parameters. The prototypes
+ should always contain variable names which can help to identify their
+ meaning; better than
-[ 7] If you enjoy assembler programming (as I do --drepper :-) you might
- be interested in writing optimized versions for some functions.
- Especially the string handling functions can be optimized a lot.
+ int foo (int, int, int, int);
- Take a look at
+ Blargh!
- Faster String Functions
- Henry Spencer, University of Toronto
- Usenix Winter '92, pp. 419--428
+*** The conformtest.pl tool helps cleaning the namespace. As far as
+ known the prototypes all contain parameter names. But maybe some
+ comments can be improved.
- or just ask. Currently mostly i?86 optimized versions exist.
- Alpha versions are on their way, so please ask before working
- on this.
+[18] Based on the sprof program we need tools to analyze the output. The
+ result should be a link map which specifies in which order the .o
+ files are placed in the shared object. This should help to improve
+ code locality and result in a smaller footprint (in code and data
+ memory) since less pages are only used in small parts.
-[ 8] Write nftw() function. Perhaps it might be good to reimplement the
- ftw() function as well to share most of the code.
-**** Almost done!
+[19] A user-level STREAMS implementation should be available if the
+ kernel does not provide the support.
+*** This is a much lower priority job now that STREAMS are optional in
+ XPG.
-[ 9] Write AVL-tree based tsearch() et.al. functions. Currently only
- a very simple algorithm is used.
- There is a public domain version but using this would cause problems
- with the assignment.
-[10] Extend regex and/or rx to work with wide characters.
+[20] More conversion modules for iconv(3). Existing modules should be
+ extended to do things like transliteration if this is wanted.
+ For often used conversion a direct conversion function should be
+ available.
-[11] Add mmap() support to malloc().
- Doug Lea's malloc implementation might give some ideas. Perhaps
- switching completly to his implementation is an option if it
- a) can work without mmap() support (not all system GNU libc
- is running on have mmap)
- b) is without mmap support at least as fast as the current
- implementation
- c) will be extended with the current hooks and additional functions
+[23] The `strptime' function needs to be completed. This includes among
+ other things that it must get teached about timezones. The solution
+ envisioned is to extract the timezones from the ADO timezone
+ specifications. Special care must be given names which are used
+ multiple times. Here the precedence should (probably) be according
+ to the geograhical distance. E.g., the timezone EST should be
+ treated as the `Eastern Australia Time' instead of the US `Eastern
+ Standard Time' if the current TZ variable is set to, say,
+ Australia/Canberra or if the current locale is en_AU.
- Please contact bug-glibc@prep.ai.mit.edu before starting to avoid
- duplicated work.
-[12] Write access function for netmasks, bootparams, netgroup, publickey,
- automount, aliases databases for nss_files and nss_db module.
- The functions should be embedded in the nss scheme. This is not
- hard and not all services must be supported at once.
+[27] ...deleted...