Extract usage information into a separate file.
diff --git a/Makefile b/Makefile
index 232a17d..bcaac87 100644
--- a/Makefile
+++ b/Makefile
@@ -80,7 +80,7 @@
     PREFIX = `pwd`/_install
 endif
 
-OBJECTS   = $(shell ./busybox.sh) busybox.o messages.o utility.o
+OBJECTS   = $(shell ./busybox.sh) busybox.o messages.o usage.o utility.o
 CFLAGS    += -DBB_VER='"$(VERSION)"'
 CFLAGS    += -DBB_BT='"$(BUILDTIME)"'
 ifdef BB_INIT_SCRIPT
diff --git a/applets/usage.c b/applets/usage.c
new file mode 100644
index 0000000..d5a34ec
--- /dev/null
+++ b/applets/usage.c
@@ -0,0 +1,1204 @@
+#include "internal.h"
+
+#if defined BB_AR
+const char ar_usage[] =
+	"ar [optxvV] archive [filenames] \n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nExtract or list files from an ar archive.\n\n"
+	"Options:\n"
+	"\to\t\tpreserve original dates\n"
+	"\tp\t\textract to stdout\n"
+	"\tt\t\tlist\n"
+	"\tx\t\textract\n"
+	"\tv\t\tverbosely list files processed\n"
+#endif
+	;
+#endif
+
+#if defined BB_BASENAME
+const char basename_usage[] =
+	"basename FILE [SUFFIX]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStrips directory path and suffixes from FILE.\n"
+	"If specified, also removes any trailing SUFFIX.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CAT
+const char cat_usage[] =
+	"cat [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nConcatenates FILE(s) and prints them to stdout.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHMOD_CHOWN_CHGRP
+const char chgrp_usage[] =
+	"chgrp [OPTION]... GROUP FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChange the group membership of each FILE to GROUP.\n"
+	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHMOD_CHOWN_CHGRP
+const char chmod_usage[] =
+	"chmod [-R] MODE[,MODE]... FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nEach MODE is one or more of the letters ugoa, one of the symbols +-= and\n"
+	"one or more of the letters rwxst.\n\n"
+	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHMOD_CHOWN_CHGRP
+const char chown_usage[] =
+	"chown [OPTION]...  OWNER[<.|:>[GROUP] FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChange the owner and/or group of each FILE to OWNER and/or GROUP.\n"
+	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHROOT
+const char chroot_usage[] =
+	"chroot NEWROOT [COMMAND...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRun COMMAND with root directory set to NEWROOT.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHVT
+const char chvt_usage[] =
+	"chvt N\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChanges the foreground virtual terminal to /dev/ttyN\n"
+#endif
+	;
+#endif
+
+#if defined BB_CP_MV
+const char cp_usage[] =
+	"cp [OPTION]... SOURCE DEST\n"
+	"   or: cp [OPTION]... SOURCE... DIRECTORY\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCopies SOURCE to DEST, or multiple SOURCE(s) to DIRECTORY.\n"
+	"\n"
+	"\t-a\tSame as -dpR\n"
+	"\t-d\tPreserves links\n"
+	"\t-p\tPreserves file attributes if possible\n"
+	"\t-f\tforce (implied; ignored) - always set\n"
+	"\t-R\tCopies directories recursively\n"
+#endif
+	;
+#endif
+
+#if defined BB_CUT
+const char cut_usage[] =
+	"cut [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints selected fields from each input FILE to standard output.\n\n"
+	"Options:\n"
+	"\t-b LIST\tOutput only bytes from LIST\n"
+	"\t-c LIST\tOutput only characters from LIST\n"
+	"\t-d CHAR\tUse CHAR instead of tab as the field delimiter\n"
+	"\t-s\tOnly output Lines if the include DELIM\n"
+	"\t-f N\tPrint only these fields\n"
+	"\t-n\tIgnored\n"
+#endif
+	;
+#endif
+
+#if defined BB_DATE
+const char date_usage[] =
+	"date [OPTION]... [+FORMAT]\n"
+	"  or:  date [OPTION] [MMDDhhmm[[CC]YY][.ss]]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDisplays the current time in the given FORMAT, or sets the system date.\n"
+	"\nOptions:\n\t-R\tOutputs RFC-822 compliant date string\n"
+	"\t-s\tSets time described by STRING\n"
+	"\t-u\tPrints or sets Coordinated Universal Time\n"
+#endif
+	;
+#endif
+
+#if defined BB_DC
+const char dc_usage[] =
+	"dc expression ...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nThis is a Tiny RPN calculator that understands the\n"
+	"following operations: +, -, /, *, and, or, not, eor.\n"
+	"i.e. 'dc 2 2 add' -> 4, and 'dc 8 8 \\* 2 2 + /' -> 16\n"
+#endif
+	;
+#endif
+
+#if defined BB_DD
+const char dd_usage[] =
+	"dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCopy a file, converting and formatting according to options\n\n"
+	"\tif=FILE\tread from FILE instead of stdin\n"
+	"\tof=FILE\twrite to FILE instead of stdout\n"
+	"\tbs=N\tread and write N bytes at a time\n"
+	"\tcount=N\tcopy only N input blocks\n"
+	"\tskip=N\tskip N input blocks\n"
+	"\tseek=N\tskip N output blocks\n"
+	"\n"
+	"Numbers may be suffixed by w (x2), k (x1024), b (x512), or M (x1024^2)\n"
+#endif
+	;
+#endif
+
+#if defined BB_DEALLOCVT
+const char deallocvt_usage[] =
+	"deallocvt N\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	 "\nDeallocate unused virtual terminal /dev/ttyN\n"
+#endif
+	 ;
+#endif
+
+#if defined BB_DF
+const char df_usage[] =
+	"df [filesystem ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint the filesystem space used and space available.\n"
+#endif
+	;
+#endif
+
+#if defined BB_DIRNAME
+const char dirname_usage[] =
+	"dirname [FILENAME ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStrips non-directory suffix from FILENAME\n"
+#endif
+	;
+#endif
+
+#if defined BB_DMESG
+const char dmesg_usage[] =
+	"dmesg [-c] [-n LEVEL] [-s SIZE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints or controls the kernel ring buffer\n\n"
+	"Options:\n"
+	"\t-c\t\tClears the ring buffer's contents after printing\n"
+	"\t-n LEVEL\tSets console logging level\n"
+	"\t-s SIZE\t\tUse a buffer of size SIZE\n"
+#endif
+	;
+#endif
+
+#if defined BB_DU
+const char du_usage[] =
+	"du [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSummarizes disk space used for each FILE and/or directory.\n"
+	"Disk space is printed in units of 1024 bytes.\n\n"
+	"Options:\n"
+	"\t-l\tcount sizes many times if hard linked\n"
+	"\t-s\tdisplay only a total for each argument\n"
+#endif
+	;
+#endif
+
+#if defined BB_DUMPKMAP
+const char dumpkmap_usage[] =
+	"dumpkmap\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints out a binary keyboard translation table to standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_DUTMP
+const char dutmp_usage[] =
+	"dutmp [FILE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDump utmp file format (pipe delimited) from FILE\n"
+	"or stdin to stdout.  (i.e. 'dutmp /var/run/utmp')\n"
+#endif
+	;
+#endif
+
+#if defined BB_ECHO
+const char echo_usage[] =
+	"echo [-neE] [ARG ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints the specified ARGs to stdout\n\n"
+	"Options:\n"
+	"\t-n\tsuppress trailing newline\n"
+	"\t-e\tinterpret backslash-escaped characters (i.e. \\t=tab etc)\n"
+	"\t-E\tdisable interpretation of backslash-escaped characters\n"
+#endif
+	;
+#endif
+
+#if defined BB_FDFLUSH
+const char fdflush_usage[] =
+	"fdflush DEVICE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nForces floppy disk drive to detect disk change\n"
+#endif
+	;
+#endif
+
+#if defined BB_FIND
+const char find_usage[] =
+	"find [PATH...] [EXPRESSION]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSearch for files in a directory hierarchy.  The default PATH is\n"
+	"the current directory; default EXPRESSION is '-print'\n\n"
+	"\nEXPRESSION may consist of:\n"
+	"\t-follow\t\tDereference symbolic links.\n"
+	"\t-name PATTERN\tFile name (leading directories removed) matches PATTERN.\n"
+	"\t-print\t\tprint the full file name followed by a newline to stdout.\n"
+#endif
+	;
+#endif
+
+#if defined BB_FREE
+const char free_usage[] =
+	"free\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDisplays the amount of free and used system memory\n"
+#endif
+	;
+#endif
+
+#if defined BB_FREERAMDISK
+const char freeramdisk_usage[] =
+	"freeramdisk DEVICE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nFrees all memory used by the specified ramdisk.\n"
+#endif
+	;
+#endif
+
+#if defined BB_FSCK_MINIX
+const char fsck_minix_usage[] =
+	"Usage: fsck.minix [-larvsmf] /dev/name\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPerforms a consistency check for MINIX filesystems.\n\n"
+	"Options:\n"
+	"\t-l\tLists all filenames\n"
+	"\t-r\tPerform interactive repairs\n"
+	"\t-a\tPerform automatic repairs\n"
+	"\t-v\tverbose\n"
+	"\t-s\tOutputs super-block information\n"
+	"\t-m\tActivates MINIX-like \"mode not cleared\" warnings\n"
+	"\t-f\tForce file system check.\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_GREP
+const char grep_usage[] =
+	"grep [-ihHnqvs] pattern [files...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSearch for PATTERN in each FILE or standard input.\n\n"
+	"Options:\n"
+	"\t-H\tprefix output lines with filename where match was found\n"
+	"\t-h\tsuppress the prefixing filename on output\n"
+	"\t-i\tignore case distinctions\n"
+	"\t-n\tprint line number with output lines\n"
+	"\t-q\tbe quiet. Returns 0 if result was found, 1 otherwise\n"
+	"\t-v\tselect non-matching lines\n"
+	"\t-s\tsuppress file open/read error messages\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_GUNZIP
+const char gunzip_usage[] =
+	"gunzip [OPTION]... FILE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUncompress FILE (or standard input if FILE is '-').\n\n"
+	"Options:\n"
+	"\t-c\tWrite output to standard output\n"
+	"\t-t\tTest compressed file integrity\n"
+#endif
+	;
+#endif
+
+#if defined BB_GZIP
+const char gzip_usage[] =
+	"gzip [OPTION]... FILE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCompress FILE with maximum compression.\n"
+	"When FILE is '-', reads standard input.  Implies -c.\n\n"
+	"Options:\n"
+	"\t-c\tWrite output to standard output instead of FILE.gz\n"
+#endif
+	;
+#endif
+
+#if defined BB_HEAD
+const char head_usage[] =
+	"head [OPTION] [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint first 10 lines of each FILE to standard output.\n"
+	"With more than one FILE, precede each with a header giving the\n"
+	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
+
+	"Options:\n" "\t-n NUM\t\tPrint first NUM lines instead of first 10\n"
+#endif
+	;
+#endif
+
+#if defined BB_HOSTNAME
+const char hostname_usage[] =
+	"hostname [OPTION] {hostname | -F file}\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nGet or set the hostname or DNS domain name. If a hostname is given\n"
+	"(or a file with the -F parameter), the host name will be set.\n\n"
+	"Options:\n"
+	"\t-s\t\tShort\n"
+
+	"\t-i\t\tAddresses for the hostname\n"
+	"\t-d\t\tDNS domain name\n"
+	"\t-F FILE\t\tUse the contents of FILE to specify the hostname\n"
+#endif
+	;
+#endif
+
+#if defined BB_ID
+const char id_usage[] =
+	"id [OPTIONS]... [USERNAME]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint information for USERNAME or the current user\n\n"
+	"Options:\n"
+	"\t-g\tprints only the group ID\n"
+	"\t-u\tprints only the user ID\n"
+	"\t-r\tprints the real user ID instead of the effective ID (with -ug)\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_INSMOD
+const char insmod_usage[] =
+	"insmod [OPTION]... MODULE [symbol=value]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLoads the specified kernel modules into the kernel.\n\n"
+	"Options:\n"
+	"\t-f\tForce module to load into the wrong kernel version.\n"
+	"\t-k\tMake module autoclean-able.\n"
+	"\t-v\tverbose output\n" "\t-x\tdo not export externs\n"
+#endif
+	;
+#endif
+
+#if defined BB_KILL
+const char kill_usage[] =
+	"kill [-signal] process-id [process-id ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
+	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_KILLALL
+const char killall_usage[] =
+	"killall [-signal] process-name [process-name ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
+	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_LENGTH
+const char length_usage[] =
+	"length STRING\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints out the length of the specified STRING.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LN
+const char ln_usage[] =
+	"ln [OPTION] TARGET... LINK_NAME|DIRECTORY\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate a link named LINK_NAME or DIRECTORY to the specified TARGET\n"
+	"\nYou may use '--' to indicate that all following arguments are non-options.\n\n"
+	"Options:\n"
+	"\t-s\tmake symbolic links instead of hard links\n"
+
+	"\t-f\tremove existing destination files\n"
+	"\t-n\tno dereference symlinks - treat like normal file\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOADACM
+const char loadacm_usage[] =
+	"loadacm\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLoads an acm from standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOADFONT
+const char loadfont_usage[] =
+	"loadfont\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"Loads a console font from standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOADKMAP
+const char loadkmap_usage[] =
+	"loadkmap\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLoads a binary keyboard translation table from standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOGGER
+const char logger_usage[] =
+	"logger [OPTION]... [MESSAGE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nWrite MESSAGE to the system log.  If MESSAGE is '-', log stdin.\n\n"
+	"Options:\n"
+	"\t-s\tLog to stderr as well as the system log.\n"
+	"\t-t\tLog using the specified tag (defaults to user name).\n"
+
+	"\t-p\tEnter the message with the specified priority.\n"
+	"\t\tThis may be numerical or a ``facility.level'' pair.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOGNAME
+const char logname_usage[] =
+	"logname\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint the name of the current user.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LS
+const char ls_usage[] =
+	"ls [-1a"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"c"
+#endif
+	"d"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"e"
+#endif
+	"ln"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"p"
+#endif
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"u"
+#endif
+	"xAC"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"F"
+#endif
+#ifdef BB_FEATURE_LS_RECURSIVE
+	"R"
+#endif
+	"] [filenames...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nList directory contents\n\n"
+	"Options:\n"
+	"\t-a\tdo not hide entries starting with .\n"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"\t-c\twith -l: show ctime (the time of last\n"
+	"\t\tmodification of file status information)\n"
+#endif
+	"\t-d\tlist directory entries instead of contents\n"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"\t-e\tlist both full date and full time\n"
+#endif
+	"\t-l\tuse a long listing format\n"
+	"\t-n\tlist numeric UIDs and GIDs instead of names\n"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"\t-p\tappend indicator (one of /=@|) to entries\n"
+#endif
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"\t-u\twith -l: show access time (the time of last\n"
+	"\t\taccess of the file)\n"
+#endif
+	"\t-x\tlist entries by lines instead of by columns\n"
+	"\t-A\tdo not list implied . and ..\n"
+	"\t-C\tlist entries by columns\n"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"\t-F\tappend indicator (one of */=@|) to entries\n"
+#endif
+#ifdef BB_FEATURE_LS_RECURSIVE
+	"\t-R\tlist subdirectories recursively\n"
+#endif
+#endif
+	;
+#endif
+
+#if defined BB_MAKEDEVS
+const char makedevs_usage[] =
+	"makedevs NAME TYPE MAJOR MINOR FIRST LAST [s]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreates a range of block or character special files\n\n"
+	"TYPEs include:\n"
+	"\tb:\tMake a block (buffered) device.\n"
+	"\tc or u:\tMake a character (un-buffered) device.\n"
+	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n\n"
+	"FIRST specifies the number appended to NAME to create the first device.\n"
+	"LAST specifies the number of the last item that should be created.\n"
+	"If 's' is the last argument, the base device is created as well.\n\n"
+	"For example:\n"
+	"\tmakedevs /dev/ttyS c 4 66 2 63   ->  ttyS2-ttyS63\n"
+	"\tmakedevs /dev/hda b 3 0 0 8 s    ->  hda,hda1-hda8\n"
+#endif
+	;
+#endif
+
+#if defined BB_MD5SUM
+const char md5sum_usage[] =
+	"md5sum [OPTION] [FILE]...\n"
+	"or:    md5sum [OPTION] -c [FILE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint or check MD5 checksums.\n\n"
+	"Options:\n"
+	"With no FILE, or when FILE is -, read standard input.\n\n"
+	"\t-b\tread files in binary mode\n"
+	"\t-c\tcheck MD5 sums against given list\n"
+	"\t-t\tread files in text mode (default)\n"
+	"\t-g\tread a string\n"
+	"\nThe following two options are useful only when verifying checksums:\n"
+	"\t-s,\tdon't output anything, status code shows success\n"
+	"\t-w,\twarn about improperly formated MD5 checksum lines\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKDIR
+const char mkdir_usage[] =
+	"mkdir [OPTION] DIRECTORY...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate the DIRECTORY(ies), if they do not already exist\n\n"
+	"Options:\n"
+
+	"\t-m\tset permission mode (as in chmod), not rwxrwxrwx - umask\n"
+	"\t-p\tno error if existing, make parent directories as needed\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKFIFO
+const char mkfifo_usage[] =
+	"mkfifo [OPTIONS] name\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreates a named pipe (identical to 'mknod name p')\n\n"
+	"Options:\n"
+	"\t-m\tcreate the pipe using the specified mode (default a=rw)\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKFS_MINIX
+const char mkfs_minix_usage[] =
+	"mkfs.minix [-c | -l filename] [-nXX] [-iXX] /dev/name [blocks]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nMake a MINIX filesystem.\n\n"
+	"Options:\n"
+	"\t-c\t\tCheck the device for bad blocks\n"
+	"\t-n [14|30]\tSpecify the maximum length of filenames\n"
+	"\t-i INODES\tSpecify the number of inodes for the filesystem\n"
+	"\t-l FILENAME\tRead the bad blocks list from FILENAME\n"
+	"\t-v\t\tMake a Minix version 2 filesystem\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKNOD
+const char mknod_usage[] =
+	"mknod [OPTIONS] NAME TYPE MAJOR MINOR\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate a special file (block, character, or pipe).\n\n"
+	"Options:\n"
+	"\t-m\tcreate the special file using the specified mode (default a=rw)\n\n"
+	"TYPEs include:\n"
+	"\tb:\tMake a block (buffered) device.\n"
+	"\tc or u:\tMake a character (un-buffered) device.\n"
+	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKSWAP
+const char mkswap_usage[] =
+	"mkswap [-c] [-v0|-v1] device [block-count]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrepare a disk partition to be used as a swap partition.\n\n"
+	"Options:\n" "\t-c\t\tCheck for read-ability.\n"
+	"\t-v0\t\tMake version 0 swap [max 128 Megs].\n"
+	"\t-v1\t\tMake version 1 swap [big!] (default for kernels > 2.1.117).\n"
+
+	"\tblock-count\tNumber of block to use (default is entire partition).\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKTEMP
+const char mktemp_usage[] =
+	"mktemp [-q] TEMPLATE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreates a temporary file with its name based on TEMPLATE.\n"
+	"TEMPLATE is any name with six `Xs' (i.e. /tmp/temp.XXXXXX).\n"
+#endif
+	;
+#endif
+
+#if defined BB_MORE
+const char more_usage[] =
+	"more [FILE ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nMore is a filter for viewing FILE one screenful at a time.\n"
+#endif
+	;
+#endif
+
+#if defined BB_MOUNT
+const char mount_usage[] = 
+	"mount [flags] device directory [-o options,more-options]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nMount a filesystem\n\n"
+	"Flags:\n" 
+	"\t-a:\t\tMount all filesystems in fstab.\n"
+#ifdef BB_MTAB
+	"\t-f:\t\t\"Fake\" mount. Add entry to mount table but don't mount it.\n"
+	"\t-n:\t\tDon't write a mount table entry.\n"
+#endif
+	"\t-o option:\tOne of many filesystem options, listed below.\n"
+	"\t-r:\t\tMount the filesystem read-only.\n"
+	"\t-t fs-type:\tSpecify the filesystem type.\n"
+	"\t-w:\t\tMount for reading and writing (default).\n"
+	"\n"
+	"Options for use with the \"-o\" flag:\n"
+	"\tasync/sync:\tWrites are asynchronous / synchronous.\n"
+	"\tatime/noatime:\tEnable / disable updates to inode access times.\n"
+	"\tdev/nodev:\tAllow use of special device files / disallow them.\n"
+	"\texec/noexec:\tAllow use of executable files / disallow them.\n"
+#if defined BB_FEATURE_MOUNT_LOOP
+	"\tloop:\t\tMounts a file via loop device.\n"
+#endif
+	"\tsuid/nosuid:\tAllow set-user-id-root programs / disallow them.\n"
+	"\tremount:\tRe-mount a currently-mounted filesystem, changing its flags.\n"
+	"\tro/rw:\t\tMount for read-only / read-write.\n"
+	"\nThere are EVEN MORE flags that are specific to each filesystem.\n"
+	"You'll have to see the written documentation for those.\n"
+#endif
+	;
+#endif
+
+#if defined BB_MT
+const char mt_usage[] =
+	"mt [-f device] opcode value\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nControl magnetic tape drive operation\n"
+#endif
+	;
+#endif
+
+#if defined BB_CP_MV
+const char mv_usage[] =
+	"mv SOURCE DEST\n"
+	"   or: mv SOURCE... DIRECTORY\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRename SOURCE to DEST, or move SOURCE(s) to DIRECTORY.\n"
+#endif
+	;
+#endif
+
+#if defined BB_NC
+const char nc_usage[] =
+	"nc [IP] [port]\n" 
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nNetcat opens a pipe to IP:port\n"
+#endif
+	;
+#endif
+
+#if defined BB_NSLOOKUP
+const char nslookup_usage[] =
+	"nslookup [HOST]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nQueries the nameserver for the IP address of the given HOST\n"
+#endif
+;
+#endif
+
+#if defined BB_PING
+#if defined BB_FEATURE_SIMPLE_PING
+const char ping_usage[] =
+	"ping host\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend ICMP ECHO_REQUEST packets to network hosts\n"
+#endif
+	;
+#else /* ! defined BB_FEATURE_SIMPLE_PING */
+const char ping_usage[] =
+	"ping [OPTION]... host\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend ICMP ECHO_REQUEST packets to network hosts.\n\n"
+	"Options:\n"
+	"\t-c COUNT\tSend only COUNT pings.\n"
+	"\t-s SIZE\t\tSend SIZE data bytes in packets (default=56).\n"
+	"\t-q\t\tQuiet mode, only displays output at start\n"
+	"\t\t\tand when finished.\n"
+#endif
+	;
+#endif
+#endif
+
+#if defined BB_PRINTF
+const char printf_usage[] =
+	"printf FORMAT [ARGUMENT...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nFormats and prints ARGUMENT(s) according to FORMAT,\n"
+	"Where FORMAT controls the output exactly as in C printf.\n"
+#endif
+	;
+#endif
+
+#if defined BB_PS
+const char ps_usage[] =
+	"ps\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nReport process status\n"
+	"\nThis version of ps accepts no options.\n"
+#endif
+	;
+#endif
+
+#if defined BB_RM
+const char rm_usage[] =
+	"rm [OPTION]... FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRemove (unlink) the FILE(s).  You may use '--' to\n"
+	"indicate that all following arguments are non-options.\n\n"
+	"Options:\n"
+	"\t-f\t\tremove existing destinations, never prompt\n"
+	"\t-r or -R\tremove the contents of directories recursively\n"
+#endif
+	;
+#endif
+
+#if defined BB_RMDIR
+const char rmdir_usage[] =
+	"rmdir [OPTION]... DIRECTORY...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRemove the DIRECTORY(ies), if they are empty.\n"
+#endif
+	;
+#endif
+
+#if defined BB_RMMOD
+const char rmmod_usage[] =
+	"rmmod [OPTION]... [MODULE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUnloads the specified kernel modules from the kernel.\n\n"
+	"Options:\n" 
+	"\t-a\tTry to remove all unused kernel modules.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SED
+const char sed_usage[] =
+	"sed [-Vhnef] pattern [files...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\n"
+	"-n\tsuppress automatic printing of pattern space\n"
+	"-e script\tadd the script to the commands to be executed\n"
+	"-f scriptfile\tadd the contents of script-file to the commands to be executed\n"
+	"-h\tdisplay this help message\n"
+	"-V\toutput version information and exit\n"
+	"\n"
+	"If no -e or -f is given, the first non-option argument is taken as the\n"
+	"sed script to interpret. All remaining arguments are names of input\n"
+	"files; if no input files are specified, then the standard input is read.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SETKEYCODES
+const char setkeycodes_usage[] =
+	"setkeycodes SCANCODE KEYCODE ...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSet entries into the kernel's scancode-to-keycode map,\n"
+	"allowing unusual keyboards to generate usable keycodes.\n\n" 
+	"SCANCODE may be either xx or e0xx (hexadecimal),\n"
+	"and KEYCODE is given in decimal\n"
+#endif
+	;
+#endif
+
+#if defined BB_SH
+const char shell_usage[] =
+	"sh [FILE]...\n"
+	"   or: sh -c command [args]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nlash: The BusyBox command interpreter (shell).\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_SLEEP
+const char sleep_usage[] =
+	"sleep N\n" 
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPause for N seconds.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SORT
+const char sort_usage[] =
+	"sort [-n]"
+#ifdef BB_FEATURE_SORT_REVERSE
+	" [-r]"
+#endif
+	" [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSorts lines of text in the specified files\n"
+#endif
+	;
+#endif
+
+#if defined BB_SWAPONOFF
+const char swapoff_usage[] =
+	"swapoff [OPTION] [device]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStop swapping virtual memory pages on the given device.\n\n"
+	"Options:\n"
+	"\t-a\tStop swapping on all swap devices\n"
+#endif
+	;
+#endif
+
+#if defined BB_SWAPONOFF
+const char swapon_usage[] =
+	"swapon [OPTION] [device]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStart swapping virtual memory pages on the given device.\n\n"
+	"Options:\n"
+	"\t-a\tStart swapping on all swap devices\n"
+#endif
+	;
+#endif
+
+#if defined BB_SYNC
+const char sync_usage[] =
+	"sync\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nWrite all buffered filesystem blocks to disk.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SYSLOGD
+const char syslogd_usage[] =
+	"syslogd [OPTION]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLinux system and kernel (provides klogd) logging utility.\n"
+	"Note that this version of syslogd/klogd ignores /etc/syslog.conf.\n\n"
+	"Options:\n"
+	"\t-m NUM\t\tInterval between MARK lines (default=20min, 0=off)\n"
+	"\t-n\t\tRun as a foreground process\n"
+#ifdef BB_FEATURE_KLOGD
+	"\t-K\t\tDo not start up the klogd process\n"
+#endif
+	"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
+#endif
+	;
+#endif
+
+#if defined BB_TAIL
+#if defined BB_FEATURE_SIMPLE_TAIL
+const char tail_usage[] =
+	"tail [OPTION] [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint last 10 lines of each FILE to standard output.\n"
+	"With more than one FILE, precede each with a header giving the\n"
+	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
+	"Options:\n"
+	"\t-n NUM\t\tPrint last NUM lines instead of first 10\n"
+
+	"\t-f\t\tOutput data as the file grows.  This version\n"
+	"\t\t\tof 'tail -f' supports only one file at a time.\n"
+#endif
+	;
+#else /* ! defined BB_FEATURE_SIMPLE_TAIL */
+const char tail_usage[] =
+	"tail [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint last 10 lines of each FILE to standard output.\n"
+	"With more than one FILE, precede each with a header giving the file name.\n"
+	"With no FILE, or when FILE is -, read standard input.\n"
+	"\n"
+	"  -c=N[kbm]       output the last N bytes\n"
+	"  -f              output appended data as the file grows\n"
+	"  -n=N            output the last N lines, instead of last 10\n"
+	"  -q              never output headers giving file names\n"
+	"  -v              always output headers giving file names\n"
+	"\n"
+	"If the first character of N (bytes or lines) is a `+', output begins with \n"
+	"the Nth item from the start of each file, otherwise, print the last N items\n"
+	"in the file.  N bytes may be suffixed by k (x1024), b (x512), or m (1024^2).\n"
+#endif
+	;
+#endif
+#endif
+
+#if defined BB_TAR
+const char tar_usage[] =
+#ifdef BB_FEATURE_TAR_CREATE
+	"tar -[cxtvO] "
+#else
+	"tar -[xtvO] "
+#endif
+#if defined BB_FEATURE_TAR_EXCLUDE
+	"[--exclude File] "
+#endif
+	"[-f tarFile] [FILE] ...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate, extract, or list files from a tar file.  Note that\n"
+	"this version of tar treats hard links as separate files.\n\n"
+	"Main operation mode:\n"
+#ifdef BB_FEATURE_TAR_CREATE
+	"\tc\t\tcreate\n"
+#endif
+	"\tx\t\textract\n"
+	"\tt\t\tlist\n"
+	"\nFile selection:\n"
+	"\tf\t\tname of tarfile or \"-\" for stdin\n"
+	"\tO\t\textract to stdout\n"
+#if defined BB_FEATURE_TAR_EXCLUDE
+	"\t--exclude\tfile to exclude\n"
+#endif
+	"\nInformative output:\n"
+	"\tv\t\tverbosely list files processed\n"
+#endif
+	;
+#endif
+
+#if defined BB_TEE
+const char tee_usage[] =
+	"tee [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCopy standard input to each FILE, and also to standard output.\n\n"
+	"Options:\n" "\t-a\tappend to the given FILEs, do not overwrite\n"
+#endif
+	;
+#endif
+
+#if defined BB_TELNET
+const char telnet_usage[] =
+	"telnet host [port]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nTelnet is used to establish interactive communication with another\n"
+	"computer over a network using the TELNET protocol.\n"
+#endif
+	;
+#endif
+
+#if defined BB_TEST
+const char test_usage[] =
+	"test EXPRESSION\n"
+	"or   [ EXPRESSION ]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChecks file types and compares values returning an exit\n"
+	"code determined by the value of EXPRESSION.\n"
+#endif
+	;
+#endif
+
+#if defined BB_TOUCH
+const char touch_usage[] =
+	"touch [-c] file [file ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUpdate the last-modified date on the given file[s].\n\n"
+	"Options:\n"
+	"\t-c\tDo not create any files\n"
+#endif
+	;
+#endif
+
+#if defined BB_TR
+const char tr_usage[] =
+	"tr [-cds] STRING1 [STRING2]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nTranslate, squeeze, and/or delete characters from\n"
+	"standard input, writing to standard output.\n\n"
+	"Options:\n"
+	"\t-c\ttake complement of STRING1\n"
+	"\t-d\tdelete input characters coded STRING1\n"
+	"\t-s\tsqueeze multiple output characters of STRING2 into one character\n"
+#endif
+	;
+#endif
+
+#if defined BB_TTY
+const char tty_usage[] =
+	"tty\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint the file name of the terminal connected to standard input.\n\n"
+	"Options:\n"
+	"\t-s\tprint nothing, only return an exit status\n"
+#endif
+	;
+#endif
+
+#if defined BB_UMOUNT
+const char umount_usage[] =
+	"umount [flags] filesystem|directory\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"Unmount file systems\n"
+	"\nFlags:\n" "\t-a:\tUnmount all file systems"
+#ifdef BB_MTAB
+	" in /etc/mtab\n\t-n:\tDon't erase /etc/mtab entries\n"
+#else
+	"\n"
+#endif
+	"\t-r:\tTry to remount devices as read-only if mount is busy\n"
+#if defined BB_FEATURE_MOUNT_FORCE
+	"\t-f:\tForce filesystem umount (i.e. unreachable NFS server)\n"
+#endif
+#if defined BB_FEATURE_MOUNT_LOOP
+	"\t-l:\tDo not free loop device (if a loop device has been used)\n"
+#endif
+#endif
+	;
+#endif
+
+#if defined BB_UNAME
+const char uname_usage[] =
+	"uname [OPTION]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint certain system information.  With no OPTION, same as -s.\n\n"
+	"Options:\n"
+	"\t-a\tprint all information\n"
+	"\t-m\tthe machine (hardware) type\n"
+	"\t-n\tprint the machine's network node hostname\n"
+	"\t-r\tprint the operating system release\n"
+	"\t-s\tprint the operating system name\n"
+
+	"\t-p\tprint the host processor type\n"
+	"\t-v\tprint the operating system version\n"
+#endif
+	;
+#endif
+
+#if defined BB_UNIQ
+const char uniq_usage[] =
+	"uniq [OPTION]... [INPUT [OUTPUT]]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDiscard all but one of successive identical lines from INPUT\n"
+	"(or standard input), writing to OUTPUT (or standard output).\n"
+#endif
+	;
+#endif
+
+#if defined BB_UPDATE
+const char update_usage[] =
+	"update [options]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPeriodically flushes filesystem buffers.\n\n"
+	"Options:\n"
+	"\t-S\tforce use of sync(2) instead of flushing\n"
+	"\t-s SECS\tcall sync this often (default 30)\n"
+	"\t-f SECS\tflush some buffers this often (default 5)\n"
+#endif
+	;
+#endif
+
+#if defined BB_USLEEP
+const char usleep_usage[] =
+	"usleep N\n" 
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPause for N microseconds.\n"
+#endif
+	;
+#endif
+
+#if defined BB_UUDECODE
+const char uudecode_usage[] =
+	"uudecode [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUudecode a file that is uuencoded.\n\n"
+	"Options:\n"
+	"\t-o FILE\tdirect output to FILE\n"
+#endif
+	;
+#endif
+
+#if defined BB_UUENCODE
+const char uuencode_usage[] =
+	"uuencode [OPTION] [INFILE] REMOTEFILE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUuencode a file.\n\n"
+	"Options:\n"
+	"\t-m\tuse base64 encoding as of RFC1521\n"
+#endif
+	;
+#endif
+
+#if defined BB_WC
+const char wc_usage[] =
+	"wc [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint line, word, and byte counts for each FILE, and a total line if\n"
+	"more than one FILE is specified.  With no FILE, read standard input.\n\n"
+	"Options:\n"
+	"\t-c\tprint the byte counts\n"
+	"\t-l\tprint the newline counts\n"
+
+	"\t-L\tprint the length of the longest line\n"
+	"\t-w\tprint the word counts\n"
+#endif
+	;
+#endif
+
+#if defined BB_WHICH
+const char which_usage[] =
+	"which [COMMAND ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLocates a COMMAND.\n"
+#endif
+	;
+#endif
+
+#if defined BB_WHOAMI
+const char whoami_usage[] =
+	"whoami\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints the user name associated with the current effective user id.\n"
+#endif
+	;
+#endif
+
+#if defined BB_YES
+const char yes_usage[] =
+	"yes [OPTION]... [STRING]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRepeatedly outputs a line with all specified STRING(s), or `y'.\n"
+#endif
+	;
+#endif
diff --git a/ar.c b/ar.c
index a43cc1d..d8c8d46 100644
--- a/ar.c
+++ b/ar.c
@@ -65,18 +65,6 @@
 };
 typedef struct ArInfo ArInfo;
 
