Rob Landley | 589f5cd | 2010-01-05 10:41:52 -0600 | [diff] [blame] | 1 | <!--#include file="header.html" --> |
| 2 | |
Rob Landley | 5cab994 | 2013-09-18 10:50:38 -0500 | [diff] [blame^] | 3 | <p>Toybox combines common Linux command line utilities together |
Rob Landley | e566f3a | 2013-06-16 20:02:38 -0500 | [diff] [blame] | 4 | into a single BSD-licensed executable that's simple, small, fast, |
| 5 | reasonably standards-compliant, and powerful enough to turn Android into |
Rob Landley | 49f8d6f | 2013-07-26 13:04:21 -0500 | [diff] [blame] | 6 | a development environment. See the links on the left for details.</p> |
| 7 | |
| 8 | <h2>News</h2> |
Rob Landley | 5cab994 | 2013-09-18 10:50:38 -0500 | [diff] [blame^] | 9 | <hr><b>September 17, 2013</b> |
| 10 | <blockquote><p>"Think of a number," said the computer, "any number." |
| 11 | Arthur told the computer the telephone number of King's Cross railway |
| 12 | station passenger inquiries, on the grounds that it must have some function, |
| 13 | and this might turn out to be it. - The Hitchhiker's Guide to the Galaxy</p> |
| 14 | </blockquote> |
| 15 | |
| 16 | <p><a href=downloads/toybox-0.4.6.tar.bz2>Toybox 0.4.6</a> is based on |
| 17 | <a href=http://landley.net/hg/toybox/shortlog/1068>commit 1068</a>.</p> |
| 18 | |
| 19 | <p>This release adds |
| 20 | several new commands: Felix Janda wrote paste and fallocate, Kyungwan Han |
| 21 | submitted eject, Strake contributed grep, Ashwini Sharma added pmap (and |
| 22 | a testsuite entry for grep), Lukasz Skalski sent pwdx, Isaac Dunham posted |
| 23 | acpi, and I did timeout and umount.</p> |
| 24 | |
| 25 | <p>The ls command now has a --color=auto option (suggested by Rich Felker). |
| 26 | The multiplexer now has a --help option so you can say "./toybox --help blah" |
| 27 | instead of using the built-in "help" command. (Which is a shell built-in. |
| 28 | Try it on your command line, it's like man for shell builtins. But a certain |
| 29 | other project has conditioned people to expect --help, so...) I forget who |
| 30 | heehooman at gmail is but they pointed out unshare needed PID and UID |
| 31 | namespace support.</p> |
| 32 | |
| 33 | <h3>Pending</h3> |
| 34 | |
| 35 | <p>A lot of new commands in toys/pending, to the point the next release should |
| 36 | probably just focus on cleanup and review of this backlog. We've got klogd, |
| 37 | dhcp, dhcpd, watch, route, and ps from |
| 38 | Ashwini Sharma (and an fdisk wrapper but no fdisk.fstype engines yet), |
| 39 | syslogd, pgrep, and pkill from Madhur Verma, netstat by Ranjan Kumar, |
| 40 | test by Felix Janda, lspci by Isaac Dunham, nl, su, and renice by strake (I.E. |
| 41 | M. Farkas-Dyck), and sysvinit by Kyungwan Han.</p> |
| 42 | |
| 43 | <p>Some cleanup work on existing pending commands that aren't |
| 44 | ready to promote yet: I did a few more rounds on ifconfig |
| 45 | and Isaac Dunham's did several cleanups to xzcat, Felix Janda cleaned up |
| 46 | logger and syslogd...</p> |
| 47 | |
| 48 | <p>Also some cleanup work on commands that predate the pending directory, |
| 49 | but weren't quite polished when they went in, most prominently du, |
| 50 | expand, and touch.</p> |
| 51 | |
| 52 | <h3>Infrastructure</h3> |
| 53 | |
| 54 | <p>The new scripts/single.sh builds a standalone command without the |
| 55 | multiplexer, although not all commands can be built that way yet (NEWTOY yes, |
| 56 | OLDTOY no) and the space savings aren't anything to write home about. (If a |
| 57 | command needs the option parsing logic at all, it needs all of it.) If |
| 58 | you're curious, you can do:</p> |
| 59 | |
| 60 | <blockquote><pre> |
| 61 | make defconfig |
| 62 | make |
| 63 | mkdir singles |
| 64 | for i in $(./toybox) |
| 65 | do |
| 66 | echo $i |
| 67 | PREFIX=singles/ scripts/single.sh $i || break |
| 68 | done |
| 69 | </pre> |
| 70 | <p>(And then wait a long time and watch almost half the builds fail.)</p> |
| 71 | </blockquote> |
| 72 | |
| 73 | <p>There is now libbuf analogous to toybuf, another global 4k buffer this |
| 74 | time for use by lib/ code instead of command code.</p> |
| 75 | |
| 76 | <p>The lib directory got split up a bit, lib/pending.c contains functions |
| 77 | not yet used by anything outside of toys/pending/*, and lib/xwrap.c contains |
| 78 | functions that wrap other functions and handle failures (via error_exit). |
| 79 | This leaves lib/lib.c containing actual new functions.</p> |
| 80 | |
| 81 | <p>General improvements and bug fixes to argument parsing. The [-abc] exclude |
| 82 | logic should now clear arguments slots when disabling options. Bare --longopts |
| 83 | should work now and be able to report errors using their name, the new ; |
| 84 | option allows optional arguments to longopts only suppliable with = (I.E. |
| 85 | --color and --color=auto but not --color auto).</p> |
| 86 | |
| 87 | <p>I'm gradually weaning the code off of itoa()/utoa() because sprintf |
| 88 | does this already. In this case "simple" probably means "let libc do it |
| 89 | for us".</p> |
| 90 | |
| 91 | <p>Rewrote for_each_pid_with_name_in() and renamed it to just names_to_pid(). |
| 92 | It shouldn't get confused trying to compare absolute and relative paths quite |
| 93 | so much anymore.</p> |
| 94 | |
| 95 | <p>lib/llist.c grew a new dlist_pop() function for removing a doubly |
| 96 | linked list entry while maintaining a circular list; tail and patch are |
| 97 | using it now.</p> |
| 98 | |
| 99 | <p>The musl guys suggested a new optimization flag |
| 100 | (-fno-asynchronous-unwind-tables) |
| 101 | that shaves about 10% off the binary size by removing a C++ism that crept |
| 102 | into gcc's idea of C. While I don't normally try to micromanage the compiler, |
| 103 | "-fstop-being-stupid" is a thing you have to hit gcc with from time to time.</p> |
| 104 | |
| 105 | <h3>Bugfixes</h3> |
| 106 | |
| 107 | <p>Felix Janda and I did a largeish rewrite of tail to |
| 108 | finally make it work right (we think). Still need to implement tail -f |
| 109 | someday (the tricky bit is making -f follow multiple files at once). |
| 110 | Felix also reported a bug in xpidfile.</p> |
| 111 | |
| 112 | <p>Juhani Haverinen pointed out that |
| 113 | python 3 doesn't work with config2help.py, so the detection logic looks |
| 114 | for python2 (until I get around to rewriting that in C). Elie De Brauwer |
| 115 | then fixed our first attempt at this, and also fixed uname's help string.</p> |
| 116 | |
| 117 | <p>Ashwini Sharma |
| 118 | pointed out the build was making a FLAG_ macro for " " which broke some |
| 119 | configurations. (That's a control character, not a command line option.)</p> |
| 120 | |
| 121 | <p>Jacek Bukarewicz pointed out a bug in chdir permission handling, and |
| 122 | a way to make env segfault. Both should be fixed now.</p> |
| 123 | |
| 124 | <p>The new function xexec_optargs() |
| 125 | replaces calls to xexec(toys.optargs) to avoid freeing and reusing optargs |
| 126 | during option parsing screwing stuff up (such as netcat's exec mode).</p> |
| 127 | |
| 128 | <p>The stat command's %a output was padded with leading zeroes, which |
| 129 | didn't match anybody else's behavior and thus made the test suite hiccup |
| 130 | between TEST_HOST and testing toybox. (If you go "TEST_HOST=1 scripts/test.sh |
| 131 | command" it sanity checks the tests against the host implementation.)</p> |
| 132 | |
| 133 | <p>Last release, "mkdir sub/sub && chmod 007 sub/sub && rm -rf sub" didn't |
| 134 | delete sub and didn't exit with an error either. Neither was correct, rm |
| 135 | should now be fixed.</p> |
| 136 | |
| 137 | <p> |
Rob Landley | 49f8d6f | 2013-07-26 13:04:21 -0500 | [diff] [blame] | 138 | <hr><b>July 26, 2013</b> |
| 139 | <p>Georgi Chorbadzhiyski maintains a <a href=https://github.com/gfto/toybox>git |
| 140 | mirror</a> of the repository on github, automatically updated from the |
| 141 | mercurial every 6 hours. The mirror is read only, but you can generate patches |
| 142 | against it and post them to the list.</p> |
Rob Landley | e566f3a | 2013-06-16 20:02:38 -0500 | [diff] [blame] | 143 | |
Isaac Dunham | c810f9f | 2013-07-06 11:26:15 -0500 | [diff] [blame] | 144 | <hr><b>July 2, 2013</b> |
| 145 | <blockquote><p>"Time is an illusion. Lunchtime doubly so." "Very deep. You |
| 146 | should send that in to the Reader's Digest. They've got a page for people |
| 147 | like you." - |
| 148 | The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 149 | |
| 150 | <p><a href=downloads/toybox-0.4.5.tar.bz2>Toybox 0.4.5</a> is based on |
| 151 | <a href=http://landley.net/hg/toybox/shortlog/941>commit 941</a>. It adds |
| 152 | uuencode and uudecode from Erich Plondke, and enables Luis Morales' "who" by |
| 153 | default. Felix Janda and I cleaned up last year's "stat" submission and |
| 154 | enabled it. Ivo van Poorten added "groups". |
| 155 | Andre Renaud added "lsusb". I implemented "split", "pivot_root", and "mv". |
| 156 | </p> |
| 157 | |
| 158 | <p>The "help" command is implemented differently now (lib/help.c) and |
| 159 | each command can now understand --help (including both "toybox --help" |
| 160 | and "toybox --help command" in the multiplexer).</p> |
| 161 | |
| 162 | <p>The "pending" directory has several commands (find, xzcat, nbd-client, |
| 163 | logger, expr) which work but are not enabled by default pending further cleanup. |
| 164 | Ifconfig is enabled, but still in pending because it's only 2/3 cleaned up. |
| 165 | (It's an awkward halfway state but I'm not holding up the release for it.)</p> |
| 166 | |
| 167 | <p>I'm <a href=cleanup.html>documenting the cleanups</a> to teach |
| 168 | more people to do it, but the writeups aren't caught up yet. The |
| 169 | <a href=roadmap.html>roadmap</a> also got updated a bit with further analysis |
| 170 | of other projects, and the README and about pages got updated.</p> |
| 171 | |
| 172 | <p>Fixed _another_ "ls -C" segfault when terminal size can't be detected, |
| 173 | condensed the ls help text to fit on one page, implented --color, and taught |
| 174 | -l to print the major, minor numbers when showing block/char devices. |
| 175 | Argument parsing now handles "--" properly (to end option checking), |
| 176 | and the infrastructure can now handle bare --longopts that have no |
| 177 | corresponding short option (both were implemented before but didn't work). |
| 178 | Fixed an old bug in "patch", chmod grew -f, who grew -a. Isaac Dunham |
| 179 | fixed "-" vs "_" handling in modinfo, added a "firmware" output |
| 180 | field, added -b and -k support, and taught it that the ".ko" extension means |
| 181 | to look for the file at the specified path instead of under /lib. Felix Janda |
| 182 | moved file permission display code to lib so ls and |
| 183 | stat could share it. Ashwini Sharma spotted a bug in xabspath when the |
| 184 | last path component exists but we haven't got permissions to open it |
| 185 | (ala readlink -f /dev/sda as a normal user). |
| 186 | </p> |
| 187 | |
| 188 | <p>In the build infrastructure, scripts/findglobals.sh finds leaked global |
| 189 | variables. (Leaked means they aren't part of the global union: Other than glibc |
| 190 | debris, toybox should define "this", "toy_list", "toybuf", and "toys", and |
| 191 | that's it; the rest add memory footprint to every command for the benefit of |
| 192 | just one command; use GLOBALS() to stick 'em in the union.) Static linking |
| 193 | against libraries other than the host's libc now applies to feature probes |
| 194 | for unshare and such. Neuter stupid internationalization support that makes |
| 195 | various host "sort" commands put things in an order other than alphabetical |
| 196 | (breaking the multiplexer's binary search on command names). |
| 197 | |
| 198 | <p>You should now be able to build from a source control snapshot on a build |
| 199 | system that hasn't got python: if you disable CONFIG_TOYBOX_HELP. (The |
| 200 | release tarballs ship generated/help.h, but it's not in source control. |
| 201 | Eventually I should rewrite that python script in C.)</p> |
| 202 | </p> |
| 203 | |
| 204 | <p><b>LICENSE TWEAK</b>: After <a href=http://lists.landley.net/pipermail/toybox-landley.net/2013-March/000794.html>discussion</a> on the mailing list the "2 clause |
| 205 | BSD" <a href=license.html>license</a> got slightly simplified so the first |
| 206 | paragraph now says:</p> |
| 207 | |
| 208 | <blockquote><p>Permission to use, copy, modify, and/or distribute this |
| 209 | software for any purpose with or without fee is hereby granted.</p></blockquote> |
| 210 | |
| 211 | <p>It used to continue "provided that the above copyright notice and this |
| 212 | permission notice appear in all copies", but A) what's the point? B) does "all |
| 213 | copies" mean binaries, or just source code, or what? C) lots of projects |
| 214 | that consider BSD and GPL compatible have <a href=https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/crypto/aes_generic.c>files with |
| 215 | both license notices</a> on them (sometimes at <a href=http://git.busybox.net/busybox/tree/shell/ash.c>opposite ends of the file</a> to make the conflict |
| 216 | less obvious) because "all copies must include this function" would violate |
| 217 | the GPL but "all copies must include this magic text blob" somehow don't?</p> |
| 218 | |
| 219 | <p>I don't want to have to care about this anymore. The tweaked version is more |
| 220 | or less public domain with a liability disclaimer, but we're still calling it |
| 221 | BSD (sometimes "0 clause BSD") to avoid explaining.</p> |
| 222 | |
Rob Landley | 6f5ef6f | 2013-03-21 20:21:12 -0500 | [diff] [blame] | 223 | <hr><b>March 21, 2013</b> |
| 224 | <p>Video of my ELC talk |
Rob Landley | e566f3a | 2013-06-16 20:02:38 -0500 | [diff] [blame] | 225 | "<a href=http://youtu.be/SGmtP5Lg_t0>Why is Toybox?</a>" |
Rob Landley | 6f5ef6f | 2013-03-21 20:21:12 -0500 | [diff] [blame] | 226 | is up on youtube. Related materials include the |
| 227 | <a href=http://landley.net/talks/celf-2013.txt>talk outline</a> and an |
| 228 | <a href=/aboriginal/about.html#selfhost>android self-hosting writeup</a>.</p> |
| 229 | |
Rob Landley | e566f3a | 2013-06-16 20:02:38 -0500 | [diff] [blame] | 230 | <p>[Updated June 4] The following links jump to specific topics in the video. (Sorry about |
| 231 | the ads, it's The Linux Foundation.)</p> |
| 232 | |
| 233 | <ul> |
| 234 | <li>0m29s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=0m29s>The smartphone is replacing the PC</a></li> |
| 235 | <ul> |
| 236 | <li>4m22s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=4m22s>Software needed to become self-hosting</a></li> |
| 237 | <li>6m20s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=6m20s>Do we care if android or iphone wins?</a></li> |
| 238 | </ul> |
| 239 | <li>9m45s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=9m45s>Android not vanilla: oppose or accept?</a></li> |
| 240 | <ul> |
| 241 | <li>11m30s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=11m30s>Open source can't do User Interfaces</a></li> |
| 242 | </ul> |
| 243 | <li>15m09s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=15m09s>Android is not copyleft: oppose or accept?</a></li> |
| 244 | <li>18m23s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=18m23s>Security issues</a></li> |
| 245 | <li>21m15s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=21m15s>Solutions to the software problems</a></li> |
| 246 | <ul> |
| 247 | <li>22m55s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=22m55s>What toybox needs to be/do</a></li> |
| 248 | <li>28m17s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=28m17s>What is toybox?</a></li> |
| 249 | <ul> |
| 250 | <li>28m58s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=28m58s>Why toybox started...</a></li> |
| 251 | <li>37m50s <a href=http://www.youtube.com/watch?v=SGmtP5Lg_t0#t=37m50s>What does toybox actually implement?</a></li> |
| 252 | </ul> |
| 253 | </ul> |
| 254 | </ul> |
| 255 | </span> |
| 256 | |
| 257 | |
Rob Landley | 6f5ef6f | 2013-03-21 20:21:12 -0500 | [diff] [blame] | 258 | <hr><b>March 14, 2013</b> |
| 259 | <blockquote><p>"Ford, you're turning into a penguin. Stop it." - |
| 260 | The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 261 | |
| 262 | <p><a href=downloads/toybox-0.4.4.tar.bz2>Toybox 0.4.4</a> is based on |
| 263 | <a href=http://landley.net/hg/toybox/shortlog/813>commit 813</a>, adding |
| 264 | the "time" and "readahead" commands, plus some bugfixes.</p> |
| 265 | |
| 266 | <p>The "cp" command now implements the -s symlink option, plus bugfixes |
| 267 | getting various corner cases right as used in actual package builds. |
| 268 | "id -Gn root" should now print root's groups |
| 269 | instead of the current user's. Several build fixes so toybox builds under |
| 270 | Ubuntu 8.04 again (which is about as old a build environment as you |
| 271 | can expect to find posix-2008 features in).</p> |
| 272 | |
| 273 | <p>Unfinished commands have generally been moved to "toys/pending". |
| 274 | Everything else should "default y" to participate in make defconfig. |
| 275 | Several of those pending commands got some basic cleanup so allyesconfig |
| 276 | should at least compile (although defconfig is still what's useful).</p> |
| 277 | |
| 278 | <p>Significant roadmap updates, checking several other multicall binaries |
| 279 | (klibc, sash, sbase, s6...) to see what commands they include.</p> |
| 280 | |
Rob Landley | 9a69a92 | 2013-02-23 18:32:08 -0600 | [diff] [blame] | 281 | <hr><b>January 18, 2013</b> |
| 282 | <blockquote><p>This must be Thursday. I never could get the hang of Thursdays. - The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 283 | |
| 284 | <p><a href=downloads/toybox-0.4.3.tar.bz2>Toybox 0.4.3</a> is based on |
| 285 | <a href=http://landley.net/hg/toybox/shortlog/793>commit 793</a>. There |
| 286 | are now exactly 100 commands in defconfig (of a little over 220 on the |
| 287 | <a href=roadmap.html>todo list</a>).</p> |
| 288 | |
| 289 | <p>Elie De Brauwer added the rev command, cleaned up tac, implemented the -s |
| 290 | and -f flags for seq, added -v and -i to killall (and fixed killall not to |
| 291 | kill itself before finishing its pid list), and added to the test suite. |
| 292 | Felix Janda added -m to mkdir, pwd -L and -P, and more test suite entries.</p> |
| 293 | |
| 294 | <p>Rob Landley added the losetup command, and fixed the existing ls, cp, and |
| 295 | readlink commands. The segfault in ls |
| 296 | happened when it couldn't determine the screen size (last release changed the |
| 297 | default to -C and a screen size of 0 made column view unhappy), and cp got an |
| 298 | extensive rewrite bringing it up to date with the dirtree changes and fixing |
| 299 | a number of things it never did right in the first place. The xabspath() |
| 300 | code in the library now handles a symlink after ".." properly (and the test |
| 301 | suite checks for it).</p> |
| 302 | |
| 303 | <p>Infrastructure-wise the code is better about automatically setting the |
| 304 | error return code properly. Now error_msg() sets the exit code to 1 if it's |
| 305 | still defaulting to 0, and the global exit path does a fflush(NULL) with error |
| 306 | bit check rather than trying to be quite so granular about flushing. (That |
| 307 | means if we use printf() instead of xprintf() it still exits with the right |
| 308 | error code, it just doesn't end the program early on an output error.) |
| 309 | Minor bugfix so TOYBOX_DEBUG |
| 310 | doesn't always warn about the lack of suid bit when toybox is built with |
| 311 | at least one STAYROOT command. Bugfix for the option [grouping] logic |
| 312 | (and then further fixes to the error reporting pointed out by Ashwini Sharma). |
| 313 | dirtree_handle_callback() now has a prefix like the rest of the dirtree |
| 314 | functions. A lot of stuff doing manual path handling was switched to using |
| 315 | libc basename() (including, embarassingly, the basename command), which means |
| 316 | it now correctly detects "/trailing/slash/" which the previous code didn't.</p> |
| 317 | |
| 318 | <p>Also, last release included some accidentally checked in debug code that |
| 319 | disabled compiler optimization, so the binary size bloated a bit. It's back |
| 320 | to -Os by default now.</p> |
| 321 | |
Rob Landley | 8390c65 | 2012-12-19 09:16:45 -0600 | [diff] [blame] | 322 | <hr><b>December 15, 2012</b> |
| 323 | <blockquote><p>"The major difference between a thing that might go wrong and a |
| 324 | thing that cannot possibly go wrong is that when a thing that cannot possibly |
| 325 | go wrong goes wrong it usually turns out to be impossible to get at or repair." |
| 326 | </p><p>- The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 327 | |
| 328 | <p><a href=downloads/toybox-0.4.2.tar.bz2>Toybox 0.4.2</a> is based on |
| 329 | <a href=http://landley.net/hg/toybox/shortlog/749>commit 749</a> and is |
| 330 | just a resync. Linux 3.7 came out, meaning it's time to do an Aboriginal |
| 331 | Linux release, and that should use a stable version of toybox. So here's |
| 332 | a new stable version.</p> |
| 333 | |
| 334 | <p>The new commands are cut (from Jason Kyungwan Han), touch |
| 335 | (from Choubey Ji), expand (from Jonathan Clairembault, and he fixed a |
| 336 | bug in login), and rm (from Rob Landley). Felix Janda added UTF-8 |
| 337 | support infrastructure (for non-ascii character sets) with a config option. |
| 338 | Elie De Brauwer added tests for cat and sha1sum, and -so options to pidof. |
| 339 | The "ls" command defaults to -C (column view) now, and "readlink" now supports |
| 340 | -fenq.</p> |
| 341 | |
| 342 | <p>Portability work: toybox should now build against the musl C library, |
| 343 | and against older glibc versions (circa 2008, much before that and kernel |
| 344 | features we depend on start to drop out).</p> |
| 345 | |
| 346 | <p>The whole codebase got reindented from "one tab" to "two spaces" per |
| 347 | level. The option parsing logic now understands [groups] of commands (when more |
| 348 | than one in a group is selected it can switch the others off, or error out, |
| 349 | or other things). The error_exit() infrastructure can now longjmp back to an |
| 350 | earlier point instead of exiting. Each toys/* directory now has a README, |
| 351 | the first line of which is the fancy name menuconfig uses for the directory |
| 352 | (so no more hardwired directory list in scripts/genconfig.sh).</p> |
| 353 | |
| 354 | <p>Fixed a filehandle leak in getmountlist(). |
| 355 | Pass parent pointer to dirtree_add_node() so it can give error messages with |
| 356 | full path. The yesno() function now always reads from stdin and writes to |
| 357 | stderr (we can retry tty checking complexity once we've got commands needing |
| 358 | it).</p> |
| 359 | |
| 360 | <p>The open group broke their website so the |
| 361 | <a href=http://opengroup.org/onlinepubs/9699919799>old links</a> to POSIX 2008 |
| 362 | now <a href=http://pubs.opengroup.org/onlinepubs/9699919799>need to start with |
| 363 | pubs</a>. Some of the links in the tree have been updated, others haven't while |
| 364 | I wait to see if their webmaster notices and fixes it.</p> |
| 365 | |
| 366 | <p>(I note that the current rm implementation is not technically posix compliant |
| 367 | because the standard requires infinite recursion depth and the current |
| 368 | implementation uses one filehandle per level. I can add a config option |
| 369 | to do it Posix's way, which is more brittle and needs extra security checks, |
| 370 | but am waiting for somebody to complain first. The default "ulimit -n" is 1024 |
| 371 | filehandles, so drilling down over 1000 nested subdirectories).</p> |
| 372 | |
Rob Landley | 571b070 | 2012-11-13 16:13:45 -0600 | [diff] [blame] | 373 | <hr><b>November 13, 2012</b> |
| 374 | <blockquote><p>"Rule Six: The winning team shall be the first team that wins." |
| 375 | - The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 376 | |
| 377 | <p><a href=downloads/toybox-0.4.1.tar.bz2>Toybox 0.4.1</a> is based on |
| 378 | <a href=http://landley.net/hg/toybox/shortlog/691>commit 691</a>.</p> |
| 379 | |
| 380 | <p>Elie De Brauwer contributed usleep, Ashwini Kumar contributed du, and |
| 381 | Kyungwan Han contributed vconfig. Other new commands include switch_root and |
| 382 | md5sum, and the remaining shell wrappers are now proper commands (dos2unix, |
| 383 | unix2dos).</p> |
| 384 | |
| 385 | <p>The patch command now supports -l, and gethostname is now enabled by |
| 386 | default. The df command follows symlinks to get the actual device name. |
| 387 | Felix Janda added -m support to wc (for utf8).</p> |
| 388 | |
| 389 | <p>On the infrastructure side, the commands have now been grouped into |
| 390 | "posix", "lsb", and "other" subdirectories (for things required by Posix-2008, |
| 391 | the Linux Standard Base 4.1, and commands in neither). This affects menuconfig |
| 392 | and the actual source layout (toys/cp.c is now toys/posix/cp.c, and so on). |
| 393 | An android directory is planned (see the updated |
| 394 | <a href=roadmap.html#android>android roadmap analysis</a>).</p> |
| 395 | |
| 396 | <p>The FLAG_ macros for command option parsing and TT alias for the command's |
| 397 | global block are now automatically generated, commands should |
| 398 | #define FOR_commandname before #including <toys.h> to get the macros for that |
| 399 | command.</p> |
| 400 | |
| 401 | <p>An upgrade to the build infrastructure now allows commands with _ and - |
| 402 | in them, such as switch_root.</p> |
| 403 | |
| 404 | <p>Bugfixes: Avery Pennarun spotted a case where ls showed uid twice instead of |
| 405 | uid and gid, and that nice was using the wrong range of numbers. |
| 406 | The ls command also recursed inappropriately last time (not quite |
| 407 | properly converted for the dirtree changes last release), and now it's |
| 408 | fixed. Roy Tam pointed out a glitch in sh, and fixed df's percentage |
| 409 | calculation to match the POSIX spec. The kernel build didn't like our mktemp |
| 410 | and it does now. The wc command wasn't quite posix compliant (trailing spaces |
| 411 | break stuff). The ls command recursed inappropriately last time (not quite |
| 412 | properly converted for the dirtree changes last release), and now it's |
| 413 | fixed. The catv command wasn't displaying byte 255 correctly. Some lib |
| 414 | fixes (thinko in xpidfile). Fixed uname -m when running a 32 bit x86 binary |
| 415 | on an x86-64 host (it lies and says the system is i686, i586, or i486 depending |
| 416 | on what the toolchain that built the binary supported. This makes builds in |
| 417 | a 32 bit chroot on a 64 bit kernel break less.) The df command was checking |
| 418 | partitions in the wrong order (displaying undermounts instead of overmounts: |
| 419 | this used to work but some library code changed out from under it and it |
| 420 | wasn't updated to match until now). Felix Janda filled out the test suite |
| 421 | some more. The patch file creation logic got tweaked several times to |
| 422 | successfully apply more patches. Support for older (pre 2.10) glibc |
| 423 | versions was added to portability.h.</p> |
| 424 | |
| 425 | <p>Miscelaneous cleanups all around (mknod, sha1sum, logname), including a |
| 426 | rewrite of taskset to be less dependent on libc getting the headers right. All |
| 427 | the command headers should now point to the current relevant standards |
| 428 | document, where applicable.</p> |
| 429 | |
| 430 | <p>This news page had old news entries from before the relaunch moved into |
| 431 | a separate <a href=oldnews.html>oldnews</a> page.</p> |
| 432 | |
| 433 | <p>I forgot to create <a href=bin>static binaries</a> last time, but they're |
| 434 | back now.</p> |
| 435 | </span> |
| 436 | |
Rob Landley | 31103f9 | 2012-08-25 11:51:25 -0500 | [diff] [blame] | 437 | <hr><b>July 23, 2012</b> |
| 438 | <blockquote><p>"Ford", Arthur said. "There's an infinite number of monkeys |
| 439 | out here who want to talk to us about this script for Hamlet they've worked |
| 440 | out." - The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 441 | |
Rob Landley | 571b070 | 2012-11-13 16:13:45 -0600 | [diff] [blame] | 442 | <p><a href=downloads/toybox-0.4.0.tar.bz2>Toybox 0.4.0</a> is based on |
| 443 | <a href=http://landley.net/hg/toybox/shortlog/640>commit 640</a>.</p> |
Rob Landley | 31103f9 | 2012-08-25 11:51:25 -0500 | [diff] [blame] | 444 | |
| 445 | <p>The new <a href=status.html>status page</a> is calculated from |
| 446 | the roadmap info, and should be easier to keep up to date in future.</p> |
| 447 | |
| 448 | <p>Andre Renaud contributed od and modinfo. Elie De Brauwer contributed |
| 449 | taskset, bugfixes to cmp and tail, and tests for sort and tail. Kyungwan Han |
| 450 | contributed passwd. Gaurang Shastri contributed w. Ashwini Sharma spotted a |
| 451 | case where dirtree was adding extra slashes to a path.</p> |
| 452 | |
| 453 | <p>I rewrote od, cleaned up comm, documented the |
| 454 | <a href=code.html#lib_llist>llist</a> and |
| 455 | <a href=code.html#lib_dirtree>dirtree</a> infrastructure, added an -r option |
| 456 | to date (and fixed a bug where -u wouldn't override /etc/localtime), |
| 457 | fixed bugs in chmod +stw, fixed ls to show suid bits properly when the |
| 458 | corresponding executable bit wasn't set, and worked around a longstanding |
| 459 | glibc bug where static linking prevents stdout from automatically flushing |
| 460 | pending output on exit.</p> |
| 461 | |
Rob Landley | b1cc1d1 | 2012-06-25 06:42:24 -0500 | [diff] [blame] | 462 | <hr><b>June 25, 2012</b> |
| 463 | <blockquote><p>"For a moment, nothing happened. Then, after a second or so, nothing continued to happen." - The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 464 | |
| 465 | <p><a href=downloads/toybox-0.3.1.tar.bz2>Toybox 0.3.1</a> is based on commit |
| 466 | <a href=http://landley.net/hg/toybox/shortlog/607>commit 607</a>. It's |
| 467 | mostly a bugfix release for ls -l (which was unhappy on targets other than |
| 468 | x86-64), plus a new "date" from Andre Renaud and rewritten chgrp/chown which |
| 469 | now support the full set of posix flags, plus a little work on the test |
| 470 | suite and some more header tweaks towards eventual compatability with the |
| 471 | musl libc.</p> |
| 472 | |
| 473 | <p>The todo list runneth over, but "release early, release often", so here |
| 474 | it is. The roadmap and documentation are a bit behind, and I've got ~40 |
| 475 | pending submissions to review. I need to catch up...</p> |
| 476 | </span> |
| 477 | |
| 478 | <hr><b>June 12, 2012</b> |
| 479 | <blockquote><p>"For instance, on the planet Earth, man had always assumed that |
| 480 | he was more intelligent than dolphins because he had achieved so much - the |
| 481 | wheel, New York, wars and so on - whilst all the dolphins had ever done was |
| 482 | muck about in the water having a good time. But conversely, the dolphins had |
| 483 | always believed that they were far more intelligent than man - for precisely |
| 484 | the same reasons." - The Hitchhiker's Guide to the Galaxy.</p></blockquote> |
| 485 | |
| 486 | <p>It's well past time for <a href=downloads/toybox-0.3.0.tar.bz2>toybox 0.3.0</a>, |
| 487 | so here it is, based |
| 488 | on <a href=http://landley.net/hg/toybox/shortlog/595>commit 595</a>, and the |
| 489 | statically linked <a href=downloads/binaries>prebuilt binaries</a> should |
| 490 | actually be statically linked this time (thanks Ashwini Sharma for spotting |
| 491 | that).</p> |
| 492 | |
| 493 | <p>It's hard to figure out where to cut a release, because development |
| 494 | doesn't stop. "Long before now" is the obviuos answer, of course. |
| 495 | The project's maintainer also moved house during this development cycle, which |
| 496 | threw things off for a bit (so many boxes). Releases should hopefully be a bit |
| 497 | more frequent from here on.</p> |
| 498 | |
| 499 | <p>The big things Rob worked on this time were the new dirtree (directory |
| 500 | tree traversal) infrastructure, and a complete rewrite of ls using that |
| 501 | which should now implement all 26 posix options.</p> |
| 502 | |
| 503 | <p>Georgi Chorbadzhiyski added printenv, whoami, mkdir, mkfifo, chmod, chown, |
| 504 | chgrp, and uniq. He also added fraction and extension support to sleep (so if |
| 505 | you need a quarter-second sleep, it can do that now), and fixed a build bug |
| 506 | on slackware.</p> |
| 507 | |
| 508 | <p>Daniel Walter contributed a string to mode_t parser (in use by chmod and |
| 509 | mkdir -m). Ilya Kuzmich contributed comm. Elie De Brauwer added mountpoint, |
| 510 | vmstat, logname, login, and mktemp. Kevin Chase did some portability cleanups. |
| 511 | Pere Orga fixed some documentation.</p> |
| 512 | |
| 513 | <p>The "tac" and "clear" commands are now normal commands instead of shell |
| 514 | wrappers, and the header #includes have been cleaned up a bit to remove |
| 515 | deprecated functions and attempt to increase compatability with the bionic and |
| 516 | musl C libraries, "tail" should now use lseek() for large files, and "id" got |
| 517 | some cleanups and bugfixes.</p> |
| 518 | |
| 519 | <p>The new TOYBOX_FLOAT configuration option selects whether or not |
| 520 | to include floating point support (for embedded targets where that's |
| 521 | problematic).</p> |
| 522 | |
| 523 | <p>Several random bugfixes: unshare() might actually build portably now, |
| 524 | yes 'n' | cp -i should no longer bypass stdin and prompt via the tty, the |
| 525 | SUID support no longer drops permissions going through the toybox |
| 526 | multiplexer command, and a bugfix to xargs -0 means it should no longer |
| 527 | segfault. (I have a pending bug report about xargs not doing the full |
| 528 | posix whitespace handling that -0 obsoleted, but I'll deal with that next |
| 529 | release.)</p> |
| 530 | |
| 531 | <p>The build infrastructure is now automatically generating FLAG_ macros |
| 532 | for the options, but currently with the wrong names. Some more macro glue |
| 533 | is necessary, which I haven't quite figured out how to do yet.</p> |
| 534 | |
| 535 | <p>A defconfig toybox at the start of the $PATH has successfully built |
| 536 | Linux From Scratch (in my Aboriginal Linux project). The commands that |
| 537 | 'default n' in the config are often still broken, cleanup is ongoing. |
| 538 | (The new dirtree stuff broke several of them that haven't been converted |
| 539 | yet, but if I wait until everything works we won't have a release before |
| 540 | 1.0, so here's a checkpoint.)</p> |
| 541 | |
| 542 | |
Rob Landley | ed6ed62 | 2012-03-06 20:49:03 -0600 | [diff] [blame] | 543 | <hr><b>March 3, 2012</b> |
| 544 | |
| 545 | <blockquote><p>"They went unnoticed at Goonhilly, passed over Cape Canaveral |
| 546 | without a blip, and Woomera and Jodrell Bank looked straight through them. |
| 547 | Which was a pity, because it was exactly the sort of thing they'd been looking |
| 548 | for all these years."</p></p>- The Hitchhiker's Guide to the Galaxy.</p> |
| 549 | </p></blockquote> |
| 550 | |
| 551 | <p>Here's <a href=downloads/toybox-0.2.1.tar.bz2>toybox 0.2.1</a> based |
| 552 | on <a href=http://landley.net/hg/toybox/shortlog/512>commit 512</a>. This |
| 553 | time around, there are statically linked <a href=downloads/binaries>prebuilt |
| 554 | binaries</a> for various embedded targets.</p> |
| 555 | |
| 556 | <p>It's been a busy few weeks, almost entirely due to new contributors. (I |
| 557 | have not quite been keeping up.)</p> |
| 558 | |
| 559 | <p>Elie De Brauwer contributed free, uptime, swapon, swapoff, lsmod, mknod, |
| 560 | insmod, rmmod, and fixed a bug in basename. Andre Renaud contributed ls, ln, |
| 561 | realpath, and hostname. Andres Heck contributed pidof and killall. Daniel |
| 562 | Walter wrote kill and extended id. Timothy Elliott contributed tail and tests |
| 563 | for cmp. Frank Bergmann sent a warning fix. Bryce Fricke added -i to cp. |
| 564 | Nathan McSween pointed out an optimization. Georgi Chorbadzhiyski fixed |
| 565 | cross compiling to work more reliably.</p> |
| 566 | |
| 567 | <p>(My own contribution this time around was just tightening up other people's |
| 568 | code, a build fix to unshare, some random bugfixes, and so on. My only new |
| 569 | code this time around was writing a bash replacement for the existing python |
| 570 | bloat-o-meter.)</p> |
| 571 | |
| 572 | <p>Last time (the 0.2.0 release) included the first pass at an id command from |
| 573 | Tim Bird, env and basename from Tryn Mirell, cmp and head from Timothy Elliott, |
| 574 | more bugfixes from Nathan McSween and Elie De Brauwer, and Luis Felipe Strano |
| 575 | Moraes did a first pass at the who command plus other bugfixes and |
| 576 | optimizations.</p> |
| 577 | |
| 578 | <p>(For that release I did xargs, cal, truncate, unlink, nohup, tty, wc, link, |
| 579 | dirname, unshare, and various infrastructure tweaks, but it took me 3 months |
| 580 | and those guys did their stuff in a week or so.)</p> |
| 581 | |
Rob Landley | e258af3 | 2008-01-05 18:09:49 -0600 | [diff] [blame] | 582 | |
Rob Landley | d11ac70 | 2012-02-13 21:16:03 -0600 | [diff] [blame] | 583 | <hr><b>February 12, 2012</b> |
| 584 | <blockquote><p> |
| 585 | "for though it has many omissions and contains much that is apocryphal, or at |
| 586 | least wildly inaccurate, it scores over the older, more pedestrian work in two |
| 587 | important respects..."</p> |
| 588 | <p> - The Hitchhiker's Guide to the Galaxy</p></blockquote> |
| 589 | |
| 590 | <p>Here's the first BSD licensed release, |
| 591 | <a href=downloads/toybox-0.2.0.tar.bz2>toybox-0.2.0</a>, more a synchronization |
| 592 | point than anything particularly useful. 47 commands in a reasonably |
| 593 | ready-to-use state (what "make defconfig" builds), another ten or so partially |
| 594 | finished stubs ("make allyesconfig"), and several |
| 595 | patches pending on the mailing list I need to review and merge.</p> |
| 596 | |
| 597 | <p>More to come...</p> |
| 598 | |
Rob Landley | ce8a267 | 2012-02-02 07:27:05 -0600 | [diff] [blame] | 599 | <hr> |
| 600 | <p><b>November 15, 2011</b> - Back from the dead, Toybox is now under a 2 |
| 601 | clause BSD license, and aiming to become the default command line |
| 602 | implementation of Android systems everywhere.</p> |
| 603 | |
| 604 | <p>More to come...</p> |
| 605 | |
| 606 | <hr> |
Rob Landley | 589f5cd | 2010-01-05 10:41:52 -0600 | [diff] [blame] | 607 | |
Rob Landley | aba5170 | 2012-08-26 16:33:06 -0500 | [diff] [blame] | 608 | <p><a href=oldnews.html>Old news</a> from before the relaunch.</p> |
Rob Landley | 589f5cd | 2010-01-05 10:41:52 -0600 | [diff] [blame] | 609 | |
| 610 | <!--#include file="footer.html" --> |