blob: dd0b3a7f7e0af5021d0e6cd3b0ce5895f509028f [file] [log] [blame]
Rob Landley589f5cd2010-01-05 10:41:52 -06001<!--#include file="header.html" -->
2
Rob Landleye258af32008-01-05 18:09:49 -06003<h2><a name="what" />What is ToyBox?</h2>
4
5<p>The goal of the Toybox project is to create simple implementations of all
6the important Linux command line utilities. These implementations should
7be small (the entire project should total less than a megabyte, uncompressed),
8fast, simple, and correctly implemented (which is related to standards
9compliance, but isn't quite the same thing). Click for
10<a href="design.html">more about the design goals</a></p>
11
12<p>Toybox has configurable levels of functionality, and should scale from tiny
13embedded systems up to full general purpose desktop and development
14environments. The author plans to run it on his laptop, and the
15<a href=/code/firmware>Firmware Linux</a> project is trying to get a complete
16Linux system to rebuild itself from source code using toybox.</p>
17
18<p>Toybox is <a href=license.html>Licensed under GPL version 2</a>.</p>
19
20<p>Toybox can be built as a single "swiss army knife" executable (ala BusyBox
21or Red Hat's Nash), or each command can be built as a traditional independent
22executable.</p>
23
24<b><h2><a name="status" />What commands are implemented?</h2></b>
25
26<p>The current list of commands implemented by toybox is at the top of the
27<a href=news.html>news page</a></p>. That list is updated when new commands
28go in.</p>
29
30<p>In general, configuring toybox for "defconfig" enables all the commands
31compete enough to be useful. Configuring "allyesconfig" enables partially
32implemented commands as well.</p>
33
34<p>The following commands are incomplete, but demonstrate some basic
35functionality: bzcat/bunzip2, help, mke2fs, sh/toysh, mdev.</p>
36
37<p>The following are partially implemented commands that don't actually do
38anything yet: mke2fs.</p>
39
Rob Landleybd915512008-01-07 20:28:26 -060040<p>Several toybox commands can do things other vesions can't. For example:</p>
41
42<p>The toybox "df" isn't confused by initramfs the way other df implementations
43are. If initramfs is visible, df shows it like any other mount point.</p>
44
45<p>The toybox "touch" command has a -l option to set the length of a file.
46This can truncate a file, or create completely sparse files.</p>
Rob Landleye258af32008-01-05 18:09:49 -060047
48<b><h3>Command Shell</h3></b>
49<p>The Toybox Shell (toysh) aims to be a reasonable bash replacement. It
50implements the "sh" and "toysh" commands, plus the built-in commands "cd" and
51"exit". This is the largest single sub-project in toybox.</p>
52
53<p>The following additional commands may be built into the shell (but not as
54separate executables): cd, exit, if, while, for, function, fg, bg, jobs, source,
55<a href="http://www.opengroup.org/onlinepubs/009695399/utilities/alias.html">alias</a>,
56export, set, unset, read, trap, and exec. (Note: not done yet.)</p>
57
58</ul>
59
60<h2><a name="commands" />Which commands are planned?</h2>
61
62<p>The toybox <a href=todo.txt>todo list</a> mentions many potential commands
63which may be added to this project. (Whether that file is readable by anybody
64but the project's maintainer is open to debate.)</p>
65
66<p>The criteria for a toybox 1.0 release is that a system built from just the
67Linux kernel, toybox, uClibc, and a compiler (such as tinycc) can rebuild
68itself from source code.</p>
69
70<b><h3>Relevant Standards</h3></b>
71
72<p>Most commands are implemented according to
73<a href=http://www.opengroup.org/onlinepubs/009695399/idx/utilities.html>The
74Single Unix Specification version 3</a> where applicable. This does not mean
75that Toybox is implementing every SUSv3 utility: some such as SCCS and ed are
76obsolete, while others such as c99 are outside the scope of the project.
77Toybox also isn't implementing full internationalization support: it should be
788-bit clean and handle UTF-8, but otherwise we leave this to X11 and higher
79layers. And some things (like $CDPATH support in "cd") await a good
80explanation of why to bother with them. (The standard provides an important
81frame of reference, but is not infallable set of commandments to be blindly
82obeyed.)</p>
83
84<p>The other major sources of commands are the Linux man pages, and testing
85the behavior of existing commands (although not generally looking at their
86source code). SUSv3 does not include many basic commands such as "mount",
87"init", and "mke2fs", which are kind of nice to have.</p>
88
89<b><h2><a name="downloads" />Download</h2></b>
90
91<p>This project is maintained as a mercurial archive. To get a copy of the
92current development version, either use mercurial (hg clone
93http://landley.net/toybox) or click on one of the zip/gz/bz2 links
94at the top of the <a href=/hg/toybox>mercurial archive browser</a> page to get
95an archive of the appropriate version. Click
96<a href="/hg/toybox?cmd=tags">tags</a> to see all the tagged release
97versions ("tip" is the current development version).</p>
98
99<p>The maintainer's <a href=/notes.html>development log</a> and the project's
100<a href=http://www2.them.com:8080/cgi-bin/mailman/listinfo/toybox>mailing
101list</a> are also good ways to track what's going on with the project.</p>
102
Rob Landley08671ef2009-09-30 23:30:26 -0500103<b><h2><a name="toycans" />What's the toybox logo image?</h2></b>
Rob Landleyb9d0cf12008-01-05 18:13:19 -0600104
105<p>It's <a href=toycans-big.jpg>carefully stacked soda cans</a>. Specifically,
106it's a bunch of the original "Coke Zero" and "Pepsi One" cans, circa 2006,
Rob Landley797a4c32008-01-05 18:23:30 -0600107stacked to spell out the binary values of the ascii string "Toybox", with
108null terminator at the bottom. (The big picture's on it's side because
109the camera was held sideways to get a better shot.)</p>
110
111<p>No, it's not photoshopped, I actually had these cans until a coworker
112who Totally Did Not Get It <sup><font size=-3><a href=http://www.timesys.com>tm</a></font></sup> threw them out one day after I'd gone home,
113thinking they were recycling. (I still have two of each kind, but
114Pepsi One seems discontinued and Coke Zero switched its can color
115from black to grey, presumably in celebration. It was fun while it lasted...)</p>
Rob Landley589f5cd2010-01-05 10:41:52 -0600116
117<!--#include file="footer.html" -->