-static const char ar_usage[] = "ar [optxvV] archive [filenames] \n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nExtract or list files from an ar archive.\n\n"
-	"Options:\n"
-	"\to\t\tpreserve original dates\n"
-	"\tp\t\textract to stdout\n"
-	"\tt\t\tlist\n"
-	"\tx\t\textract\n"
-	"\tv\t\tverbosely list files processed\n"
-#endif
-	;
-
 /*
  * Display details of a file, verbosly if funct=2   
  */
diff --git a/archival/ar.c b/archival/ar.c
index a43cc1d..d8c8d46 100644
--- a/archival/ar.c
+++ b/archival/ar.c
@@ -65,18 +65,6 @@
 };
 typedef struct ArInfo ArInfo;
 
-static const char ar_usage[] = "ar [optxvV] archive [filenames] \n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nExtract or list files from an ar archive.\n\n"
-	"Options:\n"
-	"\to\t\tpreserve original dates\n"
-	"\tp\t\textract to stdout\n"
-	"\tt\t\tlist\n"
-	"\tx\t\textract\n"
-	"\tv\t\tverbosely list files processed\n"
-#endif
-	;
-
 /*
  * Display details of a file, verbosly if funct=2   
  */
diff --git a/archival/gunzip.c b/archival/gunzip.c
index de68bd1..b29bdf7 100644
--- a/archival/gunzip.c
+++ b/archival/gunzip.c
@@ -30,19 +30,7 @@
 #include "internal.h"
 #include <getopt.h>
 
-static const char gunzip_usage[] =
-	"gunzip [OPTION]... FILE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nUncompress FILE (or standard input if FILE is '-').\n\n"
-	"Options:\n"
-
-	"\t-c\tWrite output to standard output\n"
-	"\t-t\tTest compressed file integrity\n"
-#endif
-	;
-
-	
-	/* These defines are very important for BusyBox.  Without these,
+/* These defines are very important for BusyBox.  Without these,
  * huge chunks of ram are pre-allocated making the BusyBox bss 
  * size Freaking Huge(tm), which is a bad thing.*/
 #define SMALL_MEM
diff --git a/archival/gzip.c b/archival/gzip.c
index 8bc67d9..98ce259 100644
--- a/archival/gzip.c
+++ b/archival/gzip.c
@@ -40,19 +40,6 @@
 #define SMALL_MEM
 #define DYN_ALLOC
 
-
-static const char gzip_usage[] =
-	"gzip [OPTION]... FILE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCompress FILE with maximum compression.\n"
-	"When FILE is '-', reads standard input.  Implies -c.\n\n"
-
-	"Options:\n"
-	"\t-c\tWrite output to standard output instead of FILE.gz\n"
-#endif
-	;
-
-
 /* I don't like nested includes, but the string and io functions are used
  * too often
  */
diff --git a/archival/tar.c b/archival/tar.c
index 353694f..6f18dc4 100644
--- a/archival/tar.c
+++ b/archival/tar.c
@@ -50,37 +50,6 @@
 #include <sys/types.h>
 #include <sys/sysmacros.h>
 
-
-static const char tar_usage[] =
-#ifdef BB_FEATURE_TAR_CREATE
-	"tar -[cxtvO] "
-#else
-	"tar -[xtvO] "
-#endif
-#if defined BB_FEATURE_TAR_EXCLUDE
-	"[--exclude File] "
-#endif
-	"[-f tarFile] [FILE] ...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate, extract, or list files from a tar file.  Note that\n"
-	"this version of tar treats hard links as separate files.\n\n"
-	"Main operation mode:\n"
-#ifdef BB_FEATURE_TAR_CREATE
-	"\tc\t\tcreate\n"
-#endif
-	"\tx\t\textract\n"
-	"\tt\t\tlist\n"
-	"\nFile selection:\n"
-	"\tf\t\tname of tarfile or \"-\" for stdin\n"
-	"\tO\t\textract to stdout\n"
-#if defined BB_FEATURE_TAR_EXCLUDE
-	"\t--exclude\tfile to exclude\n"
-#endif
-	"\nInformative output:\n"
-	"\tv\t\tverbosely list files processed\n"
-#endif
-	;
-
 /* Tar file constants  */
 #ifndef MAJOR
 #define MAJOR(dev) (((dev)>>8)&0xff)
diff --git a/basename.c b/basename.c
index 5678c44..5b83eef 100644
--- a/basename.c
+++ b/basename.c
@@ -24,14 +24,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char *basename_usage="basename FILE [SUFFIX]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStrips directory path and suffixes from FILE.\n"
-	"If specified, also removes any trailing SUFFIX.\n"
-#endif
-;
-
-
 extern int basename_main(int argc, char **argv)
 {
 	int m, n;
diff --git a/cat.c b/cat.c
index 6c17ee6..c27f07e 100644
--- a/cat.c
+++ b/cat.c
@@ -34,13 +34,6 @@
 	fflush(stdout);
 }
 
