around to it some time. If you have any good ideas, please let me know.
* login/sulogin/passwd/getty/etc are part of tinylogin, and so are not
- needed or wanted in busybox (or else I'd have to link in libcrypt).
-
-* Networking apps are probably going to be split out some time soon into a
- separate package (named perhaps tiny-netkit?). This currently includes
- hostid, hostname, mnc, and ping.
-
-* init's waitfor() calls wait() which can catch and ignore the wrong pid
- exiting. That other process is then not restarted.
-
+ needed or wanted in busybox (or else I'd have to link to libcrypt).
+* We _were_ going to split networking apps into a new package called
+ netkit-tiny. Per discussions on the mailing list, this isn't going
+ to happen. False alarm. Sorry about the confusion.
-Erik
-----------
-* Allow tar to create archives with sockets, devices, and other special files
-* Make insmod actually work
-* dnsdomainname
-* traceroute/nslookup/netstat
-* rdate
+Possible apps to include some time:
+
* hwclock
-* killall
* stty
-* tr
-* expr (maybe?) (ash builtin?)
+* group/commonize strings, remove dups (for i18n, l10n)
+-----------------------
+The Busybox lash shell needs to be taught Bourne shell grammer. This
+is planned for the next release of Busybox. Look out ash, we are coming
+for you...
+-----------------------
-Some known bugs, todo items, etc...
+Running the following:
------------------------
+ rm -f busybox && make LDFLAGS+=-nostdlib 2>&1 | \
+ sed -ne 's/.*undefined reference to `\(.*\)..*/\1/gp' | sort | uniq
+reveals the list of all external (i.e. libc) things that BusyBox depends on.
+It would be a very nice thing to reduce this list to an absolute minimum, to
+reduce the footprint of busybox, especially when staticly linking with
+libraries such as uClibc.
-[andersen@slag busybox]$ ./busybox du /bin
-6213 /bin
-[andersen@slag busybox]$ du /bin
-2971 /bin
-[andersen@slag busybox]$ du --block-size=512 /bin
-5943 /bin
+-----------------------
+
+Currently, busybox bypasses libc NSS. Some folks might want that,
+so perhaps adding in the option to choose whether to go to libc for
+things like getpwnam() or whether to use the busybox version might
+be nice.
-----------------------
--rw-r--r-- 1000/1000 4398 2000-01-06 21:55 uniq.c
--rw-r--r-- 1000/1000 1568 1999-10-20 18:08 update.c
--rw-r----- 0/1000 1168 2000-01-29 21:03 update.o
--rw-r--r-- 1000/1000 22820 2000-01-05 11:36 utility.c
--rw-r----- 0/1000 7372 2000-01-29 21:03 utility.o
-tar: Skipping to next file header
-tar: Skipping to next file header
-tar: Archive - EOF not on block boundary
-tar: Error is not recoverable: exiting now
+Most wanted list:
+
+ [andersen@slag busybox]$ grep -l getgroups *.[ch]
+ test.c
+Policy violation. getgroups uses libc nss, which is unlikely
+to be present in an embedded system.
-#1 You are storing by id instead of name like normal tar. Did you realize this?
-(or am I missing some compile option? )ctar did not do this, and I don't think
-it's a good idea for LRP.
+-----------------------
+
+Compile with debugging on, run 'nm --size-sort ./busybox'
+and then start with the biggest things and make them smaller...
-#2
-ctar did not produce the EOF error like your tar does. I believe you need to
-pad the end of the archive with at least 2 tarsized (512byte) blocks. (I
-think???)
+-----------------------
-#3
-There is no exclude file(s) option to tar. LRP's packaging system can not
-function without this. Will you have the time to add this soon?
+ du.c probably ought to have an -x switch like GNU du does...
+------------------------------------------------------------------