-static const char cat_usage[] =
-	"cat [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nConcatenates FILE(s) and prints them to stdout.\n"
-#endif
-	;
-
 extern int cat_main(int argc, char **argv)
 {
 	FILE *file;
diff --git a/chmod_chown_chgrp.c b/chmod_chown_chgrp.c
index 156a0a9..c02f2a3 100644
--- a/chmod_chown_chgrp.c
+++ b/chmod_chown_chgrp.c
@@ -43,29 +43,6 @@
 #define CHOWN_APP   2
 #define CHMOD_APP   3
 
-static const char chgrp_usage[] = "chgrp [OPTION]... GROUP FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nChange the group membership of each FILE to GROUP.\n"
-	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
-#endif
-	;
-static const char chown_usage[] =
-	"chown [OPTION]...  OWNER[<.|:>[GROUP] FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nChange the owner and/or group of each FILE to OWNER and/or GROUP.\n"
-	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
-#endif
-	;
-static const char chmod_usage[] =
-	"chmod [-R] MODE[,MODE]... FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nEach MODE is one or more of the letters ugoa, one of the symbols +-= and\n"
-	"one or more of the letters rwxst.\n\n"
-	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
-#endif
-	;
-
-
 static int fileAction(const char *fileName, struct stat *statbuf, void* junk)
 {
 	switch (whichApp) {
diff --git a/chroot.c b/chroot.c
index 95aed3d..9b1a5a8 100644
--- a/chroot.c
+++ b/chroot.c
@@ -27,15 +27,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-
-static const char chroot_usage[] = "chroot NEWROOT [COMMAND...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRun COMMAND with root directory set to NEWROOT.\n"
-#endif
-	;
-
-
-
 int chroot_main(int argc, char **argv)
 {
 	char *prog;
diff --git a/chvt.c b/chvt.c
index ab0e921..87a1248 100644
--- a/chvt.c
+++ b/chvt.c
@@ -15,13 +15,6 @@
 #define VT_ACTIVATE     0x5606  /* make vt active */
 #define VT_WAITACTIVE   0x5607  /* wait for vt active */
 
-const char chvt_usage[] =
-	"chvt N\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nChanges the foreground virtual terminal to /dev/ttyN\n"
-#endif
-	;
-
 int chvt_main(int argc, char **argv)
 {
 	int fd, num;
diff --git a/console-tools/chvt.c b/console-tools/chvt.c
index ab0e921..87a1248 100644
--- a/console-tools/chvt.c
+++ b/console-tools/chvt.c
@@ -15,13 +15,6 @@
 #define VT_ACTIVATE     0x5606  /* make vt active */
 #define VT_WAITACTIVE   0x5607  /* wait for vt active */
 
-const char chvt_usage[] =
-	"chvt N\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nChanges the foreground virtual terminal to /dev/ttyN\n"
-#endif
-	;
-
 int chvt_main(int argc, char **argv)
 {
 	int fd, num;
diff --git a/console-tools/deallocvt.c b/console-tools/deallocvt.c
index 042de86..9c477d2 100644
--- a/console-tools/deallocvt.c
+++ b/console-tools/deallocvt.c
@@ -13,13 +13,6 @@
 /* From <linux/vt.h> */
 #define VT_DISALLOCATE  0x5608  /* free memory associated to vt */
 
-const char deallocvt_usage[] =
-	"deallocvt N\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	 "\nDeallocate unused virtual terminal /dev/ttyN\n"
-#endif
-	 ;
-
 int deallocvt_main(int argc, char *argv[])
 {
 	int fd, num, i;
diff --git a/console-tools/dumpkmap.c b/console-tools/dumpkmap.c
index f180505..4ce6e86 100644
--- a/console-tools/dumpkmap.c
+++ b/console-tools/dumpkmap.c
@@ -38,14 +38,6 @@
 #define NR_KEYS         128
 #define MAX_NR_KEYMAPS  256
 
-
-static const char dumpkmap_usage[] = "dumpkmap\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints out a binary keyboard translation table to standard input.\n"
-#endif
-	;
-
-
 int dumpkmap_main(int argc, char **argv)
 {
 	struct kbentry ke;
diff --git a/console-tools/loadacm.c b/console-tools/loadacm.c
index 9eebf3b..2d70ffc 100644
--- a/console-tools/loadacm.c
+++ b/console-tools/loadacm.c
@@ -22,12 +22,6 @@
 #include <sys/ioctl.h>
 #include <sys/kd.h>
 
-static const char loadacm_usage[] = "loadacm\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLoads an acm from standard input.\n"
-#endif
-	;
-
 typedef unsigned short unicode;
 
 static long int ctoi(unsigned char *s, int *is_unicode);
diff --git a/console-tools/loadfont.c b/console-tools/loadfont.c
index 46a7574..6221429 100644
--- a/console-tools/loadfont.c
+++ b/console-tools/loadfont.c
@@ -30,12 +30,6 @@
 #define PSF_MAXMODE    0x03
 #define PSF_SEPARATOR  0xFFFF
 
-static const char loadfont_usage[] = "loadfont\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"Loads a console font from standard input.\n"
-#endif
-	;
-
 struct psf_header {
 	unsigned char magic1, magic2;	/* Magic number */
 	unsigned char mode;			/* PSF font mode */
diff --git a/console-tools/loadkmap.c b/console-tools/loadkmap.c
index 72247a6..488585f 100644
--- a/console-tools/loadkmap.c
+++ b/console-tools/loadkmap.c
@@ -38,14 +38,6 @@
 #define NR_KEYS         128
 #define MAX_NR_KEYMAPS  256
 
-
-static const char loadkmap_usage[] = "loadkmap\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLoads a binary keyboard translation table from standard input.\n"
-#endif
-	;
-
-
 int loadkmap_main(int argc, char **argv)
 {
 	struct kbentry ke;
diff --git a/console-tools/setkeycodes.c b/console-tools/setkeycodes.c
index 1bdb909..284ffa1 100644
--- a/console-tools/setkeycodes.c
+++ b/console-tools/setkeycodes.c
@@ -35,17 +35,6 @@
 };
 #define KDSETKEYCODE    0x4B4D  /* write kernel keycode table entry */
 
-
-static const char setkeycodes_usage[] =
-	"setkeycodes SCANCODE KEYCODE ...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSet entries into the kernel's scancode-to-keycode map,\n"
-	"allowing unusual keyboards to generate usable keycodes.\n\n" 
-	"SCANCODE may be either xx or e0xx (hexadecimal),\n"
-	"and KEYCODE is given in decimal\n"
-#endif
-	;
-
 extern int 
 setkeycodes_main(int argc, char** argv)
 {
diff --git a/coreutils/basename.c b/coreutils/basename.c
index 5678c44..5b83eef 100644
--- a/coreutils/basename.c
+++ b/coreutils/basename.c
@@ -24,14 +24,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char *basename_usage="basename FILE [SUFFIX]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStrips directory path and suffixes from FILE.\n"
-	"If specified, also removes any trailing SUFFIX.\n"
-#endif
-;
-
-
 extern int basename_main(int argc, char **argv)
 {
 	int m, n;
diff --git a/coreutils/cat.c b/coreutils/cat.c
index 6c17ee6..c27f07e 100644
--- a/coreutils/cat.c
+++ b/coreutils/cat.c
@@ -34,13 +34,6 @@
 	fflush(stdout);
 }
 
-static const char cat_usage[] =
-	"cat [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nConcatenates FILE(s) and prints them to stdout.\n"
-#endif
-	;
-
 extern int cat_main(int argc, char **argv)
 {
 	FILE *file;
diff --git a/coreutils/chroot.c b/coreutils/chroot.c
index 95aed3d..9b1a5a8 100644
--- a/coreutils/chroot.c
+++ b/coreutils/chroot.c
@@ -27,15 +27,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-
-static const char chroot_usage[] = "chroot NEWROOT [COMMAND...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRun COMMAND with root directory set to NEWROOT.\n"
-#endif
-	;
-
-
-
 int chroot_main(int argc, char **argv)
 {
 	char *prog;
diff --git a/coreutils/cut.c b/coreutils/cut.c
index 08b4586..8b28fff 100644
--- a/coreutils/cut.c
+++ b/coreutils/cut.c
@@ -206,20 +206,6 @@
 	}
 }
 
-const char cut_usage[] =
-	"cut [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints selected fields from each input FILE to standard output.\n\n"
-	"Options:\n"
-	"\t-b LIST\tOutput only bytes from LIST\n"
-	"\t-c LIST\tOutput only characters from LIST\n"
-	"\t-d CHAR\tUse CHAR instead of tab as the field delimiter\n"
-	"\t-s\tOnly output Lines if the include DELIM\n"
-	"\t-f N\tPrint only these fields\n"
-	"\t-n\tIgnored\n"
-#endif
-	;
-
 int cut_main(int argc, char **argv)
 {
 	int i = 1;
diff --git a/coreutils/date.c b/coreutils/date.c
index 3ede123..b6fc6c6 100644
--- a/coreutils/date.c
+++ b/coreutils/date.c
@@ -39,17 +39,6 @@
    an RFC 822 complient date output for shell scripting
    mail commands */
 
-static const char date_usage[] = "date [OPTION]... [+FORMAT]\n"
-	"  or:  date [OPTION] [MMDDhhmm[[CC]YY][.ss]]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDisplays the current time in the given FORMAT, or sets the system date.\n"
-	"\nOptions:\n\t-R\tOutputs RFC-822 compliant date string\n"
-	"\t-s\tSets time described by STRING\n"
-	"\t-u\tPrints or sets Coordinated Universal Time\n"
-#endif
-	;
-
-
 /* Input parsing code is always bulky - used heavy duty libc stuff as
    much as possible, missed out a lot of bounds checking */
 
diff --git a/coreutils/dd.c b/coreutils/dd.c
index 6261dfe..8689919 100644
--- a/coreutils/dd.c
+++ b/coreutils/dd.c
@@ -40,23 +40,6 @@
 typedef unsigned long long int uintmax_t;
 #endif
 
-static const char dd_usage[] =
-	"dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCopy a file, converting and formatting according to options\n\n"
-	"\tif=FILE\tread from FILE instead of stdin\n"
-	"\tof=FILE\twrite to FILE instead of stdout\n"
-	"\tbs=N\tread and write N bytes at a time\n"
-	"\tcount=N\tcopy only N input blocks\n"
-	"\tskip=N\tskip N input blocks\n"
-	"\tseek=N\tskip N output blocks\n"
-	"\n"
-	"Numbers may be suffixed by w (x2), k (x1024), b (x512), or M (x1024^2)\n"
-#endif
-	;
-
-
-
 extern int dd_main(int argc, char **argv)
 {
 	char *inFile = NULL;
diff --git a/coreutils/df.c b/coreutils/df.c
index 62226ce..714c799 100644
--- a/coreutils/df.c
+++ b/coreutils/df.c
@@ -28,12 +28,6 @@
 #include <sys/stat.h>
 #include <sys/vfs.h>
 
-static const char df_usage[] = "df [filesystem ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint the filesystem space used and space available.\n"
-#endif
-	;
-
 extern const char mtab_file[];	/* Defined in utility.c */
 
 static int df(char *device, const char *mountPoint)
diff --git a/coreutils/dirname.c b/coreutils/dirname.c
index 0b60ceb..e63fef3 100644
--- a/coreutils/dirname.c
+++ b/coreutils/dirname.c
@@ -23,13 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char dirname_usage[] =
-	"dirname [FILENAME ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStrips non-directory suffix from FILENAME\n"
-#endif
-	;
-
 extern int dirname_main(int argc, char **argv)
 {
 	char* s;
diff --git a/coreutils/du.c b/coreutils/du.c
index f1a4442..147914c 100644
--- a/coreutils/du.c
+++ b/coreutils/du.c
@@ -35,17 +35,6 @@
 
 typedef void (Display) (long, char *);
 
-static const char du_usage[] =
-	"du [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSummarizes disk space used for each FILE and/or directory.\n"
-	"Disk space is printed in units of 1024 bytes.\n\n"
-	"Options:\n"
-	"\t-l\tcount sizes many times if hard linked\n"
-	"\t-s\tdisplay only a total for each argument\n"
-#endif
-	;
-
 static int du_depth = 0;
 static int count_hardlinks = 0;
 
@@ -174,7 +163,7 @@
 	return(0);
 }
 
-/* $Id: du.c,v 1.22 2000/07/14 18:38:26 andersen Exp $ */
+/* $Id: du.c,v 1.23 2000/07/16 20:57:15 kraai Exp $ */
 /*
 Local Variables:
 c-file-style: "linux"
diff --git a/coreutils/echo.c b/coreutils/echo.c
index 387ea3f..73be8f2 100644
--- a/coreutils/echo.c
+++ b/coreutils/echo.c
@@ -25,17 +25,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-static const char uname_usage[] =
-	"echo [-neE] [ARG ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints the specified ARGs to stdout\n\n"
-	"Options:\n"
-	"\t-n\tsuppress trailing newline\n"
-	"\t-e\tinterpret backslash-escaped characters (i.e. \\t=tab etc)\n"
-	"\t-E\tdisable interpretation of backslash-escaped characters\n"
-#endif
-	;
-
 extern int 
 echo_main(int argc, char** argv)
 {
@@ -58,7 +47,7 @@
 			eflag = 0;
 			break;
 		default: 
-			usage(uname_usage);
+			usage(echo_usage);
 		}
 	}
 
diff --git a/coreutils/head.c b/coreutils/head.c
index b82678d..58b3cae 100644
--- a/coreutils/head.c
+++ b/coreutils/head.c
@@ -26,17 +26,6 @@
 #include <errno.h>
 #include <stdio.h>
 
-const char head_usage[] =
-	"head [OPTION] [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint first 10 lines of each FILE to standard output.\n"
-	"With more than one FILE, precede each with a header giving the\n"
-	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
-
-	"Options:\n" "\t-n NUM\t\tPrint first NUM lines instead of first 10\n"
-#endif
-	;
-
 int head(int len, FILE * src)
 {
 	int i;
@@ -111,4 +100,4 @@
 	return(0);
 }
 
-/* $Id: head.c,v 1.12 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: head.c,v 1.13 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/coreutils/id.c b/coreutils/id.c
index 69dfe26..56a2e27 100644
--- a/coreutils/id.c
+++ b/coreutils/id.c
@@ -28,17 +28,6 @@
 #include <grp.h>
 #include <sys/types.h>
 
-static const char id_usage[] =
-	"id [OPTIONS]... [USERNAME]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint information for USERNAME or the current user\n\n"
-	"Options:\n"
-	"\t-g\tprints only the group ID\n"
-	"\t-u\tprints only the user ID\n"
-	"\t-r\tprints the real user ID instead of the effective ID (with -ug)\n\n"
-#endif
-	;
-
 extern int id_main(int argc, char **argv)
 {
 	int no_user = 0, no_group = 0, print_real = 0;
diff --git a/coreutils/length.c b/coreutils/length.c
index 82f50c1..cf4fb1c 100644
--- a/coreutils/length.c
+++ b/coreutils/length.c
@@ -4,13 +4,6 @@
 #include <string.h>
 #include <stdio.h>
 
-const char length_usage[] =
-	"length STRING\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints out the length of the specified STRING.\n"
-#endif
-	;
-
 extern int length_main(int argc, char **argv)
 {
 	if (argc != 2 || **(argv + 1) == '-')
diff --git a/coreutils/ln.c b/coreutils/ln.c
index 9f77743..8b8fa1c 100644
--- a/coreutils/ln.c
+++ b/coreutils/ln.c
@@ -30,19 +30,6 @@
 #include <dirent.h>
 #include <errno.h>
 
-static const char ln_usage[] =
-	"ln [OPTION] TARGET... LINK_NAME|DIRECTORY\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate a link named LINK_NAME or DIRECTORY to the specified TARGET\n"
-	"\nYou may use '--' to indicate that all following arguments are non-options.\n\n"
-	"Options:\n"
-	"\t-s\tmake symbolic links instead of hard links\n"
-
-	"\t-f\tremove existing destination files\n"
-	"\t-n\tno dereference symlinks - treat like normal file\n"
-#endif
-	;
-
 static int symlinkFlag = FALSE;
 static int removeoldFlag = FALSE;
 static int followLinks = TRUE;
diff --git a/coreutils/logname.c b/coreutils/logname.c
index 12ebfbd..a0aff42 100644
--- a/coreutils/logname.c
+++ b/coreutils/logname.c
@@ -23,12 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-static const char logname_usage[] = "logname\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint the name of the current user.\n"
-#endif
-	;
-
 extern int logname_main(int argc, char **argv)
 {
 	char *user = xmalloc(9);
diff --git a/coreutils/ls.c b/coreutils/ls.c
index 0644cde..e56e3bc 100644
--- a/coreutils/ls.c
+++ b/coreutils/ls.c
@@ -427,63 +427,6 @@
 	return 1;
 }
 
-static const char ls_usage[] = "ls [-1a"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"c"
-#endif
-	"d"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"e"
-#endif
-	"ln"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"p"
-#endif
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"u"
-#endif
-	"xAC"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"F"
-#endif
-#ifdef BB_FEATURE_LS_RECURSIVE
-	"R"
-#endif
-	"] [filenames...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nList directory contents\n\n"
-	"Options:\n"
-	"\t-a\tdo not hide entries starting with .\n"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"\t-c\twith -l: show ctime (the time of last\n"
-    "\t\tmodification of file status information)\n"
-#endif
-	"\t-d\tlist directory entries instead of contents\n"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"\t-e\tlist both full date and full time\n"
-#endif
-	"\t-l\tuse a long listing format\n"
-	"\t-n\tlist numeric UIDs and GIDs instead of names\n"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"\t-p\tappend indicator (one of /=@|) to entries\n"
-#endif
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"\t-u\twith -l: show access time (the time of last\n"
-	"\t\taccess of the file)\n"
-#endif
-	"\t-x\tlist entries by lines instead of by columns\n"
-	"\t-A\tdo not list implied . and ..\n"
-	"\t-C\tlist entries by columns\n"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"\t-F\tappend indicator (one of */=@|) to entries\n"
-#endif
-#ifdef BB_FEATURE_LS_RECURSIVE
-	"\t-R\tlist subdirectories recursively\n"
-#endif
-#endif
-	;
-
-
 #ifdef BB_FEATURE_LS_RECURSIVE
 static int dirAction(const char *fileName, struct stat *statbuf, void* junk)
 {
diff --git a/coreutils/md5sum.c b/coreutils/md5sum.c
index e6f1c86..fad563f 100644
--- a/coreutils/md5sum.c
+++ b/coreutils/md5sum.c
@@ -582,23 +582,6 @@
 static int warn = 0; /* With -w, print a message to standard error warning
                         about each improperly formatted MD5 checksum line */
 
-static const char md5sum_usage[] =
-    "md5sum [OPTION] [FILE]...\n"
-    "or:    md5sum [OPTION] -c [FILE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-    "\nPrint or check MD5 checksums.\n\n"
-    "Options:\n"
-    "With no FILE, or when FILE is -, read standard input.\n\n"
-    "\t-b\tread files in binary mode\n"
-    "\t-c\tcheck MD5 sums against given list\n"
-    "\t-t\tread files in text mode (default)\n"
-    "\t-g\tread a string\n"
-    "\nThe following two options are useful only when verifying checksums:\n"
-    "\t-s,\tdon't output anything, status code shows success\n"
-    "\t-w,\twarn about improperly formated MD5 checksum lines\n"
-#endif
-;
-
 static int split_3(char *s,
                    size_t s_len,
                    unsigned char **u,
diff --git a/coreutils/mkdir.c b/coreutils/mkdir.c
index f6e08ca..f824cdc 100644
--- a/coreutils/mkdir.c
+++ b/coreutils/mkdir.c
@@ -29,18 +29,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-static const char mkdir_usage[] =
-	"mkdir [OPTION] DIRECTORY...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate the DIRECTORY(ies), if they do not already exist\n\n"
-	"Options:\n"
-
-	"\t-m\tset permission mode (as in chmod), not rwxrwxrwx - umask\n"
-	"\t-p\tno error if existing, make parent directories as needed\n"
-#endif
-	;
-
-
 static int parentFlag = FALSE;
 static mode_t mode = 0777;
 
diff --git a/coreutils/mkfifo.c b/coreutils/mkfifo.c
index f701a97..3db17bb 100644
--- a/coreutils/mkfifo.c
+++ b/coreutils/mkfifo.c
@@ -26,14 +26,6 @@
 #include <sys/stat.h>
 #include <errno.h>
 
-static const char mkfifo_usage[] = "mkfifo [OPTIONS] name\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreates a named pipe (identical to 'mknod name p')\n\n"
-	"Options:\n"
-	"\t-m\tcreate the pipe using the specified mode (default a=rw)\n"
-#endif
-	;
-
 extern int mkfifo_main(int argc, char **argv)
 {
 	char *thisarg;
diff --git a/coreutils/mknod.c b/coreutils/mknod.c
index ac96817..b51c8f3 100644
--- a/coreutils/mknod.c
+++ b/coreutils/mknod.c
@@ -28,18 +28,6 @@
 #include <fcntl.h>
 #include <unistd.h>
 
-static const char mknod_usage[] = "mknod [OPTIONS] NAME TYPE MAJOR MINOR\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate a special file (block, character, or pipe).\n\n"
-	"Options:\n"
-	"\t-m\tcreate the special file using the specified mode (default a=rw)\n\n"
-	"TYPEs include:\n"
-	"\tb:\tMake a block (buffered) device.\n"
-	"\tc or u:\tMake a character (un-buffered) device.\n"
-	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n"
-#endif
-	;
-
 int mknod_main(int argc, char **argv)
 {
 	char *thisarg;
diff --git a/coreutils/printf.c b/coreutils/printf.c
index f572897..6a87fc3 100644
--- a/coreutils/printf.c
+++ b/coreutils/printf.c
@@ -137,13 +137,6 @@
 /* The value to return to the calling program.  */
 static int exit_status;
 
-static const char printf_usage[] = "printf FORMAT [ARGUMENT...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nFormats and prints ARGUMENT(s) according to FORMAT,\n"
-	"Where FORMAT controls the output exactly as in C printf.\n"
-#endif
-	;
-
 int printf_main(int argc, char **argv)
 {
 	char *format;
diff --git a/coreutils/rm.c b/coreutils/rm.c
index 2067d87..275c059 100644
--- a/coreutils/rm.c
+++ b/coreutils/rm.c
@@ -29,17 +29,6 @@
 #include <dirent.h>
 #include <errno.h>
 
-static const char *rm_usage = "rm [OPTION]... FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRemove (unlink) the FILE(s).  You may use '--' to\n"
-	"indicate that all following arguments are non-options.\n\n"
-	"Options:\n"
-	"\t-f\t\tremove existing destinations, never prompt\n"
-	"\t-r or -R\tremove the contents of directories recursively\n"
-#endif
-	;
-
-
 static int recursiveFlag = FALSE;
 static int forceFlag = FALSE;
 static const char *srcName;
diff --git a/coreutils/rmdir.c b/coreutils/rmdir.c
index 3c3533f..500890e 100644
--- a/coreutils/rmdir.c
+++ b/coreutils/rmdir.c
@@ -26,13 +26,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-const char rmdir_usage[] =
-	"rmdir [OPTION]... DIRECTORY...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRemove the DIRECTORY(ies), if they are empty.\n"
-#endif
-	;
-
 extern int rmdir_main(int argc, char **argv)
 {
 	if (argc == 1 || **(argv + 1) == '-')
diff --git a/coreutils/sleep.c b/coreutils/sleep.c
index c7ab32d..d6705c4 100644
--- a/coreutils/sleep.c
+++ b/coreutils/sleep.c
@@ -24,12 +24,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char sleep_usage[] = "sleep N\n" 
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPause for N seconds.\n"
-#endif
-	;
-
 extern int sleep_main(int argc, char **argv)
 {
 	if ((argc < 2) || (**(argv + 1) == '-')) {
diff --git a/coreutils/sort.c b/coreutils/sort.c
index c754989..6af5c4d 100644
--- a/coreutils/sort.c
+++ b/coreutils/sort.c
@@ -29,16 +29,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-static const char sort_usage[] = "sort [-n]"
-#ifdef BB_FEATURE_SORT_REVERSE
-" [-r]"
-#endif
-" [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-"\nSorts lines of text in the specified files\n"
-#endif
-;
-
 #ifdef BB_FEATURE_SORT_REVERSE
 #define APPLY_REVERSE(x) (reverse ? -(x) : (x))
 static int reverse = 0;
@@ -304,4 +294,4 @@
 	return(0);
 }
 
-/* $Id: sort.c,v 1.19 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: sort.c,v 1.20 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/coreutils/sync.c b/coreutils/sync.c
index f7c14b0..3737cb1 100644
--- a/coreutils/sync.c
+++ b/coreutils/sync.c
@@ -24,13 +24,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char sync_usage[] =
-	"sync\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nWrite all buffered filesystem blocks to disk.\n"
-#endif
-	;
-
 extern int sync_main(int argc, char **argv)
 {
 	if (argc > 1 && **(argv + 1) == '-')
diff --git a/coreutils/tail.c b/coreutils/tail.c
index 9232356..cea63e8 100644
--- a/coreutils/tail.c
+++ b/coreutils/tail.c
@@ -72,21 +72,6 @@
 /* If nonzero, print filename headers.  */
 static int print_headers;
 
-const char tail_usage[] =
-	"tail [OPTION] [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint last 10 lines of each FILE to standard output.\n"
-	"With more than one FILE, precede each with a header giving the\n"
-	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
-	"Options:\n"
-	"\t-n NUM\t\tPrint last NUM lines instead of first 10\n"
-
-	"\t-f\t\tOutput data as the file grows.  This version\n"
-	"\t\t\tof 'tail -f' supports only one file at a time.\n"
-#endif
-	;
-
-
 static void write_header(const char *filename)
 {
 	static int first_file = 1;
@@ -516,25 +501,6 @@
 /* Nonzero if we have ever read standard input.  */
 static int have_read_stdin;
 
-
-static const char tail_usage[] = "tail [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-"\nPrint last 10 lines of each FILE to standard output.\n\
-With more than one FILE, precede each with a header giving the file name.\n\
-With no FILE, or when FILE is -, read standard input.\n\
-\n\
-  -c=N[kbm]       output the last N bytes\n\
-  -f              output appended data as the file grows\n\
-  -n=N            output the last N lines, instead of last 10\n\
-  -q              never output headers giving file names\n\
-  -v              always output headers giving file names\n\
-\n\
-If the first character of N (bytes or lines) is a `+', output begins with \n\
-the Nth item from the start of each file, otherwise, print the last N items\n\
-in the file.  N bytes may be suffixed by k (x1024), b (x512), or m (1024^2).\n"
-#endif
-;
-
 static void write_header(const char *filename, const char *comment)
 {
 	static int first_file = 1;
diff --git a/coreutils/tee.c b/coreutils/tee.c
index 67b42a2..c15408b 100644
--- a/coreutils/tee.c
+++ b/coreutils/tee.c
@@ -26,18 +26,6 @@
 #include <errno.h>
 #include <stdio.h>
 
-static const char tee_usage[] =
-	"tee [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCopy standard input to each FILE, and also to standard output.\n\n"
-	"Options:\n" "\t-a\tappend to the given FILEs, do not overwrite\n"
-#if 0
-	"\t-i\tignore interrupt signals\n"
-#endif
-#endif
-;
-
-
 /* FileList _______________________________________________________________ */
 
 #define FL_MAX	1024
@@ -133,4 +121,4 @@
 	return(0);
 }
 
-/* $Id: tee.c,v 1.12 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: tee.c,v 1.13 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/coreutils/test.c b/coreutils/test.c
index bf1622c..9a1888b 100644
--- a/coreutils/test.c
+++ b/coreutils/test.c
@@ -178,15 +178,6 @@
 static int is_a_group_member();
 static void initialize_group_array();
 
-const char test_usage[] =
-	"test EXPRESSION\n"
-	"or   [ EXPRESSION ]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nChecks file types and compares values returning an exit\n"
-	"code determined by the value of EXPRESSION.\n"
-#endif
-	;
-
 extern int
 test_main(int argc, char** argv)
 {
diff --git a/coreutils/touch.c b/coreutils/touch.c
index ac27542..afdd265 100644
--- a/coreutils/touch.c
+++ b/coreutils/touch.c
@@ -30,16 +30,6 @@
 #include <utime.h>
 #include <errno.h>
 
-
-static const char touch_usage[] = "touch [-c] file [file ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nUpdate the last-modified date on the given file[s].\n\n"
-	"Options:\n"
-	"\t-c\tDo not create any files\n"
-#endif
-	;
-
-
 extern int touch_main(int argc, char **argv)
 {
 	int fd;
diff --git a/coreutils/tr.c b/coreutils/tr.c
index 2971ef6..0040924 100644
--- a/coreutils/tr.c
+++ b/coreutils/tr.c
@@ -34,19 +34,6 @@
 #define bb_need_write_error
 #include "messages.c"
 
-const char *tr_usage="tr [-cds] STRING1 [STRING2]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nTranslate, squeeze, and/or delete characters from\n"
-	"standard input, writing to standard output.\n\n"
-	"Options:\n"
-	"\t-c\ttake complement of STRING1\n"
-	"\t-d\tdelete input characters coded STRING1\n"
-	"\t-s\tsqueeze multiple output characters of STRING2 into one character\n"
-#endif
-;
-
-
-
 #ifdef TRUE
 #undef TRUE
 #undef FALSE
diff --git a/coreutils/tty.c b/coreutils/tty.c
index f3c7fb7..bbc051f 100644
--- a/coreutils/tty.c
+++ b/coreutils/tty.c
@@ -24,14 +24,6 @@
 #include <stdio.h>
 #include <sys/types.h>
 
-static const char tty_usage[] = "tty\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint the file name of the terminal connected to standard input.\n\n"
-	"Options:\n"
-	"\t-s\tprint nothing, only return an exit status\n"
-#endif
-	;
-
 extern int tty_main(int argc, char **argv)
 {
 	char *tty;
diff --git a/coreutils/uname.c b/coreutils/uname.c
index b7c88ec..55616dd 100644
--- a/coreutils/uname.c
+++ b/coreutils/uname.c
@@ -40,24 +40,6 @@
 # include <sys/systeminfo.h>
 #endif
 
-
-static const char uname_usage[] =
-	"uname [OPTION]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint certain system information.  With no OPTION, same as -s.\n\n"
-	"Options:\n"
-	"\t-a\tprint all information\n"
-	"\t-m\tthe machine (hardware) type\n"
-	"\t-n\tprint the machine's network node hostname\n"
-	"\t-r\tprint the operating system release\n"
-	"\t-s\tprint the operating system name\n"
-
-	"\t-p\tprint the host processor type\n"
-	"\t-v\tprint the operating system version\n"
-#endif
-	;
-
-
 static void print_element(unsigned int mask, char *element);
 
 /* Values that are bitwise or'd into `toprint'. */
diff --git a/coreutils/uniq.c b/coreutils/uniq.c
index 16b2576..016fc77 100644
--- a/coreutils/uniq.c
+++ b/coreutils/uniq.c
@@ -27,14 +27,6 @@
 #include <string.h>
 #include <errno.h>
 
-static const char uniq_usage[] =
-	"uniq [OPTION]... [INPUT [OUTPUT]]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDiscard all but one of successive identical lines from INPUT\n"
-	"(or standard input), writing to OUTPUT (or standard output).\n"
-#endif
-	;
-
 /* max chars in line */
 #define UNIQ_MAX 4096
 
@@ -187,4 +179,4 @@
 	return(0);
 }
 
-/* $Id: uniq.c,v 1.12 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: uniq.c,v 1.13 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/coreutils/usleep.c b/coreutils/usleep.c
index da6cca9..fcdf3bb 100644
--- a/coreutils/usleep.c
+++ b/coreutils/usleep.c
@@ -25,12 +25,6 @@
 #include <stdlib.h>
 #include <unistd.h>
 
-const char usleep_usage[] = "usleep N\n" 
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPause for N microseconds.\n"
-#endif
-	;
-
 extern int usleep_main(int argc, char **argv)
 {
 	if ((argc < 2) || (**(argv + 1) == '-')) {
diff --git a/coreutils/uudecode.c b/coreutils/uudecode.c
index 12a71a5..90bef92 100644
--- a/coreutils/uudecode.c
+++ b/coreutils/uudecode.c
@@ -300,15 +300,6 @@
     return read_stduu (inname);
 }
 
-static const char uudecode_usage[] =
-    "uudecode [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-    "\nUudecode a file that is uuencoded.\n\n"
-    "Options:\n"
-    "\t-o FILE\tdirect output to FILE\n"
-#endif
-;
-
 int uudecode_main (int argc,
                    char **argv)
 {
diff --git a/coreutils/uuencode.c b/coreutils/uuencode.c
index e107a01..1433c7f 100644
--- a/coreutils/uuencode.c
+++ b/coreutils/uuencode.c
@@ -180,15 +180,6 @@
   }
 }
 
-static const char uuencode_usage[] =
-    "uuencode [OPTION] [INFILE] REMOTEFILE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-    "\nUuencode a file.\n\n"
-    "Options:\n"
-    "\t-m\tuse base64 encoding as of RFC1521\n"
-#endif
-;
-
 int uuencode_main (int argc,
                    char **argv)
 {
diff --git a/coreutils/wc.c b/coreutils/wc.c
index 3b0e589..058444d 100644
--- a/coreutils/wc.c
+++ b/coreutils/wc.c
@@ -23,19 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-static const char wc_usage[] = "wc [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint line, word, and byte counts for each FILE, and a total line if\n"
-	"more than one FILE is specified.  With no FILE, read standard input.\n\n"
-	"Options:\n"
-	"\t-c\tprint the byte counts\n"
-	"\t-l\tprint the newline counts\n"
-
-	"\t-L\tprint the length of the longest line\n"
-	"\t-w\tprint the word counts\n"
-#endif
-	;
-
 static int total_lines, total_words, total_chars, max_length;
 static int print_lines, print_words, print_chars, print_length;
 
diff --git a/coreutils/whoami.c b/coreutils/whoami.c
index 01dff81..84b27fe 100644
--- a/coreutils/whoami.c
+++ b/coreutils/whoami.c
@@ -24,12 +24,6 @@
 #include <stdio.h>
 #include <pwd.h>
 
-static const char whoami_usage[] = "whoami\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints the user name associated with the current effective user id.\n"
-#endif
-	;
-
 extern int whoami_main(int argc, char **argv)
 {
 	char *user = xmalloc(9);
diff --git a/coreutils/yes.c b/coreutils/yes.c
index 0191bb0..f41bbb6 100644
--- a/coreutils/yes.c
+++ b/coreutils/yes.c
@@ -23,13 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char yes_usage[] =
-	"yes [OPTION]... [STRING]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRepeatedly outputs a line with all specified STRING(s), or `y'.\n"
-#endif
-	;
-
 extern int yes_main(int argc, char **argv)
 {
 	int i;
diff --git a/cp_mv.c b/cp_mv.c
index 72ba537..4c3c7a3 100644
--- a/cp_mv.c
+++ b/cp_mv.c
@@ -47,28 +47,6 @@
 #define is_mv 1
 static int         dz_i;		/* index into cp_mv_usage */
 
-const char cp_usage[] =
-	"cp [OPTION]... SOURCE DEST\n"
-	"   or: cp [OPTION]... SOURCE... DIRECTORY\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCopies SOURCE to DEST, or multiple SOURCE(s) to DIRECTORY.\n"
-	"\n"
-	"\t-a\tSame as -dpR\n"
-	"\t-d\tPreserves links\n"
-	"\t-p\tPreserves file attributes if possible\n"
-	"\t-f\tforce (implied; ignored) - always set\n"
-	"\t-R\tCopies directories recursively\n"
-#endif
-	;
-
-const char mv_usage[] =
-	"mv SOURCE DEST\n"
-	"   or: mv SOURCE... DIRECTORY\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRename SOURCE to DEST, or move SOURCE(s) to DIRECTORY.\n"
-#endif
-	;
-
 static const char *cp_mv_usage[] =	/* .rodata */
 {
 	cp_usage,
diff --git a/cut.c b/cut.c
index 08b4586..8b28fff 100644
--- a/cut.c
+++ b/cut.c
@@ -206,20 +206,6 @@
 	}
 }
 
-const char cut_usage[] =
-	"cut [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints selected fields from each input FILE to standard output.\n\n"
-	"Options:\n"
-	"\t-b LIST\tOutput only bytes from LIST\n"
-	"\t-c LIST\tOutput only characters from LIST\n"
-	"\t-d CHAR\tUse CHAR instead of tab as the field delimiter\n"
-	"\t-s\tOnly output Lines if the include DELIM\n"
-	"\t-f N\tPrint only these fields\n"
-	"\t-n\tIgnored\n"
-#endif
-	;
-
 int cut_main(int argc, char **argv)
 {
 	int i = 1;
diff --git a/date.c b/date.c
index 3ede123..b6fc6c6 100644
--- a/date.c
+++ b/date.c
@@ -39,17 +39,6 @@
    an RFC 822 complient date output for shell scripting
    mail commands */
 
-static const char date_usage[] = "date [OPTION]... [+FORMAT]\n"
-	"  or:  date [OPTION] [MMDDhhmm[[CC]YY][.ss]]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDisplays the current time in the given FORMAT, or sets the system date.\n"
-	"\nOptions:\n\t-R\tOutputs RFC-822 compliant date string\n"
-	"\t-s\tSets time described by STRING\n"
-	"\t-u\tPrints or sets Coordinated Universal Time\n"
-#endif
-	;
-
-
 /* Input parsing code is always bulky - used heavy duty libc stuff as
    much as possible, missed out a lot of bounds checking */
 
diff --git a/dc.c b/dc.c
index 7b13cb9..fac48e8 100644
--- a/dc.c
+++ b/dc.c
@@ -8,14 +8,6 @@
 
 /* Tiny RPN calculator, because "expr" didn't give me bitwise operations. */
 
-static const char dc_usage[] = "dc expression ...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-		"\nThis is a Tiny RPN calculator that understands the\n"
-		"following operations: +, -, /, *, and, or, not, eor.\n"
-		"i.e. 'dc 2 2 add' -> 4, and 'dc 8 8 \\* 2 2 + /' -> 16\n"
-#endif
-		;
-
 static double stack[100];
 static unsigned int pointer;
 
diff --git a/dd.c b/dd.c
index 6261dfe..8689919 100644
--- a/dd.c
+++ b/dd.c
@@ -40,23 +40,6 @@
 typedef unsigned long long int uintmax_t;
 #endif
 
-static const char dd_usage[] =
-	"dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCopy a file, converting and formatting according to options\n\n"
-	"\tif=FILE\tread from FILE instead of stdin\n"
-	"\tof=FILE\twrite to FILE instead of stdout\n"
-	"\tbs=N\tread and write N bytes at a time\n"
-	"\tcount=N\tcopy only N input blocks\n"
-	"\tskip=N\tskip N input blocks\n"
-	"\tseek=N\tskip N output blocks\n"
-	"\n"
-	"Numbers may be suffixed by w (x2), k (x1024), b (x512), or M (x1024^2)\n"
-#endif
-	;
-
-
-
 extern int dd_main(int argc, char **argv)
 {
 	char *inFile = NULL;
diff --git a/deallocvt.c b/deallocvt.c
index 042de86..9c477d2 100644
--- a/deallocvt.c
+++ b/deallocvt.c
@@ -13,13 +13,6 @@
 /* From <linux/vt.h> */
 #define VT_DISALLOCATE  0x5608  /* free memory associated to vt */
 
-const char deallocvt_usage[] =
-	"deallocvt N\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	 "\nDeallocate unused virtual terminal /dev/ttyN\n"
-#endif
-	 ;
-
 int deallocvt_main(int argc, char *argv[])
 {
 	int fd, num, i;
diff --git a/df.c b/df.c
index 62226ce..714c799 100644
--- a/df.c
+++ b/df.c
@@ -28,12 +28,6 @@
 #include <sys/stat.h>
 #include <sys/vfs.h>
 
-static const char df_usage[] = "df [filesystem ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint the filesystem space used and space available.\n"
-#endif
-	;
-
 extern const char mtab_file[];	/* Defined in utility.c */
 
 static int df(char *device, const char *mountPoint)
diff --git a/dirname.c b/dirname.c
index 0b60ceb..e63fef3 100644
--- a/dirname.c
+++ b/dirname.c
@@ -23,13 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char dirname_usage[] =
-	"dirname [FILENAME ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStrips non-directory suffix from FILENAME\n"
-#endif
-	;
-
 extern int dirname_main(int argc, char **argv)
 {
 	char* s;
diff --git a/dmesg.c b/dmesg.c
index 961e532..a8c61c7 100644
--- a/dmesg.c
+++ b/dmesg.c
@@ -32,16 +32,6 @@
 # include <sys/klog.h>
 #endif
 
-static const char dmesg_usage[] = "dmesg [-c] [-n LEVEL] [-s SIZE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints or controls the kernel ring buffer\n\n"
-	"Options:\n"
-	"\t-c\t\tClears the ring buffer's contents after printing\n"
-	"\t-n LEVEL\tSets console logging level\n"
-	"\t-s SIZE\t\tUse a buffer of size SIZE\n"
-#endif
-	;
-
 int dmesg_main(int argc, char **argv)
 {
 	char *buf, c;
diff --git a/du.c b/du.c
index f1a4442..147914c 100644
--- a/du.c
+++ b/du.c
@@ -35,17 +35,6 @@
 
 typedef void (Display) (long, char *);
 
-static const char du_usage[] =
-	"du [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSummarizes disk space used for each FILE and/or directory.\n"
-	"Disk space is printed in units of 1024 bytes.\n\n"
-	"Options:\n"
-	"\t-l\tcount sizes many times if hard linked\n"
-	"\t-s\tdisplay only a total for each argument\n"
-#endif
-	;
-
 static int du_depth = 0;
 static int count_hardlinks = 0;
 
@@ -174,7 +163,7 @@
 	return(0);
 }
 
-/* $Id: du.c,v 1.22 2000/07/14 18:38:26 andersen Exp $ */
+/* $Id: du.c,v 1.23 2000/07/16 20:57:15 kraai Exp $ */
 /*
 Local Variables:
 c-file-style: "linux"
diff --git a/dumpkmap.c b/dumpkmap.c
index f180505..4ce6e86 100644
--- a/dumpkmap.c
+++ b/dumpkmap.c
@@ -38,14 +38,6 @@
 #define NR_KEYS         128
 #define MAX_NR_KEYMAPS  256
 
-
-static const char dumpkmap_usage[] = "dumpkmap\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints out a binary keyboard translation table to standard input.\n"
-#endif
-	;
-
-
 int dumpkmap_main(int argc, char **argv)
 {
 	struct kbentry ke;
diff --git a/dutmp.c b/dutmp.c
index c6bc0c7..047b880 100644
--- a/dutmp.c
+++ b/dutmp.c
@@ -23,14 +23,6 @@
 #include "messages.c"
 #include <utmp.h>
 
-
-static const char dutmp_usage[] = "dutmp [FILE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDump utmp file format (pipe delimited) from FILE\n"
-	"or stdin to stdout.  (i.e. 'dutmp /var/run/utmp')\n"
-#endif
-	;
-
 extern int dutmp_main(int argc, char **argv)
 {
 
diff --git a/echo.c b/echo.c
index 387ea3f..73be8f2 100644
--- a/echo.c
+++ b/echo.c
@@ -25,17 +25,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-static const char uname_usage[] =
-	"echo [-neE] [ARG ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints the specified ARGs to stdout\n\n"
-	"Options:\n"
-	"\t-n\tsuppress trailing newline\n"
-	"\t-e\tinterpret backslash-escaped characters (i.e. \\t=tab etc)\n"
-	"\t-E\tdisable interpretation of backslash-escaped characters\n"
-#endif
-	;
-
 extern int 
 echo_main(int argc, char** argv)
 {
@@ -58,7 +47,7 @@
 			eflag = 0;
 			break;
 		default: 
-			usage(uname_usage);
+			usage(echo_usage);
 		}
 	}
 
diff --git a/editors/sed.c b/editors/sed.c
index 1f1e906..4d4886e 100644
--- a/editors/sed.c
+++ b/editors/sed.c
@@ -85,22 +85,6 @@
 
 /*static char *cur_file = NULL;*/ /* file currently being processed XXX: do I need this? */
 
-static const char sed_usage[] =
-	"sed [-Vhnef] pattern [files...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\n"
-	"-n\tsuppress automatic printing of pattern space\n"
-	"-e script\tadd the script to the commands to be executed\n"
-	"-f scriptfile\tadd the contents of script-file to the commands to be executed\n"
-	"-h\tdisplay this help message\n"
-	"-V\toutput version information and exit\n"
-	"\n"
-	"If no -e or -f is given, the first non-option argument is taken as the\n"
-	"sed script to interpret. All remaining arguments are names of input\n"
-	"files; if no input files are specified, then the standard input is read.\n"
-#endif
-	;
-
 #if 0
 static void destroy_cmd_strs()
 {
diff --git a/fdflush.c b/fdflush.c
index d993735..6bc3e7d 100644
--- a/fdflush.c
+++ b/fdflush.c
@@ -34,13 +34,8 @@
 	int value;
 	int fd;
 
-	if (argc <= 1 || **(++argv) == '-') {
-		usage("fdflush DEVICE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-				"\nForces floppy disk drive to detect disk change\n"
-#endif
-				);
-	}
+	if (argc <= 1 || **(++argv) == '-')
+		usage(fdflush_usage);
 
 	fd = open(*argv, 0);
 	if (fd < 0) {
diff --git a/find.c b/find.c
index e18f3c5..1c209ae 100644
--- a/find.c
+++ b/find.c
@@ -32,18 +32,6 @@
 static char *directory = ".";
 static int dereferenceFlag = FALSE;
 
-static const char find_usage[] = "find [PATH...] [EXPRESSION]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSearch for files in a directory hierarchy.  The default PATH is\n"
-	"the current directory; default EXPRESSION is '-print'\n\n"
-	"\nEXPRESSION may consist of:\n"
-	"\t-follow\t\tDereference symbolic links.\n"
-	"\t-name PATTERN\tFile name (leading directories removed) matches PATTERN.\n"
-	"\t-print\t\tprint the full file name followed by a newline to stdout.\n"
-#endif
-	;
-
-
 static int fileAction(const char *fileName, struct stat *statbuf, void* junk)
 {
 	if (pattern == NULL)
diff --git a/findutils/find.c b/findutils/find.c
index e18f3c5..1c209ae 100644
--- a/findutils/find.c
+++ b/findutils/find.c
@@ -32,18 +32,6 @@
 static char *directory = ".";
 static int dereferenceFlag = FALSE;
 
-static const char find_usage[] = "find [PATH...] [EXPRESSION]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSearch for files in a directory hierarchy.  The default PATH is\n"
-	"the current directory; default EXPRESSION is '-print'\n\n"
-	"\nEXPRESSION may consist of:\n"
-	"\t-follow\t\tDereference symbolic links.\n"
-	"\t-name PATTERN\tFile name (leading directories removed) matches PATTERN.\n"
-	"\t-print\t\tprint the full file name followed by a newline to stdout.\n"
-#endif
-	;
-
-
 static int fileAction(const char *fileName, struct stat *statbuf, void* junk)
 {
 	if (pattern == NULL)
diff --git a/findutils/grep.c b/findutils/grep.c
index 03945fa..a2c07c5 100644
--- a/findutils/grep.c
+++ b/findutils/grep.c
@@ -31,21 +31,6 @@
 extern int optind; /* in unistd.h */
 extern int errno;  /* for use with strerror() */
 
-static const char grep_usage[] =
-	"grep [-ihHnqvs] pattern [files...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSearch for PATTERN in each FILE or standard input.\n\n"
-	"Options:\n"
-	"\t-H\tprefix output lines with filename where match was found\n"
-	"\t-h\tsuppress the prefixing filename on output\n"
-	"\t-i\tignore case distinctions\n"
-	"\t-n\tprint line number with output lines\n"
-	"\t-q\tbe quiet. Returns 0 if result was found, 1 otherwise\n"
-	"\t-v\tselect non-matching lines\n"
-	"\t-s\tsuppress file open/read error messages\n\n"
-#endif
-	;
-
 /* options */
 static int ignore_case       = 0;
 static int print_filename    = 0;
diff --git a/findutils/which.c b/findutils/which.c
index 186bfda..943e10a 100644
--- a/findutils/which.c
+++ b/findutils/which.c
@@ -26,13 +26,6 @@
 #include <sys/stat.h>
 #include <sys/param.h>
 
-const char which_usage[] =
-	"which [COMMAND ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLocates a COMMAND.\n"
-#endif
-	;
-
 extern int which_main(int argc, char **argv)
 {
 	char *path_list, *test, *tmp, *path_parsed;
diff --git a/free.c b/free.c
index 7c9d7f1..78298cf 100644
--- a/free.c
+++ b/free.c
@@ -25,13 +25,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-const char free_usage[] =
-	"free\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDisplays the amount of free and used system memory\n"
-#endif
-	;
-
 extern int free_main(int argc, char **argv)
 {
 	struct sysinfo info;
diff --git a/freeramdisk.c b/freeramdisk.c
index 927c169..2da2427 100644
--- a/freeramdisk.c
+++ b/freeramdisk.c
@@ -34,14 +34,6 @@
 /* From linux/fs.h */
 #define BLKFLSBUF  _IO(0x12,97)	/* flush buffer cache */
 
-
-static const char freeramdisk_usage[] =
-	"freeramdisk DEVICE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nFrees all memory used by the specified ramdisk.\n"
-#endif
-	;
-
 extern int
 freeramdisk_main(int argc, char **argv)
 {
diff --git a/fsck_minix.c b/fsck_minix.c
index ea27c23..5807b9a 100644
--- a/fsck_minix.c
+++ b/fsck_minix.c
@@ -288,21 +288,6 @@
 	exit(status);
 }
 
-const char fsck_minix_usage[] =
-	"Usage: fsck.minix [-larvsmf] /dev/name\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPerforms a consistency check for MINIX filesystems.\n\n"
-	"Options:\n"
-	"\t-l\tLists all filenames\n"
-	"\t-r\tPerform interactive repairs\n"
-	"\t-a\tPerform automatic repairs\n"
-	"\t-v\tverbose\n"
-	"\t-s\tOutputs super-block information\n"
-	"\t-m\tActivates MINIX-like \"mode not cleared\" warnings\n"
-	"\t-f\tForce file system check.\n\n"
-#endif
-	;
-
 static void show_usage(void)
 {
 	usage(fsck_minix_usage);
diff --git a/grep.c b/grep.c
index 03945fa..a2c07c5 100644
--- a/grep.c
+++ b/grep.c
@@ -31,21 +31,6 @@
 extern int optind; /* in unistd.h */
 extern int errno;  /* for use with strerror() */
 
-static const char grep_usage[] =
-	"grep [-ihHnqvs] pattern [files...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSearch for PATTERN in each FILE or standard input.\n\n"
-	"Options:\n"
-	"\t-H\tprefix output lines with filename where match was found\n"
-	"\t-h\tsuppress the prefixing filename on output\n"
-	"\t-i\tignore case distinctions\n"
-	"\t-n\tprint line number with output lines\n"
-	"\t-q\tbe quiet. Returns 0 if result was found, 1 otherwise\n"
-	"\t-v\tselect non-matching lines\n"
-	"\t-s\tsuppress file open/read error messages\n\n"
-#endif
-	;
-
 /* options */
 static int ignore_case       = 0;
 static int print_filename    = 0;
diff --git a/gunzip.c b/gunzip.c
index de68bd1..b29bdf7 100644
--- a/gunzip.c
+++ b/gunzip.c
@@ -30,19 +30,7 @@
 #include "internal.h"
 #include <getopt.h>
 
-static const char gunzip_usage[] =
-	"gunzip [OPTION]... FILE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nUncompress FILE (or standard input if FILE is '-').\n\n"
-	"Options:\n"
-
-	"\t-c\tWrite output to standard output\n"
-	"\t-t\tTest compressed file integrity\n"
-#endif
-	;
-
-	
-	/* These defines are very important for BusyBox.  Without these,
+/* These defines are very important for BusyBox.  Without these,
  * huge chunks of ram are pre-allocated making the BusyBox bss 
  * size Freaking Huge(tm), which is a bad thing.*/
 #define SMALL_MEM
diff --git a/gzip.c b/gzip.c
index 8bc67d9..98ce259 100644
--- a/gzip.c
+++ b/gzip.c
@@ -40,19 +40,6 @@
 #define SMALL_MEM
 #define DYN_ALLOC
 
-
-static const char gzip_usage[] =
-	"gzip [OPTION]... FILE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCompress FILE with maximum compression.\n"
-	"When FILE is '-', reads standard input.  Implies -c.\n\n"
-
-	"Options:\n"
-	"\t-c\tWrite output to standard output instead of FILE.gz\n"
-#endif
-	;
-
-
 /* I don't like nested includes, but the string and io functions are used
  * too often
  */
diff --git a/head.c b/head.c
index b82678d..58b3cae 100644
--- a/head.c
+++ b/head.c
@@ -26,17 +26,6 @@
 #include <errno.h>
 #include <stdio.h>
 
-const char head_usage[] =
-	"head [OPTION] [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint first 10 lines of each FILE to standard output.\n"
-	"With more than one FILE, precede each with a header giving the\n"
-	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
-
-	"Options:\n" "\t-n NUM\t\tPrint first NUM lines instead of first 10\n"
-#endif
-	;
-
 int head(int len, FILE * src)
 {
 	int i;
@@ -111,4 +100,4 @@
 	return(0);
 }
 
-/* $Id: head.c,v 1.12 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: head.c,v 1.13 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/hostname.c b/hostname.c
index 60f66c0..77b545d 100644
--- a/hostname.c
+++ b/hostname.c
@@ -1,6 +1,6 @@
 /* vi: set sw=4 ts=4: */
 /*
- * $Id: hostname.c,v 1.11 2000/07/14 01:51:25 kraai Exp $
+ * $Id: hostname.c,v 1.12 2000/07/16 20:57:15 kraai Exp $
  * Mini hostname implementation for busybox
  *
  * Copyright (C) 1999 by Randolph Chung <tausq@debian.org>
@@ -30,21 +30,6 @@
 #include <unistd.h>
 #include <stdio.h>
 
-static const char *hostname_usage =
-	"hostname [OPTION] {hostname | -F file}\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nGet or set the hostname or DNS domain name. If a hostname is given\n"
-	"(or a file with the -F parameter), the host name will be set.\n\n"
-	"Options:\n"
-	"\t-s\t\tShort\n"
-
-	"\t-i\t\tAddresses for the hostname\n"
-	"\t-d\t\tDNS domain name\n"
-	"\t-F FILE\t\tUse the contents of FILE to specify the hostname\n"
-#endif
-	;
-
-
 void do_sethostname(char *s, int isfile)
 {
 	FILE *f;
diff --git a/id.c b/id.c
index 69dfe26..56a2e27 100644
--- a/id.c
+++ b/id.c
@@ -28,17 +28,6 @@
 #include <grp.h>
 #include <sys/types.h>
 
-static const char id_usage[] =
-	"id [OPTIONS]... [USERNAME]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint information for USERNAME or the current user\n\n"
-	"Options:\n"
-	"\t-g\tprints only the group ID\n"
-	"\t-u\tprints only the user ID\n"
-	"\t-r\tprints the real user ID instead of the effective ID (with -ug)\n\n"
-#endif
-	;
-
 extern int id_main(int argc, char **argv)
 {
 	int no_user = 0, no_group = 0, print_real = 0;
diff --git a/insmod.c b/insmod.c
index 97c360b..9daedf9 100644
--- a/insmod.c
+++ b/insmod.c
@@ -70,7 +70,7 @@
 #ifndef MODUTILS_MODULE_H
 #define MODUTILS_MODULE_H 1
 
-#ident "$Id: insmod.c,v 1.17 2000/07/14 16:23:32 proski Exp $"
+#ident "$Id: insmod.c,v 1.18 2000/07/16 20:57:15 kraai Exp $"
 
 /* This file contains the structures used by the 2.0 and 2.1 kernels.
    We do not use the kernel headers directly because we do not wish
@@ -276,7 +276,7 @@
 #ifndef MODUTILS_OBJ_H
 #define MODUTILS_OBJ_H 1
 
-#ident "$Id: insmod.c,v 1.17 2000/07/14 16:23:32 proski Exp $"
+#ident "$Id: insmod.c,v 1.18 2000/07/16 20:57:15 kraai Exp $"
 
 /* The relocatable object is manipulated using elfin types.  */
 
@@ -560,16 +560,6 @@
 #endif
 static char m_filename[BUFSIZ + 1] = "\0";
 static char m_fullName[BUFSIZ + 1] = "\0";
-static const char insmod_usage[] =
-	"insmod [OPTION]... MODULE [symbol=value]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLoads the specified kernel modules into the kernel.\n\n"
-	"Options:\n"
-	"\t-f\tForce module to load into the wrong kernel version.\n"
-	"\t-k\tMake module autoclean-able.\n"
-	"\t-v\tverbose output\n" "\t-x\tdo not export externs\n"
-#endif
-;
 
 /*======================================================================*/
 
diff --git a/internal.h b/internal.h
index 50b7869..a192679 100644
--- a/internal.h
+++ b/internal.h
@@ -208,6 +208,98 @@
 extern int whoami_main(int argc, char** argv);
 extern int yes_main(int argc, char** argv);
 
+extern const char ar_usage[];
+extern const char basename_usage[];
+extern const char cat_usage[];
+extern const char chgrp_usage[];
+extern const char chmod_usage[];
+extern const char chown_usage[];
+extern const char chroot_usage[];
+extern const char chvt_usage[];
+extern const char cp_usage[];
+extern const char cut_usage[];
+extern const char date_usage[];
+extern const char dc_usage[];
+extern const char dd_usage[];
+extern const char deallocvt_usage[];
+extern const char df_usage[];
+extern const char dirname_usage[];
+extern const char dmesg_usage[];
+extern const char du_usage[];
+extern const char dumpkmap_usage[];
+extern const char dutmp_usage[];
+extern const char echo_usage[];
+extern const char fdflush_usage[];
+extern const char find_usage[];
+extern const char free_usage[];
+extern const char freeramdisk_usage[];
+extern const char fsck_minix_usage[];
+extern const char grep_usage[];
+extern const char gunzip_usage[];
+extern const char gzip_usage[];
+extern const char head_usage[];
+extern const char hostname_usage[];
+extern const char id_usage[];
+extern const char insmod_usage[];
+extern const char kill_usage[];
+extern const char killall_usage[];
+extern const char length_usage[];
+extern const char ln_usage[];
+extern const char loadacm_usage[];
+extern const char loadfont_usage[];
+extern const char loadkmap_usage[];
+extern const char logger_usage[];
+extern const char logname_usage[];
+extern const char ls_usage[];
+extern const char makedevs_usage[];
+extern const char md5sum_usage[];
+extern const char mkdir_usage[];
+extern const char mkfifo_usage[];
+extern const char mkfs_minix_usage[];
+extern const char mknod_usage[];
+extern const char mkswap_usage[];
+extern const char mktemp_usage[];
+extern const char more_usage[];
+extern const char mount_usage[]; 
+extern const char mt_usage[];
+extern const char mv_usage[];
+extern const char nc_usage[];
+extern const char nslookup_usage[];
+extern const char ping_usage[];
+extern const char printf_usage[];
+extern const char ps_usage[];
+extern const char rm_usage[];
+extern const char rmdir_usage[];
+extern const char rmmod_usage[];
+extern const char sed_usage[];
+extern const char setkeycodes_usage[];
+extern const char shell_usage[];
+extern const char sleep_usage[];
+extern const char sort_usage[];
+extern const char swapoff_usage[];
+extern const char swapon_usage[];
+extern const char sync_usage[];
+extern const char syslogd_usage[];
+extern const char tail_usage[];
+extern const char tar_usage[];
+extern const char tee_usage[];
+extern const char telnet_usage[];
+extern const char test_usage[];
+extern const char touch_usage[];
+extern const char tr_usage[];
+extern const char tty_usage[];
+extern const char umount_usage[];
+extern const char uname_usage[];
+extern const char uniq_usage[];
+extern const char update_usage[];
+extern const char usleep_usage[];
+extern const char uudecode_usage[];
+extern const char uuencode_usage[];
+extern const char wc_usage[];
+extern const char which_usage[];
+extern const char whoami_usage[];
+extern const char yes_usage[];
+
 extern char *applet_name;
 
 extern void usage(const char *usage) __attribute__ ((noreturn));
diff --git a/kill.c b/kill.c
index 44cb383..da46620 100644
--- a/kill.c
+++ b/kill.c
@@ -31,24 +31,6 @@
 #include <sys/stat.h>
 #include <unistd.h>
 
-static const char *kill_usage =
-	"kill [-signal] process-id [process-id ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
-	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
-#endif
-	;
-
-#ifdef BB_KILLALL
-static const char *killall_usage =
-	"killall [-signal] process-name [process-name ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
-	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
-#endif
-#endif
-	;
-
 #define KILL	0
 #define KILLALL	1
 
diff --git a/lash.c b/lash.c
index d829b6b..9b34353 100644
--- a/lash.c
+++ b/lash.c
@@ -137,14 +137,6 @@
 	{NULL, NULL, NULL, NULL}
 };
 
-static const char shell_usage[] =
-	"sh [FILE]...\n"
-	"   or: sh -c command [args]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nlash: The BusyBox command interpreter (shell).\n\n"
-#endif
-	;
-
 static char *prompt = "# ";
 static char *cwd = NULL;
 static char *local_pending_command = NULL;
diff --git a/length.c b/length.c
index 82f50c1..cf4fb1c 100644
--- a/length.c
+++ b/length.c
@@ -4,13 +4,6 @@
 #include <string.h>
 #include <stdio.h>
 
-const char length_usage[] =
-	"length STRING\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints out the length of the specified STRING.\n"
-#endif
-	;
-
 extern int length_main(int argc, char **argv)
 {
 	if (argc != 2 || **(argv + 1) == '-')
diff --git a/ln.c b/ln.c
index 9f77743..8b8fa1c 100644
--- a/ln.c
+++ b/ln.c
@@ -30,19 +30,6 @@
 #include <dirent.h>
 #include <errno.h>
 
-static const char ln_usage[] =
-	"ln [OPTION] TARGET... LINK_NAME|DIRECTORY\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate a link named LINK_NAME or DIRECTORY to the specified TARGET\n"
-	"\nYou may use '--' to indicate that all following arguments are non-options.\n\n"
-	"Options:\n"
-	"\t-s\tmake symbolic links instead of hard links\n"
-
-	"\t-f\tremove existing destination files\n"
-	"\t-n\tno dereference symlinks - treat like normal file\n"
-#endif
-	;
-
 static int symlinkFlag = FALSE;
 static int removeoldFlag = FALSE;
 static int followLinks = TRUE;
diff --git a/loadacm.c b/loadacm.c
index 9eebf3b..2d70ffc 100644
--- a/loadacm.c
+++ b/loadacm.c
@@ -22,12 +22,6 @@
 #include <sys/ioctl.h>
 #include <sys/kd.h>
 
-static const char loadacm_usage[] = "loadacm\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLoads an acm from standard input.\n"
-#endif
-	;
-
 typedef unsigned short unicode;
 
 static long int ctoi(unsigned char *s, int *is_unicode);
diff --git a/loadfont.c b/loadfont.c
index 46a7574..6221429 100644
--- a/loadfont.c
+++ b/loadfont.c
@@ -30,12 +30,6 @@
 #define PSF_MAXMODE    0x03
 #define PSF_SEPARATOR  0xFFFF
 
-static const char loadfont_usage[] = "loadfont\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"Loads a console font from standard input.\n"
-#endif
-	;
-
 struct psf_header {
 	unsigned char magic1, magic2;	/* Magic number */
 	unsigned char mode;			/* PSF font mode */
diff --git a/loadkmap.c b/loadkmap.c
index 72247a6..488585f 100644
--- a/loadkmap.c
+++ b/loadkmap.c
@@ -38,14 +38,6 @@
 #define NR_KEYS         128
 #define MAX_NR_KEYMAPS  256
 
-
-static const char loadkmap_usage[] = "loadkmap\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLoads a binary keyboard translation table from standard input.\n"
-#endif
-	;
-
-
 int loadkmap_main(int argc, char **argv)
 {
 	struct kbentry ke;
diff --git a/logger.c b/logger.c
index 981748b..0e1ce8d 100644
--- a/logger.c
+++ b/logger.c
@@ -47,20 +47,6 @@
 extern CODE facilitynames[];
 #endif
 
-static const char logger_usage[] =
-	"logger [OPTION]... [MESSAGE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nWrite MESSAGE to the system log.  If MESSAGE is '-', log stdin.\n\n"
-	"Options:\n"
-	"\t-s\tLog to stderr as well as the system log.\n"
-	"\t-t\tLog using the specified tag (defaults to user name).\n"
-
-	"\t-p\tEnter the message with the specified priority.\n"
-	"\t\tThis may be numerical or a ``facility.level'' pair.\n"
-#endif
-	;
-
-
 /* Decode a symbolic name to a numeric value 
  * this function is based on code
  * Copyright (c) 1983, 1993
diff --git a/logname.c b/logname.c
index 12ebfbd..a0aff42 100644
--- a/logname.c
+++ b/logname.c
@@ -23,12 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-static const char logname_usage[] = "logname\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint the name of the current user.\n"
-#endif
-	;
-
 extern int logname_main(int argc, char **argv)
 {
 	char *user = xmalloc(9);
diff --git a/ls.c b/ls.c
index 0644cde..e56e3bc 100644
--- a/ls.c
+++ b/ls.c
@@ -427,63 +427,6 @@
 	return 1;
 }
 
-static const char ls_usage[] = "ls [-1a"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"c"
-#endif
-	"d"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"e"
-#endif
-	"ln"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"p"
-#endif
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"u"
-#endif
-	"xAC"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"F"
-#endif
-#ifdef BB_FEATURE_LS_RECURSIVE
-	"R"
-#endif
-	"] [filenames...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nList directory contents\n\n"
-	"Options:\n"
-	"\t-a\tdo not hide entries starting with .\n"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"\t-c\twith -l: show ctime (the time of last\n"
-    "\t\tmodification of file status information)\n"
-#endif
-	"\t-d\tlist directory entries instead of contents\n"
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"\t-e\tlist both full date and full time\n"
-#endif
-	"\t-l\tuse a long listing format\n"
-	"\t-n\tlist numeric UIDs and GIDs instead of names\n"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"\t-p\tappend indicator (one of /=@|) to entries\n"
-#endif
-#ifdef BB_FEATURE_LS_TIMESTAMPS
-	"\t-u\twith -l: show access time (the time of last\n"
-	"\t\taccess of the file)\n"
-#endif
-	"\t-x\tlist entries by lines instead of by columns\n"
-	"\t-A\tdo not list implied . and ..\n"
-	"\t-C\tlist entries by columns\n"
-#ifdef BB_FEATURE_LS_FILETYPES
-	"\t-F\tappend indicator (one of */=@|) to entries\n"
-#endif
-#ifdef BB_FEATURE_LS_RECURSIVE
-	"\t-R\tlist subdirectories recursively\n"
-#endif
-#endif
-	;
-
-
 #ifdef BB_FEATURE_LS_RECURSIVE
 static int dirAction(const char *fileName, struct stat *statbuf, void* junk)
 {
diff --git a/makedevs.c b/makedevs.c
index 5072095..99dbc0b 100644
--- a/makedevs.c
+++ b/makedevs.c
@@ -16,23 +16,6 @@
 #include <sys/types.h>
 #include <sys/stat.h>
 
-static const char makedevs_usage[] =
-	"makedevs NAME TYPE MAJOR MINOR FIRST LAST [s]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreates a range of block or character special files\n\n"
-	"TYPEs include:\n"
-	"\tb:\tMake a block (buffered) device.\n"
-	"\tc or u:\tMake a character (un-buffered) device.\n"
-	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n\n"
-	"FIRST specifies the number appended to NAME to create the first device.\n"
-	"LAST specifies the number of the last item that should be created.\n"
-	"If 's' is the last argument, the base device is created as well.\n\n"
-	"For example:\n"
-	"\tmakedevs /dev/ttyS c 4 66 2 63   ->  ttyS2-ttyS63\n"
-	"\tmakedevs /dev/hda b 3 0 0 8 s    ->  hda,hda1-hda8\n"
-#endif
-	;
-
 int makedevs_main(int argc, char **argv)
 {
 
diff --git a/md5sum.c b/md5sum.c
index e6f1c86..fad563f 100644
--- a/md5sum.c
+++ b/md5sum.c
@@ -582,23 +582,6 @@
 static int warn = 0; /* With -w, print a message to standard error warning
                         about each improperly formatted MD5 checksum line */
 
-static const char md5sum_usage[] =
-    "md5sum [OPTION] [FILE]...\n"
-    "or:    md5sum [OPTION] -c [FILE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-    "\nPrint or check MD5 checksums.\n\n"
-    "Options:\n"
-    "With no FILE, or when FILE is -, read standard input.\n\n"
-    "\t-b\tread files in binary mode\n"
-    "\t-c\tcheck MD5 sums against given list\n"
-    "\t-t\tread files in text mode (default)\n"
-    "\t-g\tread a string\n"
-    "\nThe following two options are useful only when verifying checksums:\n"
-    "\t-s,\tdon't output anything, status code shows success\n"
-    "\t-w,\twarn about improperly formated MD5 checksum lines\n"
-#endif
-;
-
 static int split_3(char *s,
                    size_t s_len,
                    unsigned char **u,
diff --git a/miscutils/dc.c b/miscutils/dc.c
index 7b13cb9..fac48e8 100644
--- a/miscutils/dc.c
+++ b/miscutils/dc.c
@@ -8,14 +8,6 @@
 
 /* Tiny RPN calculator, because "expr" didn't give me bitwise operations. */
 
-static const char dc_usage[] = "dc expression ...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-		"\nThis is a Tiny RPN calculator that understands the\n"
-		"following operations: +, -, /, *, and, or, not, eor.\n"
-		"i.e. 'dc 2 2 add' -> 4, and 'dc 8 8 \\* 2 2 + /' -> 16\n"
-#endif
-		;
-
 static double stack[100];
 static unsigned int pointer;
 
diff --git a/miscutils/dutmp.c b/miscutils/dutmp.c
index c6bc0c7..047b880 100644
--- a/miscutils/dutmp.c
+++ b/miscutils/dutmp.c
@@ -23,14 +23,6 @@
 #include "messages.c"
 #include <utmp.h>
 
-
-static const char dutmp_usage[] = "dutmp [FILE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDump utmp file format (pipe delimited) from FILE\n"
-	"or stdin to stdout.  (i.e. 'dutmp /var/run/utmp')\n"
-#endif
-	;
-
 extern int dutmp_main(int argc, char **argv)
 {
 
diff --git a/miscutils/makedevs.c b/miscutils/makedevs.c
index 5072095..99dbc0b 100644
--- a/miscutils/makedevs.c
+++ b/miscutils/makedevs.c
@@ -16,23 +16,6 @@
 #include <sys/types.h>
 #include <sys/stat.h>
 
-static const char makedevs_usage[] =
-	"makedevs NAME TYPE MAJOR MINOR FIRST LAST [s]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreates a range of block or character special files\n\n"
-	"TYPEs include:\n"
-	"\tb:\tMake a block (buffered) device.\n"
-	"\tc or u:\tMake a character (un-buffered) device.\n"
-	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n\n"
-	"FIRST specifies the number appended to NAME to create the first device.\n"
-	"LAST specifies the number of the last item that should be created.\n"
-	"If 's' is the last argument, the base device is created as well.\n\n"
-	"For example:\n"
-	"\tmakedevs /dev/ttyS c 4 66 2 63   ->  ttyS2-ttyS63\n"
-	"\tmakedevs /dev/hda b 3 0 0 8 s    ->  hda,hda1-hda8\n"
-#endif
-	;
-
 int makedevs_main(int argc, char **argv)
 {
 
diff --git a/miscutils/mktemp.c b/miscutils/mktemp.c
index 247d16d..2ec0785 100644
--- a/miscutils/mktemp.c
+++ b/miscutils/mktemp.c
@@ -26,14 +26,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-const char mktemp_usage[] =
-	"mktemp [-q] TEMPLATE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreates a temporary file with its name based on TEMPLATE.\n"
-	"TEMPLATE is any name with six `Xs' (i.e. /tmp/temp.XXXXXX).\n"
-#endif
-	;
-
 extern int mktemp_main(int argc, char **argv)
 {
 	if (argc != 2 && (argc != 3 || strcmp(argv[1], "-q")))
diff --git a/miscutils/mt.c b/miscutils/mt.c
index 4ab4782..087819e 100644
--- a/miscutils/mt.c
+++ b/miscutils/mt.c
@@ -4,12 +4,6 @@
 #include <sys/mtio.h>
 #include <sys/fcntl.h>
 
-static const char mt_usage[] = "mt [-f device] opcode value\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-			"\nControl magnetic tape drive operation\n"
-#endif
-			;
-
 struct mt_opcodes {
 	char *name;
 	short value;
diff --git a/miscutils/update.c b/miscutils/update.c
index f943461..0bdc90e 100644
--- a/miscutils/update.c
+++ b/miscutils/update.c
@@ -34,18 +34,6 @@
 static _syscall2(int, bdflush, int, func, int, data);
 #endif							/* __GLIBC__ */
 
-
-static char update_usage[] =
-	"update [options]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPeriodically flushes filesystem buffers.\n\n"
-	"Options:\n"
-	"\t-S\tforce use of sync(2) instead of flushing\n"
-	"\t-s SECS\tcall sync this often (default 30)\n"
-	"\t-f SECS\tflush some buffers this often (default 5)\n"
-#endif
-	;
-
 static unsigned int sync_duration = 30;
 static unsigned int flush_duration = 5;
 static int use_sync = 0;
diff --git a/mkdir.c b/mkdir.c
index f6e08ca..f824cdc 100644
--- a/mkdir.c
+++ b/mkdir.c
@@ -29,18 +29,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-static const char mkdir_usage[] =
-	"mkdir [OPTION] DIRECTORY...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate the DIRECTORY(ies), if they do not already exist\n\n"
-	"Options:\n"
-
-	"\t-m\tset permission mode (as in chmod), not rwxrwxrwx - umask\n"
-	"\t-p\tno error if existing, make parent directories as needed\n"
-#endif
-	;
-
-
 static int parentFlag = FALSE;
 static mode_t mode = 0777;
 
diff --git a/mkfifo.c b/mkfifo.c
index f701a97..3db17bb 100644
--- a/mkfifo.c
+++ b/mkfifo.c
@@ -26,14 +26,6 @@
 #include <sys/stat.h>
 #include <errno.h>
 
-static const char mkfifo_usage[] = "mkfifo [OPTIONS] name\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreates a named pipe (identical to 'mknod name p')\n\n"
-	"Options:\n"
-	"\t-m\tcreate the pipe using the specified mode (default a=rw)\n"
-#endif
-	;
-
 extern int mkfifo_main(int argc, char **argv)
 {
 	char *thisarg;
diff --git a/mkfs_minix.c b/mkfs_minix.c
index 9ae4b56..dec310d 100644
--- a/mkfs_minix.c
+++ b/mkfs_minix.c
@@ -267,19 +267,6 @@
 	exit(8);
 }
 
-const char mkfs_minix_usage[] =
-	"mkfs.minix [-c | -l filename] [-nXX] [-iXX] /dev/name [blocks]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nMake a MINIX filesystem.\n\n"
-	"Options:\n"
-	"\t-c\t\tCheck the device for bad blocks\n"
-	"\t-n [14|30]\tSpecify the maximum length of filenames\n"
-	"\t-i INODES\tSpecify the number of inodes for the filesystem\n"
-	"\t-l FILENAME\tRead the bad blocks list from FILENAME\n"
-	"\t-v\t\tMake a Minix version 2 filesystem\n\n"
-#endif
-	;
-
 static volatile void show_usage() __attribute__ ((noreturn));
 static volatile void show_usage()
 {
diff --git a/mknod.c b/mknod.c
index ac96817..b51c8f3 100644
--- a/mknod.c
+++ b/mknod.c
@@ -28,18 +28,6 @@
 #include <fcntl.h>
 #include <unistd.h>
 
-static const char mknod_usage[] = "mknod [OPTIONS] NAME TYPE MAJOR MINOR\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate a special file (block, character, or pipe).\n\n"
-	"Options:\n"
-	"\t-m\tcreate the special file using the specified mode (default a=rw)\n\n"
-	"TYPEs include:\n"
-	"\tb:\tMake a block (buffered) device.\n"
-	"\tc or u:\tMake a character (un-buffered) device.\n"
-	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n"
-#endif
-	;
-
 int mknod_main(int argc, char **argv)
 {
 	char *thisarg;
diff --git a/mkswap.c b/mkswap.c
index 5a33945..eacd881 100644
--- a/mkswap.c
+++ b/mkswap.c
@@ -47,20 +47,6 @@
 #include <asm/page.h>			/* for PAGE_SIZE and PAGE_SHIFT */
 				/* we also get PAGE_SIZE via getpagesize() */
 
-
-static const char mkswap_usage[] =
-	"mkswap [-c] [-v0|-v1] device [block-count]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrepare a disk partition to be used as a swap partition.\n\n"
-	"Options:\n" "\t-c\t\tCheck for read-ability.\n"
-	"\t-v0\t\tMake version 0 swap [max 128 Megs].\n"
-	"\t-v1\t\tMake version 1 swap [big!] (default for kernels > 2.1.117).\n"
-
-	"\tblock-count\tNumber of block to use (default is entire partition).\n"
-#endif
-	;
-
-
 #ifndef _IO
 /* pre-1.3.45 */
 #define BLKGETSIZE 0x1260
diff --git a/mktemp.c b/mktemp.c
index 247d16d..2ec0785 100644
--- a/mktemp.c
+++ b/mktemp.c
@@ -26,14 +26,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-const char mktemp_usage[] =
-	"mktemp [-q] TEMPLATE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreates a temporary file with its name based on TEMPLATE.\n"
-	"TEMPLATE is any name with six `Xs' (i.e. /tmp/temp.XXXXXX).\n"
-#endif
-	;
-
 extern int mktemp_main(int argc, char **argv)
 {
 	if (argc != 2 && (argc != 3 || strcmp(argv[1], "-q")))
diff --git a/modutils/insmod.c b/modutils/insmod.c
index 97c360b..9daedf9 100644
--- a/modutils/insmod.c
+++ b/modutils/insmod.c
@@ -70,7 +70,7 @@
 #ifndef MODUTILS_MODULE_H
 #define MODUTILS_MODULE_H 1
 
-#ident "$Id: insmod.c,v 1.17 2000/07/14 16:23:32 proski Exp $"
+#ident "$Id: insmod.c,v 1.18 2000/07/16 20:57:15 kraai Exp $"
 
 /* This file contains the structures used by the 2.0 and 2.1 kernels.
    We do not use the kernel headers directly because we do not wish
@@ -276,7 +276,7 @@
 #ifndef MODUTILS_OBJ_H
 #define MODUTILS_OBJ_H 1
 
-#ident "$Id: insmod.c,v 1.17 2000/07/14 16:23:32 proski Exp $"
+#ident "$Id: insmod.c,v 1.18 2000/07/16 20:57:15 kraai Exp $"
 
 /* The relocatable object is manipulated using elfin types.  */
 
@@ -560,16 +560,6 @@
 #endif
 static char m_filename[BUFSIZ + 1] = "\0";
 static char m_fullName[BUFSIZ + 1] = "\0";
-static const char insmod_usage[] =
-	"insmod [OPTION]... MODULE [symbol=value]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLoads the specified kernel modules into the kernel.\n\n"
-	"Options:\n"
-	"\t-f\tForce module to load into the wrong kernel version.\n"
-	"\t-k\tMake module autoclean-able.\n"
-	"\t-v\tverbose output\n" "\t-x\tdo not export externs\n"
-#endif
-;
 
 /*======================================================================*/
 
diff --git a/modutils/rmmod.c b/modutils/rmmod.c
index 3158686..da10b7f 100644
--- a/modutils/rmmod.c
+++ b/modutils/rmmod.c
@@ -32,18 +32,6 @@
 /* And the system call of the day is...  */
 _syscall1(int, delete_module, const char *, name)
 
-
-static const char rmmod_usage[] =
-	"rmmod [OPTION]... [MODULE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nUnloads the specified kernel modules from the kernel.\n\n"
-	"Options:\n" 
-	"\t-a\tTry to remove all unused kernel modules.\n"
-#endif
-	;
-
-
-
 extern int rmmod_main(int argc, char **argv)
 {
 	if (argc <= 1) {
diff --git a/more.c b/more.c
index 91c2815..2334576 100644
--- a/more.c
+++ b/more.c
@@ -34,12 +34,6 @@
 #define bb_need_help
 #include "messages.c"
 
-static const char more_usage[] = "more [FILE ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nMore is a filter for viewing FILE one screenful at a time.\n"
-#endif
-	;
-
 /* ED: sparc termios is broken: revert back to old termio handling. */
 #ifdef BB_FEATURE_USE_TERMIOS
 #	if #cpu(sparc)
diff --git a/mount.c b/mount.c
index addeb09..610d12d 100644
--- a/mount.c
+++ b/mount.c
@@ -80,38 +80,6 @@
 
 extern const char mtab_file[];	/* Defined in utility.c */
 
-static const char mount_usage[] = 
-	"mount [flags] device directory [-o options,more-options]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nMount a filesystem\n\n"
-	"Flags:\n" 
-	"\t-a:\t\tMount all filesystems in fstab.\n"
-#ifdef BB_MTAB
-	"\t-f:\t\t\"Fake\" mount. Add entry to mount table but don't mount it.\n"
-	"\t-n:\t\tDon't write a mount table entry.\n"
-#endif
-	"\t-o option:\tOne of many filesystem options, listed below.\n"
-	"\t-r:\t\tMount the filesystem read-only.\n"
-	"\t-t fs-type:\tSpecify the filesystem type.\n"
-	"\t-w:\t\tMount for reading and writing (default).\n"
-	"\n"
-	"Options for use with the \"-o\" flag:\n"
-	"\tasync/sync:\tWrites are asynchronous / synchronous.\n"
-	"\tatime/noatime:\tEnable / disable updates to inode access times.\n"
-	"\tdev/nodev:\tAllow use of special device files / disallow them.\n"
-	"\texec/noexec:\tAllow use of executable files / disallow them.\n"
-#if defined BB_FEATURE_MOUNT_LOOP
-	"\tloop:\t\tMounts a file via loop device.\n"
-#endif
-	"\tsuid/nosuid:\tAllow set-user-id-root programs / disallow them.\n"
-	"\tremount:\tRe-mount a currently-mounted filesystem, changing its flags.\n"
-	"\tro/rw:\t\tMount for read-only / read-write.\n"
-	"\nThere are EVEN MORE flags that are specific to each filesystem.\n"
-	"You'll have to see the written documentation for those.\n"
-#endif
-	;
-
-
 struct mount_options {
 	const char *name;
 	unsigned long and;
diff --git a/mt.c b/mt.c
index 4ab4782..087819e 100644
--- a/mt.c
+++ b/mt.c
@@ -4,12 +4,6 @@
 #include <sys/mtio.h>
 #include <sys/fcntl.h>
 
-static const char mt_usage[] = "mt [-f device] opcode value\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-			"\nControl magnetic tape drive operation\n"
-#endif
-			;
-
 struct mt_opcodes {
 	char *name;
 	short value;
diff --git a/nc.c b/nc.c
index b6afe6f..a544f32 100644
--- a/nc.c
+++ b/nc.c
@@ -40,12 +40,6 @@
 
 #define BUFSIZE 100
 
-static const char nc_usage[] = "nc [IP] [port]\n" 
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nNetcat opens a pipe to IP:port\n"
-#endif
-	;
-
 int nc_main(int argc, char **argv)
 {
 	int sfd;
diff --git a/networking/hostname.c b/networking/hostname.c
index 60f66c0..77b545d 100644
--- a/networking/hostname.c
+++ b/networking/hostname.c
@@ -1,6 +1,6 @@
 /* vi: set sw=4 ts=4: */
 /*
- * $Id: hostname.c,v 1.11 2000/07/14 01:51:25 kraai Exp $
+ * $Id: hostname.c,v 1.12 2000/07/16 20:57:15 kraai Exp $
  * Mini hostname implementation for busybox
  *
  * Copyright (C) 1999 by Randolph Chung <tausq@debian.org>
@@ -30,21 +30,6 @@
 #include <unistd.h>
 #include <stdio.h>
 
-static const char *hostname_usage =
-	"hostname [OPTION] {hostname | -F file}\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nGet or set the hostname or DNS domain name. If a hostname is given\n"
-	"(or a file with the -F parameter), the host name will be set.\n\n"
-	"Options:\n"
-	"\t-s\t\tShort\n"
-
-	"\t-i\t\tAddresses for the hostname\n"
-	"\t-d\t\tDNS domain name\n"
-	"\t-F FILE\t\tUse the contents of FILE to specify the hostname\n"
-#endif
-	;
-
-
 void do_sethostname(char *s, int isfile)
 {
 	FILE *f;
diff --git a/networking/nc.c b/networking/nc.c
index b6afe6f..a544f32 100644
--- a/networking/nc.c
+++ b/networking/nc.c
@@ -40,12 +40,6 @@
 
 #define BUFSIZE 100
 
-static const char nc_usage[] = "nc [IP] [port]\n" 
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nNetcat opens a pipe to IP:port\n"
-#endif
-	;
-
 int nc_main(int argc, char **argv)
 {
 	int sfd;
diff --git a/networking/nslookup.c b/networking/nslookup.c
index 54f37c8..10d36b2 100644
--- a/networking/nslookup.c
+++ b/networking/nslookup.c
@@ -41,13 +41,6 @@
  |  + find out how the real nslookup gets the default name server
  */
 
-static const char nslookup_usage[] = "nslookup [HOST]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nQueries the nameserver for the IP address of the given HOST\n"
-#endif
-;
-
-
 /* I have to see how the real nslookup does this.
  * I could dig through /etc/resolv.conf, but is there a
  * better (programatic) way?
@@ -177,4 +170,4 @@
 	return( TRUE);
 }
 
-/* $Id: nslookup.c,v 1.10 2000/06/19 17:25:40 andersen Exp $ */
+/* $Id: nslookup.c,v 1.11 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/networking/ping.c b/networking/ping.c
index b2b4880..5f44a68 100644
--- a/networking/ping.c
+++ b/networking/ping.c
@@ -1,6 +1,6 @@
 /* vi: set sw=4 ts=4: */
 /*
- * $Id: ping.c,v 1.22 2000/07/14 06:49:52 andersen Exp $
+ * $Id: ping.c,v 1.23 2000/07/16 20:57:15 kraai Exp $
  * Mini ping implementation for busybox
  *
  * Copyright (C) 1999 by Randolph Chung <tausq@debian.org>
@@ -174,12 +174,6 @@
 
 /* simple version */
 #ifdef BB_FEATURE_SIMPLE_PING
-static const char *ping_usage = "ping host\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend ICMP ECHO_REQUEST packets to network hosts\n"
-#endif
-	;
-
 static char *hostname = NULL;
 
 static void noresp(int ign)
@@ -267,17 +261,6 @@
 
 #else /* ! BB_FEATURE_SIMPLE_PING */
 /* full(er) version */
-static const char *ping_usage = "ping [OPTION]... host\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend ICMP ECHO_REQUEST packets to network hosts.\n\n"
-	"Options:\n"
-	"\t-c COUNT\tSend only COUNT pings.\n"
-	"\t-s SIZE\t\tSend SIZE data bytes in packets (default=56).\n"
-	"\t-q\t\tQuiet mode, only displays output at start\n"
-	"\t\t\tand when finished.\n"
-#endif
-	;
-
 static char *hostname = NULL;
 static struct sockaddr_in pingaddr;
 static int pingsock = -1;
diff --git a/networking/telnet.c b/networking/telnet.c
index f276035..3e43c4a 100644
--- a/networking/telnet.c
+++ b/networking/telnet.c
@@ -134,14 +134,6 @@
 
 /* Some globals */
 static int one = 1;
-static const char telnet_usage[] =
-	"telnet host [port]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nTelnet is used to establish interactive communication with another\n"
-	"computer over a network using the TELNET protocol.\n"
-#endif
-	;
-
 
 static void doexit(int ev)
 {
diff --git a/nslookup.c b/nslookup.c
index 54f37c8..10d36b2 100644
--- a/nslookup.c
+++ b/nslookup.c
@@ -41,13 +41,6 @@
  |  + find out how the real nslookup gets the default name server
  */
 
-static const char nslookup_usage[] = "nslookup [HOST]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nQueries the nameserver for the IP address of the given HOST\n"
-#endif
-;
-
-
 /* I have to see how the real nslookup does this.
  * I could dig through /etc/resolv.conf, but is there a
  * better (programatic) way?
@@ -177,4 +170,4 @@
 	return( TRUE);
 }
 
-/* $Id: nslookup.c,v 1.10 2000/06/19 17:25:40 andersen Exp $ */
+/* $Id: nslookup.c,v 1.11 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/ping.c b/ping.c
index b2b4880..5f44a68 100644
--- a/ping.c
+++ b/ping.c
@@ -1,6 +1,6 @@
 /* vi: set sw=4 ts=4: */
 /*
- * $Id: ping.c,v 1.22 2000/07/14 06:49:52 andersen Exp $
+ * $Id: ping.c,v 1.23 2000/07/16 20:57:15 kraai Exp $
  * Mini ping implementation for busybox
  *
  * Copyright (C) 1999 by Randolph Chung <tausq@debian.org>
@@ -174,12 +174,6 @@
 
 /* simple version */
 #ifdef BB_FEATURE_SIMPLE_PING
-static const char *ping_usage = "ping host\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend ICMP ECHO_REQUEST packets to network hosts\n"
-#endif
-	;
-
 static char *hostname = NULL;
 
 static void noresp(int ign)
@@ -267,17 +261,6 @@
 
 #else /* ! BB_FEATURE_SIMPLE_PING */
 /* full(er) version */
-static const char *ping_usage = "ping [OPTION]... host\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend ICMP ECHO_REQUEST packets to network hosts.\n\n"
-	"Options:\n"
-	"\t-c COUNT\tSend only COUNT pings.\n"
-	"\t-s SIZE\t\tSend SIZE data bytes in packets (default=56).\n"
-	"\t-q\t\tQuiet mode, only displays output at start\n"
-	"\t\t\tand when finished.\n"
-#endif
-	;
-
 static char *hostname = NULL;
 static struct sockaddr_in pingaddr;
 static int pingsock = -1;
diff --git a/printf.c b/printf.c
index f572897..6a87fc3 100644
--- a/printf.c
+++ b/printf.c
@@ -137,13 +137,6 @@
 /* The value to return to the calling program.  */
 static int exit_status;
 
-static const char printf_usage[] = "printf FORMAT [ARGUMENT...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nFormats and prints ARGUMENT(s) according to FORMAT,\n"
-	"Where FORMAT controls the output exactly as in C printf.\n"
-#endif
-	;
-
 int printf_main(int argc, char **argv)
 {
 	char *format;
diff --git a/procps/free.c b/procps/free.c
index 7c9d7f1..78298cf 100644
--- a/procps/free.c
+++ b/procps/free.c
@@ -25,13 +25,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-const char free_usage[] =
-	"free\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDisplays the amount of free and used system memory\n"
-#endif
-	;
-
 extern int free_main(int argc, char **argv)
 {
 	struct sysinfo info;
diff --git a/procps/kill.c b/procps/kill.c
index 44cb383..da46620 100644
--- a/procps/kill.c
+++ b/procps/kill.c
@@ -31,24 +31,6 @@
 #include <sys/stat.h>
 #include <unistd.h>
 
-static const char *kill_usage =
-	"kill [-signal] process-id [process-id ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
-	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
-#endif
-	;
-
-#ifdef BB_KILLALL
-static const char *killall_usage =
-	"killall [-signal] process-name [process-name ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
-	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
-#endif
-#endif
-	;
-
 #define KILL	0
 #define KILLALL	1
 
diff --git a/procps/ps.c b/procps/ps.c
index 74e79f5..fc58a9b 100644
--- a/procps/ps.c
+++ b/procps/ps.c
@@ -114,14 +114,6 @@
 
 }
 
-const char ps_usage[] =
-	"ps\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nReport process status\n"
-	"\nThis version of ps accepts no options.\n"
-#endif
-	;
-
 extern int ps_main(int argc, char **argv)
 {
 	proc_t p;
diff --git a/ps.c b/ps.c
index 74e79f5..fc58a9b 100644
--- a/ps.c
+++ b/ps.c
@@ -114,14 +114,6 @@
 
 }
 
-const char ps_usage[] =
-	"ps\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nReport process status\n"
-	"\nThis version of ps accepts no options.\n"
-#endif
-	;
-
 extern int ps_main(int argc, char **argv)
 {
 	proc_t p;
diff --git a/rm.c b/rm.c
index 2067d87..275c059 100644
--- a/rm.c
+++ b/rm.c
@@ -29,17 +29,6 @@
 #include <dirent.h>
 #include <errno.h>
 
-static const char *rm_usage = "rm [OPTION]... FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRemove (unlink) the FILE(s).  You may use '--' to\n"
-	"indicate that all following arguments are non-options.\n\n"
-	"Options:\n"
-	"\t-f\t\tremove existing destinations, never prompt\n"
-	"\t-r or -R\tremove the contents of directories recursively\n"
-#endif
-	;
-
-
 static int recursiveFlag = FALSE;
 static int forceFlag = FALSE;
 static const char *srcName;
diff --git a/rmdir.c b/rmdir.c
index 3c3533f..500890e 100644
--- a/rmdir.c
+++ b/rmdir.c
@@ -26,13 +26,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-const char rmdir_usage[] =
-	"rmdir [OPTION]... DIRECTORY...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRemove the DIRECTORY(ies), if they are empty.\n"
-#endif
-	;
-
 extern int rmdir_main(int argc, char **argv)
 {
 	if (argc == 1 || **(argv + 1) == '-')
diff --git a/rmmod.c b/rmmod.c
index 3158686..da10b7f 100644
--- a/rmmod.c
+++ b/rmmod.c
@@ -32,18 +32,6 @@
 /* And the system call of the day is...  */
 _syscall1(int, delete_module, const char *, name)
 
-
-static const char rmmod_usage[] =
-	"rmmod [OPTION]... [MODULE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nUnloads the specified kernel modules from the kernel.\n\n"
-	"Options:\n" 
-	"\t-a\tTry to remove all unused kernel modules.\n"
-#endif
-	;
-
-
-
 extern int rmmod_main(int argc, char **argv)
 {
 	if (argc <= 1) {
diff --git a/sed.c b/sed.c
index 1f1e906..4d4886e 100644
--- a/sed.c
+++ b/sed.c
@@ -85,22 +85,6 @@
 
 /*static char *cur_file = NULL;*/ /* file currently being processed XXX: do I need this? */
 
-static const char sed_usage[] =
-	"sed [-Vhnef] pattern [files...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\n"
-	"-n\tsuppress automatic printing of pattern space\n"
-	"-e script\tadd the script to the commands to be executed\n"
-	"-f scriptfile\tadd the contents of script-file to the commands to be executed\n"
-	"-h\tdisplay this help message\n"
-	"-V\toutput version information and exit\n"
-	"\n"
-	"If no -e or -f is given, the first non-option argument is taken as the\n"
-	"sed script to interpret. All remaining arguments are names of input\n"
-	"files; if no input files are specified, then the standard input is read.\n"
-#endif
-	;
-
 #if 0
 static void destroy_cmd_strs()
 {
diff --git a/setkeycodes.c b/setkeycodes.c
index 1bdb909..284ffa1 100644
--- a/setkeycodes.c
+++ b/setkeycodes.c
@@ -35,17 +35,6 @@
 };
 #define KDSETKEYCODE    0x4B4D  /* write kernel keycode table entry */
 
-
-static const char setkeycodes_usage[] =
-	"setkeycodes SCANCODE KEYCODE ...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nSet entries into the kernel's scancode-to-keycode map,\n"
-	"allowing unusual keyboards to generate usable keycodes.\n\n" 
-	"SCANCODE may be either xx or e0xx (hexadecimal),\n"
-	"and KEYCODE is given in decimal\n"
-#endif
-	;
-
 extern int 
 setkeycodes_main(int argc, char** argv)
 {
diff --git a/sh.c b/sh.c
index d829b6b..9b34353 100644
--- a/sh.c
+++ b/sh.c
@@ -137,14 +137,6 @@
 	{NULL, NULL, NULL, NULL}
 };
 
-static const char shell_usage[] =
-	"sh [FILE]...\n"
-	"   or: sh -c command [args]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nlash: The BusyBox command interpreter (shell).\n\n"
-#endif
-	;
-
 static char *prompt = "# ";
 static char *cwd = NULL;
 static char *local_pending_command = NULL;
diff --git a/shell/lash.c b/shell/lash.c
index d829b6b..9b34353 100644
--- a/shell/lash.c
+++ b/shell/lash.c
@@ -137,14 +137,6 @@
 	{NULL, NULL, NULL, NULL}
 };
 
-static const char shell_usage[] =
-	"sh [FILE]...\n"
-	"   or: sh -c command [args]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nlash: The BusyBox command interpreter (shell).\n\n"
-#endif
-	;
-
 static char *prompt = "# ";
 static char *cwd = NULL;
 static char *local_pending_command = NULL;
diff --git a/sleep.c b/sleep.c
index c7ab32d..d6705c4 100644
--- a/sleep.c
+++ b/sleep.c
@@ -24,12 +24,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char sleep_usage[] = "sleep N\n" 
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPause for N seconds.\n"
-#endif
-	;
-
 extern int sleep_main(int argc, char **argv)
 {
 	if ((argc < 2) || (**(argv + 1) == '-')) {
diff --git a/sort.c b/sort.c
index c754989..6af5c4d 100644
--- a/sort.c
+++ b/sort.c
@@ -29,16 +29,6 @@
 #include <stdio.h>
 #include <errno.h>
 
-static const char sort_usage[] = "sort [-n]"
-#ifdef BB_FEATURE_SORT_REVERSE
-" [-r]"
-#endif
-" [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-"\nSorts lines of text in the specified files\n"
-#endif
-;
-
 #ifdef BB_FEATURE_SORT_REVERSE
 #define APPLY_REVERSE(x) (reverse ? -(x) : (x))
 static int reverse = 0;
@@ -304,4 +294,4 @@
 	return(0);
 }
 
-/* $Id: sort.c,v 1.19 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: sort.c,v 1.20 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/swaponoff.c b/swaponoff.c
index a79b93a..6aafe51 100644
--- a/swaponoff.c
+++ b/swaponoff.c
@@ -35,25 +35,6 @@
 
 static int whichApp;
 
-static const char swapoff_usage[] =
-	"swapoff [OPTION] [device]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStop swapping virtual memory pages on the given device.\n\n"
-	"Options:\n"
-	"\t-a\tStop swapping on all swap devices\n"
-#endif
-	;
-
-static const char swapon_usage[] =
-	"swapon [OPTION] [device]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStart swapping virtual memory pages on the given device.\n\n"
-	"Options:\n"
-	"\t-a\tStart swapping on all swap devices\n"
-#endif
-	;
-
-
 #define SWAPON_APP   1
 #define SWAPOFF_APP  2
 
diff --git a/sync.c b/sync.c
index f7c14b0..3737cb1 100644
--- a/sync.c
+++ b/sync.c
@@ -24,13 +24,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char sync_usage[] =
-	"sync\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nWrite all buffered filesystem blocks to disk.\n"
-#endif
-	;
-
 extern int sync_main(int argc, char **argv)
 {
 	if (argc > 1 && **(argv + 1) == '-')
diff --git a/sysklogd/logger.c b/sysklogd/logger.c
index 981748b..0e1ce8d 100644
--- a/sysklogd/logger.c
+++ b/sysklogd/logger.c
@@ -47,20 +47,6 @@
 extern CODE facilitynames[];
 #endif
 
-static const char logger_usage[] =
-	"logger [OPTION]... [MESSAGE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nWrite MESSAGE to the system log.  If MESSAGE is '-', log stdin.\n\n"
-	"Options:\n"
-	"\t-s\tLog to stderr as well as the system log.\n"
-	"\t-t\tLog using the specified tag (defaults to user name).\n"
-
-	"\t-p\tEnter the message with the specified priority.\n"
-	"\t\tThis may be numerical or a ``facility.level'' pair.\n"
-#endif
-	;
-
-
 /* Decode a symbolic name to a numeric value 
  * this function is based on code
  * Copyright (c) 1983, 1993
diff --git a/sysklogd/syslogd.c b/sysklogd/syslogd.c
index 55fd8dc..264d899 100644
--- a/sysklogd/syslogd.c
+++ b/sysklogd/syslogd.c
@@ -76,21 +76,6 @@
 /* localhost's name */
 static char LocalHostName[32];
 
-static const char syslogd_usage[] =
-	"syslogd [OPTION]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLinux system and kernel (provides klogd) logging utility.\n"
-	"Note that this version of syslogd/klogd ignores /etc/syslog.conf.\n\n"
-	"Options:\n"
-	"\t-m NUM\t\tInterval between MARK lines (default=20min, 0=off)\n"
-	"\t-n\t\tRun as a foreground process\n"
-#ifdef BB_FEATURE_KLOGD
-	"\t-K\t\tDo not start up the klogd process\n"
-#endif
-	"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
-#endif
-	;
-
 /* Note: There is also a function called "message()" in init.c */
 /* Print a message to the log file. */
 static void message (char *fmt, ...) __attribute__ ((format (printf, 1, 2)));
diff --git a/syslogd.c b/syslogd.c
index 55fd8dc..264d899 100644
--- a/syslogd.c
+++ b/syslogd.c
@@ -76,21 +76,6 @@
 /* localhost's name */
 static char LocalHostName[32];
 
-static const char syslogd_usage[] =
-	"syslogd [OPTION]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLinux system and kernel (provides klogd) logging utility.\n"
-	"Note that this version of syslogd/klogd ignores /etc/syslog.conf.\n\n"
-	"Options:\n"
-	"\t-m NUM\t\tInterval between MARK lines (default=20min, 0=off)\n"
-	"\t-n\t\tRun as a foreground process\n"
-#ifdef BB_FEATURE_KLOGD
-	"\t-K\t\tDo not start up the klogd process\n"
-#endif
-	"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
-#endif
-	;
-
 /* Note: There is also a function called "message()" in init.c */
 /* Print a message to the log file. */
 static void message (char *fmt, ...) __attribute__ ((format (printf, 1, 2)));
diff --git a/tail.c b/tail.c
index 9232356..cea63e8 100644
--- a/tail.c
+++ b/tail.c
@@ -72,21 +72,6 @@
 /* If nonzero, print filename headers.  */
 static int print_headers;
 
-const char tail_usage[] =
-	"tail [OPTION] [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint last 10 lines of each FILE to standard output.\n"
-	"With more than one FILE, precede each with a header giving the\n"
-	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
-	"Options:\n"
-	"\t-n NUM\t\tPrint last NUM lines instead of first 10\n"
-
-	"\t-f\t\tOutput data as the file grows.  This version\n"
-	"\t\t\tof 'tail -f' supports only one file at a time.\n"
-#endif
-	;
-
-
 static void write_header(const char *filename)
 {
 	static int first_file = 1;
@@ -516,25 +501,6 @@
 /* Nonzero if we have ever read standard input.  */
 static int have_read_stdin;
 
-
-static const char tail_usage[] = "tail [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-"\nPrint last 10 lines of each FILE to standard output.\n\
-With more than one FILE, precede each with a header giving the file name.\n\
-With no FILE, or when FILE is -, read standard input.\n\
-\n\
-  -c=N[kbm]       output the last N bytes\n\
-  -f              output appended data as the file grows\n\
-  -n=N            output the last N lines, instead of last 10\n\
-  -q              never output headers giving file names\n\
-  -v              always output headers giving file names\n\
-\n\
-If the first character of N (bytes or lines) is a `+', output begins with \n\
-the Nth item from the start of each file, otherwise, print the last N items\n\
-in the file.  N bytes may be suffixed by k (x1024), b (x512), or m (1024^2).\n"
-#endif
-;
-
 static void write_header(const char *filename, const char *comment)
 {
 	static int first_file = 1;
diff --git a/tar.c b/tar.c
index 353694f..6f18dc4 100644
--- a/tar.c
+++ b/tar.c
@@ -50,37 +50,6 @@
 #include <sys/types.h>
 #include <sys/sysmacros.h>
 
-
-static const char tar_usage[] =
-#ifdef BB_FEATURE_TAR_CREATE
-	"tar -[cxtvO] "
-#else
-	"tar -[xtvO] "
-#endif
-#if defined BB_FEATURE_TAR_EXCLUDE
-	"[--exclude File] "
-#endif
-	"[-f tarFile] [FILE] ...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCreate, extract, or list files from a tar file.  Note that\n"
-	"this version of tar treats hard links as separate files.\n\n"
-	"Main operation mode:\n"
-#ifdef BB_FEATURE_TAR_CREATE
-	"\tc\t\tcreate\n"
-#endif
-	"\tx\t\textract\n"
-	"\tt\t\tlist\n"
-	"\nFile selection:\n"
-	"\tf\t\tname of tarfile or \"-\" for stdin\n"
-	"\tO\t\textract to stdout\n"
-#if defined BB_FEATURE_TAR_EXCLUDE
-	"\t--exclude\tfile to exclude\n"
-#endif
-	"\nInformative output:\n"
-	"\tv\t\tverbosely list files processed\n"
-#endif
-	;
-
 /* Tar file constants  */
 #ifndef MAJOR
 #define MAJOR(dev) (((dev)>>8)&0xff)
diff --git a/tee.c b/tee.c
index 67b42a2..c15408b 100644
--- a/tee.c
+++ b/tee.c
@@ -26,18 +26,6 @@
 #include <errno.h>
 #include <stdio.h>
 
-static const char tee_usage[] =
-	"tee [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nCopy standard input to each FILE, and also to standard output.\n\n"
-	"Options:\n" "\t-a\tappend to the given FILEs, do not overwrite\n"
-#if 0
-	"\t-i\tignore interrupt signals\n"
-#endif
-#endif
-;
-
-
 /* FileList _______________________________________________________________ */
 
 #define FL_MAX	1024
@@ -133,4 +121,4 @@
 	return(0);
 }
 
-/* $Id: tee.c,v 1.12 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: tee.c,v 1.13 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/telnet.c b/telnet.c
index f276035..3e43c4a 100644
--- a/telnet.c
+++ b/telnet.c
@@ -134,14 +134,6 @@
 
 /* Some globals */
 static int one = 1;
-static const char telnet_usage[] =
-	"telnet host [port]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nTelnet is used to establish interactive communication with another\n"
-	"computer over a network using the TELNET protocol.\n"
-#endif
-	;
-
 
 static void doexit(int ev)
 {
diff --git a/test.c b/test.c
index bf1622c..9a1888b 100644
--- a/test.c
+++ b/test.c
@@ -178,15 +178,6 @@
 static int is_a_group_member();
 static void initialize_group_array();
 
-const char test_usage[] =
-	"test EXPRESSION\n"
-	"or   [ EXPRESSION ]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nChecks file types and compares values returning an exit\n"
-	"code determined by the value of EXPRESSION.\n"
-#endif
-	;
-
 extern int
 test_main(int argc, char** argv)
 {
diff --git a/touch.c b/touch.c
index ac27542..afdd265 100644
--- a/touch.c
+++ b/touch.c
@@ -30,16 +30,6 @@
 #include <utime.h>
 #include <errno.h>
 
-
-static const char touch_usage[] = "touch [-c] file [file ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nUpdate the last-modified date on the given file[s].\n\n"
-	"Options:\n"
-	"\t-c\tDo not create any files\n"
-#endif
-	;
-
-
 extern int touch_main(int argc, char **argv)
 {
 	int fd;
diff --git a/tr.c b/tr.c
index 2971ef6..0040924 100644
--- a/tr.c
+++ b/tr.c
@@ -34,19 +34,6 @@
 #define bb_need_write_error
 #include "messages.c"
 
-const char *tr_usage="tr [-cds] STRING1 [STRING2]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nTranslate, squeeze, and/or delete characters from\n"
-	"standard input, writing to standard output.\n\n"
-	"Options:\n"
-	"\t-c\ttake complement of STRING1\n"
-	"\t-d\tdelete input characters coded STRING1\n"
-	"\t-s\tsqueeze multiple output characters of STRING2 into one character\n"
-#endif
-;
-
-
-
 #ifdef TRUE
 #undef TRUE
 #undef FALSE
diff --git a/tty.c b/tty.c
index f3c7fb7..bbc051f 100644
--- a/tty.c
+++ b/tty.c
@@ -24,14 +24,6 @@
 #include <stdio.h>
 #include <sys/types.h>
 
-static const char tty_usage[] = "tty\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint the file name of the terminal connected to standard input.\n\n"
-	"Options:\n"
-	"\t-s\tprint nothing, only return an exit status\n"
-#endif
-	;
-
 extern int tty_main(int argc, char **argv)
 {
 	char *tty;
diff --git a/umount.c b/umount.c
index 1b250fd..df075f7 100644
--- a/umount.c
+++ b/umount.c
@@ -39,28 +39,6 @@
 extern int umount (__const char *__special_file);
 extern int umount2 (__const char *__special_file, int __flags);
 
-
-
-static const char umount_usage[] =
-	"umount [flags] filesystem|directory\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"Unmount file systems\n"
-	"\nFlags:\n" "\t-a:\tUnmount all file systems"
-#ifdef BB_MTAB
-	" in /etc/mtab\n\t-n:\tDon't erase /etc/mtab entries\n"
-#else
-	"\n"
-#endif
-	"\t-r:\tTry to remount devices as read-only if mount is busy\n"
-#if defined BB_FEATURE_MOUNT_FORCE
-	"\t-f:\tForce filesystem umount (i.e. unreachable NFS server)\n"
-#endif
-#if defined BB_FEATURE_MOUNT_LOOP
-	"\t-l:\tDo not free loop device (if a loop device has been used)\n"
-#endif
-#endif
-;
-
 struct _mtab_entry_t {
 	char *device;
 	char *mountpt;
diff --git a/uname.c b/uname.c
index b7c88ec..55616dd 100644
--- a/uname.c
+++ b/uname.c
@@ -40,24 +40,6 @@
 # include <sys/systeminfo.h>
 #endif
 
-
-static const char uname_usage[] =
-	"uname [OPTION]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint certain system information.  With no OPTION, same as -s.\n\n"
-	"Options:\n"
-	"\t-a\tprint all information\n"
-	"\t-m\tthe machine (hardware) type\n"
-	"\t-n\tprint the machine's network node hostname\n"
-	"\t-r\tprint the operating system release\n"
-	"\t-s\tprint the operating system name\n"
-
-	"\t-p\tprint the host processor type\n"
-	"\t-v\tprint the operating system version\n"
-#endif
-	;
-
-
 static void print_element(unsigned int mask, char *element);
 
 /* Values that are bitwise or'd into `toprint'. */
diff --git a/uniq.c b/uniq.c
index 16b2576..016fc77 100644
--- a/uniq.c
+++ b/uniq.c
@@ -27,14 +27,6 @@
 #include <string.h>
 #include <errno.h>
 
-static const char uniq_usage[] =
-	"uniq [OPTION]... [INPUT [OUTPUT]]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nDiscard all but one of successive identical lines from INPUT\n"
-	"(or standard input), writing to OUTPUT (or standard output).\n"
-#endif
-	;
-
 /* max chars in line */
 #define UNIQ_MAX 4096
 
@@ -187,4 +179,4 @@
 	return(0);
 }
 
-/* $Id: uniq.c,v 1.12 2000/07/14 01:51:25 kraai Exp $ */
+/* $Id: uniq.c,v 1.13 2000/07/16 20:57:15 kraai Exp $ */
diff --git a/update.c b/update.c
index f943461..0bdc90e 100644
--- a/update.c
+++ b/update.c
@@ -34,18 +34,6 @@
 static _syscall2(int, bdflush, int, func, int, data);
 #endif							/* __GLIBC__ */
 
-
-static char update_usage[] =
-	"update [options]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPeriodically flushes filesystem buffers.\n\n"
-	"Options:\n"
-	"\t-S\tforce use of sync(2) instead of flushing\n"
-	"\t-s SECS\tcall sync this often (default 30)\n"
-	"\t-f SECS\tflush some buffers this often (default 5)\n"
-#endif
-	;
-
 static unsigned int sync_duration = 30;
 static unsigned int flush_duration = 5;
 static int use_sync = 0;
diff --git a/usage.c b/usage.c
new file mode 100644
index 0000000..d5a34ec
--- /dev/null
+++ b/usage.c
@@ -0,0 +1,1204 @@
+#include "internal.h"
+
+#if defined BB_AR
+const char ar_usage[] =
+	"ar [optxvV] archive [filenames] \n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nExtract or list files from an ar archive.\n\n"
+	"Options:\n"
+	"\to\t\tpreserve original dates\n"
+	"\tp\t\textract to stdout\n"
+	"\tt\t\tlist\n"
+	"\tx\t\textract\n"
+	"\tv\t\tverbosely list files processed\n"
+#endif
+	;
+#endif
+
+#if defined BB_BASENAME
+const char basename_usage[] =
+	"basename FILE [SUFFIX]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStrips directory path and suffixes from FILE.\n"
+	"If specified, also removes any trailing SUFFIX.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CAT
+const char cat_usage[] =
+	"cat [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nConcatenates FILE(s) and prints them to stdout.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHMOD_CHOWN_CHGRP
+const char chgrp_usage[] =
+	"chgrp [OPTION]... GROUP FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChange the group membership of each FILE to GROUP.\n"
+	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHMOD_CHOWN_CHGRP
+const char chmod_usage[] =
+	"chmod [-R] MODE[,MODE]... FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nEach MODE is one or more of the letters ugoa, one of the symbols +-= and\n"
+	"one or more of the letters rwxst.\n\n"
+	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHMOD_CHOWN_CHGRP
+const char chown_usage[] =
+	"chown [OPTION]...  OWNER[<.|:>[GROUP] FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChange the owner and/or group of each FILE to OWNER and/or GROUP.\n"
+	"\nOptions:\n\t-R\tChanges files and directories recursively.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHROOT
+const char chroot_usage[] =
+	"chroot NEWROOT [COMMAND...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRun COMMAND with root directory set to NEWROOT.\n"
+#endif
+	;
+#endif
+
+#if defined BB_CHVT
+const char chvt_usage[] =
+	"chvt N\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChanges the foreground virtual terminal to /dev/ttyN\n"
+#endif
+	;
+#endif
+
+#if defined BB_CP_MV
+const char cp_usage[] =
+	"cp [OPTION]... SOURCE DEST\n"
+	"   or: cp [OPTION]... SOURCE... DIRECTORY\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCopies SOURCE to DEST, or multiple SOURCE(s) to DIRECTORY.\n"
+	"\n"
+	"\t-a\tSame as -dpR\n"
+	"\t-d\tPreserves links\n"
+	"\t-p\tPreserves file attributes if possible\n"
+	"\t-f\tforce (implied; ignored) - always set\n"
+	"\t-R\tCopies directories recursively\n"
+#endif
+	;
+#endif
+
+#if defined BB_CUT
+const char cut_usage[] =
+	"cut [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints selected fields from each input FILE to standard output.\n\n"
+	"Options:\n"
+	"\t-b LIST\tOutput only bytes from LIST\n"
+	"\t-c LIST\tOutput only characters from LIST\n"
+	"\t-d CHAR\tUse CHAR instead of tab as the field delimiter\n"
+	"\t-s\tOnly output Lines if the include DELIM\n"
+	"\t-f N\tPrint only these fields\n"
+	"\t-n\tIgnored\n"
+#endif
+	;
+#endif
+
+#if defined BB_DATE
+const char date_usage[] =
+	"date [OPTION]... [+FORMAT]\n"
+	"  or:  date [OPTION] [MMDDhhmm[[CC]YY][.ss]]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDisplays the current time in the given FORMAT, or sets the system date.\n"
+	"\nOptions:\n\t-R\tOutputs RFC-822 compliant date string\n"
+	"\t-s\tSets time described by STRING\n"
+	"\t-u\tPrints or sets Coordinated Universal Time\n"
+#endif
+	;
+#endif
+
+#if defined BB_DC
+const char dc_usage[] =
+	"dc expression ...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nThis is a Tiny RPN calculator that understands the\n"
+	"following operations: +, -, /, *, and, or, not, eor.\n"
+	"i.e. 'dc 2 2 add' -> 4, and 'dc 8 8 \\* 2 2 + /' -> 16\n"
+#endif
+	;
+#endif
+
+#if defined BB_DD
+const char dd_usage[] =
+	"dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCopy a file, converting and formatting according to options\n\n"
+	"\tif=FILE\tread from FILE instead of stdin\n"
+	"\tof=FILE\twrite to FILE instead of stdout\n"
+	"\tbs=N\tread and write N bytes at a time\n"
+	"\tcount=N\tcopy only N input blocks\n"
+	"\tskip=N\tskip N input blocks\n"
+	"\tseek=N\tskip N output blocks\n"
+	"\n"
+	"Numbers may be suffixed by w (x2), k (x1024), b (x512), or M (x1024^2)\n"
+#endif
+	;
+#endif
+
+#if defined BB_DEALLOCVT
+const char deallocvt_usage[] =
+	"deallocvt N\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	 "\nDeallocate unused virtual terminal /dev/ttyN\n"
+#endif
+	 ;
+#endif
+
+#if defined BB_DF
+const char df_usage[] =
+	"df [filesystem ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint the filesystem space used and space available.\n"
+#endif
+	;
+#endif
+
+#if defined BB_DIRNAME
+const char dirname_usage[] =
+	"dirname [FILENAME ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStrips non-directory suffix from FILENAME\n"
+#endif
+	;
+#endif
+
+#if defined BB_DMESG
+const char dmesg_usage[] =
+	"dmesg [-c] [-n LEVEL] [-s SIZE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints or controls the kernel ring buffer\n\n"
+	"Options:\n"
+	"\t-c\t\tClears the ring buffer's contents after printing\n"
+	"\t-n LEVEL\tSets console logging level\n"
+	"\t-s SIZE\t\tUse a buffer of size SIZE\n"
+#endif
+	;
+#endif
+
+#if defined BB_DU
+const char du_usage[] =
+	"du [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSummarizes disk space used for each FILE and/or directory.\n"
+	"Disk space is printed in units of 1024 bytes.\n\n"
+	"Options:\n"
+	"\t-l\tcount sizes many times if hard linked\n"
+	"\t-s\tdisplay only a total for each argument\n"
+#endif
+	;
+#endif
+
+#if defined BB_DUMPKMAP
+const char dumpkmap_usage[] =
+	"dumpkmap\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints out a binary keyboard translation table to standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_DUTMP
+const char dutmp_usage[] =
+	"dutmp [FILE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDump utmp file format (pipe delimited) from FILE\n"
+	"or stdin to stdout.  (i.e. 'dutmp /var/run/utmp')\n"
+#endif
+	;
+#endif
+
+#if defined BB_ECHO
+const char echo_usage[] =
+	"echo [-neE] [ARG ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints the specified ARGs to stdout\n\n"
+	"Options:\n"
+	"\t-n\tsuppress trailing newline\n"
+	"\t-e\tinterpret backslash-escaped characters (i.e. \\t=tab etc)\n"
+	"\t-E\tdisable interpretation of backslash-escaped characters\n"
+#endif
+	;
+#endif
+
+#if defined BB_FDFLUSH
+const char fdflush_usage[] =
+	"fdflush DEVICE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nForces floppy disk drive to detect disk change\n"
+#endif
+	;
+#endif
+
+#if defined BB_FIND
+const char find_usage[] =
+	"find [PATH...] [EXPRESSION]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSearch for files in a directory hierarchy.  The default PATH is\n"
+	"the current directory; default EXPRESSION is '-print'\n\n"
+	"\nEXPRESSION may consist of:\n"
+	"\t-follow\t\tDereference symbolic links.\n"
+	"\t-name PATTERN\tFile name (leading directories removed) matches PATTERN.\n"
+	"\t-print\t\tprint the full file name followed by a newline to stdout.\n"
+#endif
+	;
+#endif
+
+#if defined BB_FREE
+const char free_usage[] =
+	"free\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDisplays the amount of free and used system memory\n"
+#endif
+	;
+#endif
+
+#if defined BB_FREERAMDISK
+const char freeramdisk_usage[] =
+	"freeramdisk DEVICE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nFrees all memory used by the specified ramdisk.\n"
+#endif
+	;
+#endif
+
+#if defined BB_FSCK_MINIX
+const char fsck_minix_usage[] =
+	"Usage: fsck.minix [-larvsmf] /dev/name\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPerforms a consistency check for MINIX filesystems.\n\n"
+	"Options:\n"
+	"\t-l\tLists all filenames\n"
+	"\t-r\tPerform interactive repairs\n"
+	"\t-a\tPerform automatic repairs\n"
+	"\t-v\tverbose\n"
+	"\t-s\tOutputs super-block information\n"
+	"\t-m\tActivates MINIX-like \"mode not cleared\" warnings\n"
+	"\t-f\tForce file system check.\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_GREP
+const char grep_usage[] =
+	"grep [-ihHnqvs] pattern [files...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSearch for PATTERN in each FILE or standard input.\n\n"
+	"Options:\n"
+	"\t-H\tprefix output lines with filename where match was found\n"
+	"\t-h\tsuppress the prefixing filename on output\n"
+	"\t-i\tignore case distinctions\n"
+	"\t-n\tprint line number with output lines\n"
+	"\t-q\tbe quiet. Returns 0 if result was found, 1 otherwise\n"
+	"\t-v\tselect non-matching lines\n"
+	"\t-s\tsuppress file open/read error messages\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_GUNZIP
+const char gunzip_usage[] =
+	"gunzip [OPTION]... FILE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUncompress FILE (or standard input if FILE is '-').\n\n"
+	"Options:\n"
+	"\t-c\tWrite output to standard output\n"
+	"\t-t\tTest compressed file integrity\n"
+#endif
+	;
+#endif
+
+#if defined BB_GZIP
+const char gzip_usage[] =
+	"gzip [OPTION]... FILE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCompress FILE with maximum compression.\n"
+	"When FILE is '-', reads standard input.  Implies -c.\n\n"
+	"Options:\n"
+	"\t-c\tWrite output to standard output instead of FILE.gz\n"
+#endif
+	;
+#endif
+
+#if defined BB_HEAD
+const char head_usage[] =
+	"head [OPTION] [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint first 10 lines of each FILE to standard output.\n"
+	"With more than one FILE, precede each with a header giving the\n"
+	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
+
+	"Options:\n" "\t-n NUM\t\tPrint first NUM lines instead of first 10\n"
+#endif
+	;
+#endif
+
+#if defined BB_HOSTNAME
+const char hostname_usage[] =
+	"hostname [OPTION] {hostname | -F file}\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nGet or set the hostname or DNS domain name. If a hostname is given\n"
+	"(or a file with the -F parameter), the host name will be set.\n\n"
+	"Options:\n"
+	"\t-s\t\tShort\n"
+
+	"\t-i\t\tAddresses for the hostname\n"
+	"\t-d\t\tDNS domain name\n"
+	"\t-F FILE\t\tUse the contents of FILE to specify the hostname\n"
+#endif
+	;
+#endif
+
+#if defined BB_ID
+const char id_usage[] =
+	"id [OPTIONS]... [USERNAME]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint information for USERNAME or the current user\n\n"
+	"Options:\n"
+	"\t-g\tprints only the group ID\n"
+	"\t-u\tprints only the user ID\n"
+	"\t-r\tprints the real user ID instead of the effective ID (with -ug)\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_INSMOD
+const char insmod_usage[] =
+	"insmod [OPTION]... MODULE [symbol=value]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLoads the specified kernel modules into the kernel.\n\n"
+	"Options:\n"
+	"\t-f\tForce module to load into the wrong kernel version.\n"
+	"\t-k\tMake module autoclean-able.\n"
+	"\t-v\tverbose output\n" "\t-x\tdo not export externs\n"
+#endif
+	;
+#endif
+
+#if defined BB_KILL
+const char kill_usage[] =
+	"kill [-signal] process-id [process-id ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
+	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_KILLALL
+const char killall_usage[] =
+	"killall [-signal] process-name [process-name ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend a signal (default is SIGTERM) to the specified process(es).\n\n"
+	"Options:\n" "\t-l\tList all signal names and numbers.\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_LENGTH
+const char length_usage[] =
+	"length STRING\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints out the length of the specified STRING.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LN
+const char ln_usage[] =
+	"ln [OPTION] TARGET... LINK_NAME|DIRECTORY\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate a link named LINK_NAME or DIRECTORY to the specified TARGET\n"
+	"\nYou may use '--' to indicate that all following arguments are non-options.\n\n"
+	"Options:\n"
+	"\t-s\tmake symbolic links instead of hard links\n"
+
+	"\t-f\tremove existing destination files\n"
+	"\t-n\tno dereference symlinks - treat like normal file\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOADACM
+const char loadacm_usage[] =
+	"loadacm\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLoads an acm from standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOADFONT
+const char loadfont_usage[] =
+	"loadfont\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"Loads a console font from standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOADKMAP
+const char loadkmap_usage[] =
+	"loadkmap\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLoads a binary keyboard translation table from standard input.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOGGER
+const char logger_usage[] =
+	"logger [OPTION]... [MESSAGE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nWrite MESSAGE to the system log.  If MESSAGE is '-', log stdin.\n\n"
+	"Options:\n"
+	"\t-s\tLog to stderr as well as the system log.\n"
+	"\t-t\tLog using the specified tag (defaults to user name).\n"
+
+	"\t-p\tEnter the message with the specified priority.\n"
+	"\t\tThis may be numerical or a ``facility.level'' pair.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LOGNAME
+const char logname_usage[] =
+	"logname\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint the name of the current user.\n"
+#endif
+	;
+#endif
+
+#if defined BB_LS
+const char ls_usage[] =
+	"ls [-1a"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"c"
+#endif
+	"d"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"e"
+#endif
+	"ln"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"p"
+#endif
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"u"
+#endif
+	"xAC"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"F"
+#endif
+#ifdef BB_FEATURE_LS_RECURSIVE
+	"R"
+#endif
+	"] [filenames...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nList directory contents\n\n"
+	"Options:\n"
+	"\t-a\tdo not hide entries starting with .\n"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"\t-c\twith -l: show ctime (the time of last\n"
+	"\t\tmodification of file status information)\n"
+#endif
+	"\t-d\tlist directory entries instead of contents\n"
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"\t-e\tlist both full date and full time\n"
+#endif
+	"\t-l\tuse a long listing format\n"
+	"\t-n\tlist numeric UIDs and GIDs instead of names\n"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"\t-p\tappend indicator (one of /=@|) to entries\n"
+#endif
+#ifdef BB_FEATURE_LS_TIMESTAMPS
+	"\t-u\twith -l: show access time (the time of last\n"
+	"\t\taccess of the file)\n"
+#endif
+	"\t-x\tlist entries by lines instead of by columns\n"
+	"\t-A\tdo not list implied . and ..\n"
+	"\t-C\tlist entries by columns\n"
+#ifdef BB_FEATURE_LS_FILETYPES
+	"\t-F\tappend indicator (one of */=@|) to entries\n"
+#endif
+#ifdef BB_FEATURE_LS_RECURSIVE
+	"\t-R\tlist subdirectories recursively\n"
+#endif
+#endif
+	;
+#endif
+
+#if defined BB_MAKEDEVS
+const char makedevs_usage[] =
+	"makedevs NAME TYPE MAJOR MINOR FIRST LAST [s]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreates a range of block or character special files\n\n"
+	"TYPEs include:\n"
+	"\tb:\tMake a block (buffered) device.\n"
+	"\tc or u:\tMake a character (un-buffered) device.\n"
+	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n\n"
+	"FIRST specifies the number appended to NAME to create the first device.\n"
+	"LAST specifies the number of the last item that should be created.\n"
+	"If 's' is the last argument, the base device is created as well.\n\n"
+	"For example:\n"
+	"\tmakedevs /dev/ttyS c 4 66 2 63   ->  ttyS2-ttyS63\n"
+	"\tmakedevs /dev/hda b 3 0 0 8 s    ->  hda,hda1-hda8\n"
+#endif
+	;
+#endif
+
+#if defined BB_MD5SUM
+const char md5sum_usage[] =
+	"md5sum [OPTION] [FILE]...\n"
+	"or:    md5sum [OPTION] -c [FILE]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint or check MD5 checksums.\n\n"
+	"Options:\n"
+	"With no FILE, or when FILE is -, read standard input.\n\n"
+	"\t-b\tread files in binary mode\n"
+	"\t-c\tcheck MD5 sums against given list\n"
+	"\t-t\tread files in text mode (default)\n"
+	"\t-g\tread a string\n"
+	"\nThe following two options are useful only when verifying checksums:\n"
+	"\t-s,\tdon't output anything, status code shows success\n"
+	"\t-w,\twarn about improperly formated MD5 checksum lines\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKDIR
+const char mkdir_usage[] =
+	"mkdir [OPTION] DIRECTORY...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate the DIRECTORY(ies), if they do not already exist\n\n"
+	"Options:\n"
+
+	"\t-m\tset permission mode (as in chmod), not rwxrwxrwx - umask\n"
+	"\t-p\tno error if existing, make parent directories as needed\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKFIFO
+const char mkfifo_usage[] =
+	"mkfifo [OPTIONS] name\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreates a named pipe (identical to 'mknod name p')\n\n"
+	"Options:\n"
+	"\t-m\tcreate the pipe using the specified mode (default a=rw)\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKFS_MINIX
+const char mkfs_minix_usage[] =
+	"mkfs.minix [-c | -l filename] [-nXX] [-iXX] /dev/name [blocks]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nMake a MINIX filesystem.\n\n"
+	"Options:\n"
+	"\t-c\t\tCheck the device for bad blocks\n"
+	"\t-n [14|30]\tSpecify the maximum length of filenames\n"
+	"\t-i INODES\tSpecify the number of inodes for the filesystem\n"
+	"\t-l FILENAME\tRead the bad blocks list from FILENAME\n"
+	"\t-v\t\tMake a Minix version 2 filesystem\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKNOD
+const char mknod_usage[] =
+	"mknod [OPTIONS] NAME TYPE MAJOR MINOR\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate a special file (block, character, or pipe).\n\n"
+	"Options:\n"
+	"\t-m\tcreate the special file using the specified mode (default a=rw)\n\n"
+	"TYPEs include:\n"
+	"\tb:\tMake a block (buffered) device.\n"
+	"\tc or u:\tMake a character (un-buffered) device.\n"
+	"\tp:\tMake a named pipe. MAJOR and MINOR are ignored for named pipes.\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKSWAP
+const char mkswap_usage[] =
+	"mkswap [-c] [-v0|-v1] device [block-count]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrepare a disk partition to be used as a swap partition.\n\n"
+	"Options:\n" "\t-c\t\tCheck for read-ability.\n"
+	"\t-v0\t\tMake version 0 swap [max 128 Megs].\n"
+	"\t-v1\t\tMake version 1 swap [big!] (default for kernels > 2.1.117).\n"
+
+	"\tblock-count\tNumber of block to use (default is entire partition).\n"
+#endif
+	;
+#endif
+
+#if defined BB_MKTEMP
+const char mktemp_usage[] =
+	"mktemp [-q] TEMPLATE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreates a temporary file with its name based on TEMPLATE.\n"
+	"TEMPLATE is any name with six `Xs' (i.e. /tmp/temp.XXXXXX).\n"
+#endif
+	;
+#endif
+
+#if defined BB_MORE
+const char more_usage[] =
+	"more [FILE ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nMore is a filter for viewing FILE one screenful at a time.\n"
+#endif
+	;
+#endif
+
+#if defined BB_MOUNT
+const char mount_usage[] = 
+	"mount [flags] device directory [-o options,more-options]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nMount a filesystem\n\n"
+	"Flags:\n" 
+	"\t-a:\t\tMount all filesystems in fstab.\n"
+#ifdef BB_MTAB
+	"\t-f:\t\t\"Fake\" mount. Add entry to mount table but don't mount it.\n"
+	"\t-n:\t\tDon't write a mount table entry.\n"
+#endif
+	"\t-o option:\tOne of many filesystem options, listed below.\n"
+	"\t-r:\t\tMount the filesystem read-only.\n"
+	"\t-t fs-type:\tSpecify the filesystem type.\n"
+	"\t-w:\t\tMount for reading and writing (default).\n"
+	"\n"
+	"Options for use with the \"-o\" flag:\n"
+	"\tasync/sync:\tWrites are asynchronous / synchronous.\n"
+	"\tatime/noatime:\tEnable / disable updates to inode access times.\n"
+	"\tdev/nodev:\tAllow use of special device files / disallow them.\n"
+	"\texec/noexec:\tAllow use of executable files / disallow them.\n"
+#if defined BB_FEATURE_MOUNT_LOOP
+	"\tloop:\t\tMounts a file via loop device.\n"
+#endif
+	"\tsuid/nosuid:\tAllow set-user-id-root programs / disallow them.\n"
+	"\tremount:\tRe-mount a currently-mounted filesystem, changing its flags.\n"
+	"\tro/rw:\t\tMount for read-only / read-write.\n"
+	"\nThere are EVEN MORE flags that are specific to each filesystem.\n"
+	"You'll have to see the written documentation for those.\n"
+#endif
+	;
+#endif
+
+#if defined BB_MT
+const char mt_usage[] =
+	"mt [-f device] opcode value\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nControl magnetic tape drive operation\n"
+#endif
+	;
+#endif
+
+#if defined BB_CP_MV
+const char mv_usage[] =
+	"mv SOURCE DEST\n"
+	"   or: mv SOURCE... DIRECTORY\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRename SOURCE to DEST, or move SOURCE(s) to DIRECTORY.\n"
+#endif
+	;
+#endif
+
+#if defined BB_NC
+const char nc_usage[] =
+	"nc [IP] [port]\n" 
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nNetcat opens a pipe to IP:port\n"
+#endif
+	;
+#endif
+
+#if defined BB_NSLOOKUP
+const char nslookup_usage[] =
+	"nslookup [HOST]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nQueries the nameserver for the IP address of the given HOST\n"
+#endif
+;
+#endif
+
+#if defined BB_PING
+#if defined BB_FEATURE_SIMPLE_PING
+const char ping_usage[] =
+	"ping host\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend ICMP ECHO_REQUEST packets to network hosts\n"
+#endif
+	;
+#else /* ! defined BB_FEATURE_SIMPLE_PING */
+const char ping_usage[] =
+	"ping [OPTION]... host\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSend ICMP ECHO_REQUEST packets to network hosts.\n\n"
+	"Options:\n"
+	"\t-c COUNT\tSend only COUNT pings.\n"
+	"\t-s SIZE\t\tSend SIZE data bytes in packets (default=56).\n"
+	"\t-q\t\tQuiet mode, only displays output at start\n"
+	"\t\t\tand when finished.\n"
+#endif
+	;
+#endif
+#endif
+
+#if defined BB_PRINTF
+const char printf_usage[] =
+	"printf FORMAT [ARGUMENT...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nFormats and prints ARGUMENT(s) according to FORMAT,\n"
+	"Where FORMAT controls the output exactly as in C printf.\n"
+#endif
+	;
+#endif
+
+#if defined BB_PS
+const char ps_usage[] =
+	"ps\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nReport process status\n"
+	"\nThis version of ps accepts no options.\n"
+#endif
+	;
+#endif
+
+#if defined BB_RM
+const char rm_usage[] =
+	"rm [OPTION]... FILE...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRemove (unlink) the FILE(s).  You may use '--' to\n"
+	"indicate that all following arguments are non-options.\n\n"
+	"Options:\n"
+	"\t-f\t\tremove existing destinations, never prompt\n"
+	"\t-r or -R\tremove the contents of directories recursively\n"
+#endif
+	;
+#endif
+
+#if defined BB_RMDIR
+const char rmdir_usage[] =
+	"rmdir [OPTION]... DIRECTORY...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRemove the DIRECTORY(ies), if they are empty.\n"
+#endif
+	;
+#endif
+
+#if defined BB_RMMOD
+const char rmmod_usage[] =
+	"rmmod [OPTION]... [MODULE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUnloads the specified kernel modules from the kernel.\n\n"
+	"Options:\n" 
+	"\t-a\tTry to remove all unused kernel modules.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SED
+const char sed_usage[] =
+	"sed [-Vhnef] pattern [files...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\n"
+	"-n\tsuppress automatic printing of pattern space\n"
+	"-e script\tadd the script to the commands to be executed\n"
+	"-f scriptfile\tadd the contents of script-file to the commands to be executed\n"
+	"-h\tdisplay this help message\n"
+	"-V\toutput version information and exit\n"
+	"\n"
+	"If no -e or -f is given, the first non-option argument is taken as the\n"
+	"sed script to interpret. All remaining arguments are names of input\n"
+	"files; if no input files are specified, then the standard input is read.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SETKEYCODES
+const char setkeycodes_usage[] =
+	"setkeycodes SCANCODE KEYCODE ...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSet entries into the kernel's scancode-to-keycode map,\n"
+	"allowing unusual keyboards to generate usable keycodes.\n\n" 
+	"SCANCODE may be either xx or e0xx (hexadecimal),\n"
+	"and KEYCODE is given in decimal\n"
+#endif
+	;
+#endif
+
+#if defined BB_SH
+const char shell_usage[] =
+	"sh [FILE]...\n"
+	"   or: sh -c command [args]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nlash: The BusyBox command interpreter (shell).\n\n"
+#endif
+	;
+#endif
+
+#if defined BB_SLEEP
+const char sleep_usage[] =
+	"sleep N\n" 
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPause for N seconds.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SORT
+const char sort_usage[] =
+	"sort [-n]"
+#ifdef BB_FEATURE_SORT_REVERSE
+	" [-r]"
+#endif
+	" [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nSorts lines of text in the specified files\n"
+#endif
+	;
+#endif
+
+#if defined BB_SWAPONOFF
+const char swapoff_usage[] =
+	"swapoff [OPTION] [device]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStop swapping virtual memory pages on the given device.\n\n"
+	"Options:\n"
+	"\t-a\tStop swapping on all swap devices\n"
+#endif
+	;
+#endif
+
+#if defined BB_SWAPONOFF
+const char swapon_usage[] =
+	"swapon [OPTION] [device]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nStart swapping virtual memory pages on the given device.\n\n"
+	"Options:\n"
+	"\t-a\tStart swapping on all swap devices\n"
+#endif
+	;
+#endif
+
+#if defined BB_SYNC
+const char sync_usage[] =
+	"sync\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nWrite all buffered filesystem blocks to disk.\n"
+#endif
+	;
+#endif
+
+#if defined BB_SYSLOGD
+const char syslogd_usage[] =
+	"syslogd [OPTION]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLinux system and kernel (provides klogd) logging utility.\n"
+	"Note that this version of syslogd/klogd ignores /etc/syslog.conf.\n\n"
+	"Options:\n"
+	"\t-m NUM\t\tInterval between MARK lines (default=20min, 0=off)\n"
+	"\t-n\t\tRun as a foreground process\n"
+#ifdef BB_FEATURE_KLOGD
+	"\t-K\t\tDo not start up the klogd process\n"
+#endif
+	"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
+#endif
+	;
+#endif
+
+#if defined BB_TAIL
+#if defined BB_FEATURE_SIMPLE_TAIL
+const char tail_usage[] =
+	"tail [OPTION] [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint last 10 lines of each FILE to standard output.\n"
+	"With more than one FILE, precede each with a header giving the\n"
+	"file name. With no FILE, or when FILE is -, read standard input.\n\n"
+	"Options:\n"
+	"\t-n NUM\t\tPrint last NUM lines instead of first 10\n"
+
+	"\t-f\t\tOutput data as the file grows.  This version\n"
+	"\t\t\tof 'tail -f' supports only one file at a time.\n"
+#endif
+	;
+#else /* ! defined BB_FEATURE_SIMPLE_TAIL */
+const char tail_usage[] =
+	"tail [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint last 10 lines of each FILE to standard output.\n"
+	"With more than one FILE, precede each with a header giving the file name.\n"
+	"With no FILE, or when FILE is -, read standard input.\n"
+	"\n"
+	"  -c=N[kbm]       output the last N bytes\n"
+	"  -f              output appended data as the file grows\n"
+	"  -n=N            output the last N lines, instead of last 10\n"
+	"  -q              never output headers giving file names\n"
+	"  -v              always output headers giving file names\n"
+	"\n"
+	"If the first character of N (bytes or lines) is a `+', output begins with \n"
+	"the Nth item from the start of each file, otherwise, print the last N items\n"
+	"in the file.  N bytes may be suffixed by k (x1024), b (x512), or m (1024^2).\n"
+#endif
+	;
+#endif
+#endif
+
+#if defined BB_TAR
+const char tar_usage[] =
+#ifdef BB_FEATURE_TAR_CREATE
+	"tar -[cxtvO] "
+#else
+	"tar -[xtvO] "
+#endif
+#if defined BB_FEATURE_TAR_EXCLUDE
+	"[--exclude File] "
+#endif
+	"[-f tarFile] [FILE] ...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCreate, extract, or list files from a tar file.  Note that\n"
+	"this version of tar treats hard links as separate files.\n\n"
+	"Main operation mode:\n"
+#ifdef BB_FEATURE_TAR_CREATE
+	"\tc\t\tcreate\n"
+#endif
+	"\tx\t\textract\n"
+	"\tt\t\tlist\n"
+	"\nFile selection:\n"
+	"\tf\t\tname of tarfile or \"-\" for stdin\n"
+	"\tO\t\textract to stdout\n"
+#if defined BB_FEATURE_TAR_EXCLUDE
+	"\t--exclude\tfile to exclude\n"
+#endif
+	"\nInformative output:\n"
+	"\tv\t\tverbosely list files processed\n"
+#endif
+	;
+#endif
+
+#if defined BB_TEE
+const char tee_usage[] =
+	"tee [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nCopy standard input to each FILE, and also to standard output.\n\n"
+	"Options:\n" "\t-a\tappend to the given FILEs, do not overwrite\n"
+#endif
+	;
+#endif
+
+#if defined BB_TELNET
+const char telnet_usage[] =
+	"telnet host [port]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nTelnet is used to establish interactive communication with another\n"
+	"computer over a network using the TELNET protocol.\n"
+#endif
+	;
+#endif
+
+#if defined BB_TEST
+const char test_usage[] =
+	"test EXPRESSION\n"
+	"or   [ EXPRESSION ]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nChecks file types and compares values returning an exit\n"
+	"code determined by the value of EXPRESSION.\n"
+#endif
+	;
+#endif
+
+#if defined BB_TOUCH
+const char touch_usage[] =
+	"touch [-c] file [file ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUpdate the last-modified date on the given file[s].\n\n"
+	"Options:\n"
+	"\t-c\tDo not create any files\n"
+#endif
+	;
+#endif
+
+#if defined BB_TR
+const char tr_usage[] =
+	"tr [-cds] STRING1 [STRING2]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nTranslate, squeeze, and/or delete characters from\n"
+	"standard input, writing to standard output.\n\n"
+	"Options:\n"
+	"\t-c\ttake complement of STRING1\n"
+	"\t-d\tdelete input characters coded STRING1\n"
+	"\t-s\tsqueeze multiple output characters of STRING2 into one character\n"
+#endif
+	;
+#endif
+
+#if defined BB_TTY
+const char tty_usage[] =
+	"tty\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint the file name of the terminal connected to standard input.\n\n"
+	"Options:\n"
+	"\t-s\tprint nothing, only return an exit status\n"
+#endif
+	;
+#endif
+
+#if defined BB_UMOUNT
+const char umount_usage[] =
+	"umount [flags] filesystem|directory\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"Unmount file systems\n"
+	"\nFlags:\n" "\t-a:\tUnmount all file systems"
+#ifdef BB_MTAB
+	" in /etc/mtab\n\t-n:\tDon't erase /etc/mtab entries\n"
+#else
+	"\n"
+#endif
+	"\t-r:\tTry to remount devices as read-only if mount is busy\n"
+#if defined BB_FEATURE_MOUNT_FORCE
+	"\t-f:\tForce filesystem umount (i.e. unreachable NFS server)\n"
+#endif
+#if defined BB_FEATURE_MOUNT_LOOP
+	"\t-l:\tDo not free loop device (if a loop device has been used)\n"
+#endif
+#endif
+	;
+#endif
+
+#if defined BB_UNAME
+const char uname_usage[] =
+	"uname [OPTION]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint certain system information.  With no OPTION, same as -s.\n\n"
+	"Options:\n"
+	"\t-a\tprint all information\n"
+	"\t-m\tthe machine (hardware) type\n"
+	"\t-n\tprint the machine's network node hostname\n"
+	"\t-r\tprint the operating system release\n"
+	"\t-s\tprint the operating system name\n"
+
+	"\t-p\tprint the host processor type\n"
+	"\t-v\tprint the operating system version\n"
+#endif
+	;
+#endif
+
+#if defined BB_UNIQ
+const char uniq_usage[] =
+	"uniq [OPTION]... [INPUT [OUTPUT]]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nDiscard all but one of successive identical lines from INPUT\n"
+	"(or standard input), writing to OUTPUT (or standard output).\n"
+#endif
+	;
+#endif
+
+#if defined BB_UPDATE
+const char update_usage[] =
+	"update [options]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPeriodically flushes filesystem buffers.\n\n"
+	"Options:\n"
+	"\t-S\tforce use of sync(2) instead of flushing\n"
+	"\t-s SECS\tcall sync this often (default 30)\n"
+	"\t-f SECS\tflush some buffers this often (default 5)\n"
+#endif
+	;
+#endif
+
+#if defined BB_USLEEP
+const char usleep_usage[] =
+	"usleep N\n" 
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPause for N microseconds.\n"
+#endif
+	;
+#endif
+
+#if defined BB_UUDECODE
+const char uudecode_usage[] =
+	"uudecode [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUudecode a file that is uuencoded.\n\n"
+	"Options:\n"
+	"\t-o FILE\tdirect output to FILE\n"
+#endif
+	;
+#endif
+
+#if defined BB_UUENCODE
+const char uuencode_usage[] =
+	"uuencode [OPTION] [INFILE] REMOTEFILE\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nUuencode a file.\n\n"
+	"Options:\n"
+	"\t-m\tuse base64 encoding as of RFC1521\n"
+#endif
+	;
+#endif
+
+#if defined BB_WC
+const char wc_usage[] =
+	"wc [OPTION]... [FILE]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrint line, word, and byte counts for each FILE, and a total line if\n"
+	"more than one FILE is specified.  With no FILE, read standard input.\n\n"
+	"Options:\n"
+	"\t-c\tprint the byte counts\n"
+	"\t-l\tprint the newline counts\n"
+
+	"\t-L\tprint the length of the longest line\n"
+	"\t-w\tprint the word counts\n"
+#endif
+	;
+#endif
+
+#if defined BB_WHICH
+const char which_usage[] =
+	"which [COMMAND ...]\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nLocates a COMMAND.\n"
+#endif
+	;
+#endif
+
+#if defined BB_WHOAMI
+const char whoami_usage[] =
+	"whoami\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nPrints the user name associated with the current effective user id.\n"
+#endif
+	;
+#endif
+
+#if defined BB_YES
+const char yes_usage[] =
+	"yes [OPTION]... [STRING]...\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+	"\nRepeatedly outputs a line with all specified STRING(s), or `y'.\n"
+#endif
+	;
+#endif
diff --git a/usleep.c b/usleep.c
index da6cca9..fcdf3bb 100644
--- a/usleep.c
+++ b/usleep.c
@@ -25,12 +25,6 @@
 #include <stdlib.h>
 #include <unistd.h>
 
-const char usleep_usage[] = "usleep N\n" 
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPause for N microseconds.\n"
-#endif
-	;
-
 extern int usleep_main(int argc, char **argv)
 {
 	if ((argc < 2) || (**(argv + 1) == '-')) {
diff --git a/util-linux/dmesg.c b/util-linux/dmesg.c
index 961e532..a8c61c7 100644
--- a/util-linux/dmesg.c
+++ b/util-linux/dmesg.c
@@ -32,16 +32,6 @@
 # include <sys/klog.h>
 #endif
 
-static const char dmesg_usage[] = "dmesg [-c] [-n LEVEL] [-s SIZE]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints or controls the kernel ring buffer\n\n"
-	"Options:\n"
-	"\t-c\t\tClears the ring buffer's contents after printing\n"
-	"\t-n LEVEL\tSets console logging level\n"
-	"\t-s SIZE\t\tUse a buffer of size SIZE\n"
-#endif
-	;
-
 int dmesg_main(int argc, char **argv)
 {
 	char *buf, c;
diff --git a/util-linux/fdflush.c b/util-linux/fdflush.c
index d993735..6bc3e7d 100644
--- a/util-linux/fdflush.c
+++ b/util-linux/fdflush.c
@@ -34,13 +34,8 @@
 	int value;
 	int fd;
 
-	if (argc <= 1 || **(++argv) == '-') {
-		usage("fdflush DEVICE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-				"\nForces floppy disk drive to detect disk change\n"
-#endif
-				);
-	}
+	if (argc <= 1 || **(++argv) == '-')
+		usage(fdflush_usage);
 
 	fd = open(*argv, 0);
 	if (fd < 0) {
diff --git a/util-linux/freeramdisk.c b/util-linux/freeramdisk.c
index 927c169..2da2427 100644
--- a/util-linux/freeramdisk.c
+++ b/util-linux/freeramdisk.c
@@ -34,14 +34,6 @@
 /* From linux/fs.h */
 #define BLKFLSBUF  _IO(0x12,97)	/* flush buffer cache */
 
-
-static const char freeramdisk_usage[] =
-	"freeramdisk DEVICE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nFrees all memory used by the specified ramdisk.\n"
-#endif
-	;
-
 extern int
 freeramdisk_main(int argc, char **argv)
 {
diff --git a/util-linux/fsck_minix.c b/util-linux/fsck_minix.c
index ea27c23..5807b9a 100644
--- a/util-linux/fsck_minix.c
+++ b/util-linux/fsck_minix.c
@@ -288,21 +288,6 @@
 	exit(status);
 }
 
-const char fsck_minix_usage[] =
-	"Usage: fsck.minix [-larvsmf] /dev/name\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPerforms a consistency check for MINIX filesystems.\n\n"
-	"Options:\n"
-	"\t-l\tLists all filenames\n"
-	"\t-r\tPerform interactive repairs\n"
-	"\t-a\tPerform automatic repairs\n"
-	"\t-v\tverbose\n"
-	"\t-s\tOutputs super-block information\n"
-	"\t-m\tActivates MINIX-like \"mode not cleared\" warnings\n"
-	"\t-f\tForce file system check.\n\n"
-#endif
-	;
-
 static void show_usage(void)
 {
 	usage(fsck_minix_usage);
diff --git a/util-linux/mkfs_minix.c b/util-linux/mkfs_minix.c
index 9ae4b56..dec310d 100644
--- a/util-linux/mkfs_minix.c
+++ b/util-linux/mkfs_minix.c
@@ -267,19 +267,6 @@
 	exit(8);
 }
 
-const char mkfs_minix_usage[] =
-	"mkfs.minix [-c | -l filename] [-nXX] [-iXX] /dev/name [blocks]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nMake a MINIX filesystem.\n\n"
-	"Options:\n"
-	"\t-c\t\tCheck the device for bad blocks\n"
-	"\t-n [14|30]\tSpecify the maximum length of filenames\n"
-	"\t-i INODES\tSpecify the number of inodes for the filesystem\n"
-	"\t-l FILENAME\tRead the bad blocks list from FILENAME\n"
-	"\t-v\t\tMake a Minix version 2 filesystem\n\n"
-#endif
-	;
-
 static volatile void show_usage() __attribute__ ((noreturn));
 static volatile void show_usage()
 {
diff --git a/util-linux/mkswap.c b/util-linux/mkswap.c
index 5a33945..eacd881 100644
--- a/util-linux/mkswap.c
+++ b/util-linux/mkswap.c
@@ -47,20 +47,6 @@
 #include <asm/page.h>			/* for PAGE_SIZE and PAGE_SHIFT */
 				/* we also get PAGE_SIZE via getpagesize() */
 
-
-static const char mkswap_usage[] =
-	"mkswap [-c] [-v0|-v1] device [block-count]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrepare a disk partition to be used as a swap partition.\n\n"
-	"Options:\n" "\t-c\t\tCheck for read-ability.\n"
-	"\t-v0\t\tMake version 0 swap [max 128 Megs].\n"
-	"\t-v1\t\tMake version 1 swap [big!] (default for kernels > 2.1.117).\n"
-
-	"\tblock-count\tNumber of block to use (default is entire partition).\n"
-#endif
-	;
-
-
 #ifndef _IO
 /* pre-1.3.45 */
 #define BLKGETSIZE 0x1260
diff --git a/util-linux/more.c b/util-linux/more.c
index 91c2815..2334576 100644
--- a/util-linux/more.c
+++ b/util-linux/more.c
@@ -34,12 +34,6 @@
 #define bb_need_help
 #include "messages.c"
 
-static const char more_usage[] = "more [FILE ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nMore is a filter for viewing FILE one screenful at a time.\n"
-#endif
-	;
-
 /* ED: sparc termios is broken: revert back to old termio handling. */
 #ifdef BB_FEATURE_USE_TERMIOS
 #	if #cpu(sparc)
diff --git a/util-linux/mount.c b/util-linux/mount.c
index addeb09..610d12d 100644
--- a/util-linux/mount.c
+++ b/util-linux/mount.c
@@ -80,38 +80,6 @@
 
 extern const char mtab_file[];	/* Defined in utility.c */
 
-static const char mount_usage[] = 
-	"mount [flags] device directory [-o options,more-options]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nMount a filesystem\n\n"
-	"Flags:\n" 
-	"\t-a:\t\tMount all filesystems in fstab.\n"
-#ifdef BB_MTAB
-	"\t-f:\t\t\"Fake\" mount. Add entry to mount table but don't mount it.\n"
-	"\t-n:\t\tDon't write a mount table entry.\n"
-#endif
-	"\t-o option:\tOne of many filesystem options, listed below.\n"
-	"\t-r:\t\tMount the filesystem read-only.\n"
-	"\t-t fs-type:\tSpecify the filesystem type.\n"
-	"\t-w:\t\tMount for reading and writing (default).\n"
-	"\n"
-	"Options for use with the \"-o\" flag:\n"
-	"\tasync/sync:\tWrites are asynchronous / synchronous.\n"
-	"\tatime/noatime:\tEnable / disable updates to inode access times.\n"
-	"\tdev/nodev:\tAllow use of special device files / disallow them.\n"
-	"\texec/noexec:\tAllow use of executable files / disallow them.\n"
-#if defined BB_FEATURE_MOUNT_LOOP
-	"\tloop:\t\tMounts a file via loop device.\n"
-#endif
-	"\tsuid/nosuid:\tAllow set-user-id-root programs / disallow them.\n"
-	"\tremount:\tRe-mount a currently-mounted filesystem, changing its flags.\n"
-	"\tro/rw:\t\tMount for read-only / read-write.\n"
-	"\nThere are EVEN MORE flags that are specific to each filesystem.\n"
-	"You'll have to see the written documentation for those.\n"
-#endif
-	;
-
-
 struct mount_options {
 	const char *name;
 	unsigned long and;
diff --git a/util-linux/swaponoff.c b/util-linux/swaponoff.c
index a79b93a..6aafe51 100644
--- a/util-linux/swaponoff.c
+++ b/util-linux/swaponoff.c
@@ -35,25 +35,6 @@
 
 static int whichApp;
 
-static const char swapoff_usage[] =
-	"swapoff [OPTION] [device]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStop swapping virtual memory pages on the given device.\n\n"
-	"Options:\n"
-	"\t-a\tStop swapping on all swap devices\n"
-#endif
-	;
-
-static const char swapon_usage[] =
-	"swapon [OPTION] [device]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nStart swapping virtual memory pages on the given device.\n\n"
-	"Options:\n"
-	"\t-a\tStart swapping on all swap devices\n"
-#endif
-	;
-
-
 #define SWAPON_APP   1
 #define SWAPOFF_APP  2
 
diff --git a/util-linux/umount.c b/util-linux/umount.c
index 1b250fd..df075f7 100644
--- a/util-linux/umount.c
+++ b/util-linux/umount.c
@@ -39,28 +39,6 @@
 extern int umount (__const char *__special_file);
 extern int umount2 (__const char *__special_file, int __flags);
 
-
-
-static const char umount_usage[] =
-	"umount [flags] filesystem|directory\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"Unmount file systems\n"
-	"\nFlags:\n" "\t-a:\tUnmount all file systems"
-#ifdef BB_MTAB
-	" in /etc/mtab\n\t-n:\tDon't erase /etc/mtab entries\n"
-#else
-	"\n"
-#endif
-	"\t-r:\tTry to remount devices as read-only if mount is busy\n"
-#if defined BB_FEATURE_MOUNT_FORCE
-	"\t-f:\tForce filesystem umount (i.e. unreachable NFS server)\n"
-#endif
-#if defined BB_FEATURE_MOUNT_LOOP
-	"\t-l:\tDo not free loop device (if a loop device has been used)\n"
-#endif
-#endif
-;
-
 struct _mtab_entry_t {
 	char *device;
 	char *mountpt;
diff --git a/uudecode.c b/uudecode.c
index 12a71a5..90bef92 100644
--- a/uudecode.c
+++ b/uudecode.c
@@ -300,15 +300,6 @@
     return read_stduu (inname);
 }
 
-static const char uudecode_usage[] =
-    "uudecode [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-    "\nUudecode a file that is uuencoded.\n\n"
-    "Options:\n"
-    "\t-o FILE\tdirect output to FILE\n"
-#endif
-;
-
 int uudecode_main (int argc,
                    char **argv)
 {
diff --git a/uuencode.c b/uuencode.c
index e107a01..1433c7f 100644
--- a/uuencode.c
+++ b/uuencode.c
@@ -180,15 +180,6 @@
   }
 }
 
-static const char uuencode_usage[] =
-    "uuencode [OPTION] [INFILE] REMOTEFILE\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-    "\nUuencode a file.\n\n"
-    "Options:\n"
-    "\t-m\tuse base64 encoding as of RFC1521\n"
-#endif
-;
-
 int uuencode_main (int argc,
                    char **argv)
 {
diff --git a/wc.c b/wc.c
index 3b0e589..058444d 100644
--- a/wc.c
+++ b/wc.c
@@ -23,19 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-static const char wc_usage[] = "wc [OPTION]... [FILE]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrint line, word, and byte counts for each FILE, and a total line if\n"
-	"more than one FILE is specified.  With no FILE, read standard input.\n\n"
-	"Options:\n"
-	"\t-c\tprint the byte counts\n"
-	"\t-l\tprint the newline counts\n"
-
-	"\t-L\tprint the length of the longest line\n"
-	"\t-w\tprint the word counts\n"
-#endif
-	;
-
 static int total_lines, total_words, total_chars, max_length;
 static int print_lines, print_words, print_chars, print_length;
 
diff --git a/which.c b/which.c
index 186bfda..943e10a 100644
--- a/which.c
+++ b/which.c
@@ -26,13 +26,6 @@
 #include <sys/stat.h>
 #include <sys/param.h>
 
-const char which_usage[] =
-	"which [COMMAND ...]\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nLocates a COMMAND.\n"
-#endif
-	;
-
 extern int which_main(int argc, char **argv)
 {
 	char *path_list, *test, *tmp, *path_parsed;
diff --git a/whoami.c b/whoami.c
index 01dff81..84b27fe 100644
--- a/whoami.c
+++ b/whoami.c
@@ -24,12 +24,6 @@
 #include <stdio.h>
 #include <pwd.h>
 
-static const char whoami_usage[] = "whoami\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nPrints the user name associated with the current effective user id.\n"
-#endif
-	;
-
 extern int whoami_main(int argc, char **argv)
 {
 	char *user = xmalloc(9);
diff --git a/yes.c b/yes.c
index 0191bb0..f41bbb6 100644
--- a/yes.c
+++ b/yes.c
@@ -23,13 +23,6 @@
 #include "internal.h"
 #include <stdio.h>
 
-const char yes_usage[] =
-	"yes [OPTION]... [STRING]...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
-	"\nRepeatedly outputs a line with all specified STRING(s), or `y'.\n"
-#endif
-	;
-
 extern int yes_main(int argc, char **argv)
 {
 	int i;