hush (a Bourne-style shell) for the GNO multitasking environment on the Apple IIgs
Go to file
2014-12-26 21:49:55 -06:00
coreutils Make test report EXEC files (shell scripts) as executable. 2014-12-04 13:41:21 -06:00
include Check for TERM changes every time we read input. 2014-12-24 14:54:06 -06:00
libbb Changes to support GNO-style PATH in type and source commands, and in tab completion. 2014-12-26 21:49:55 -06:00
notes Move all the source files to 15-character ProDOS-compatible file names. 2014-11-02 22:11:07 -06:00
shell Changes to support GNO-style PATH in type and source commands, and in tab completion. 2014-12-26 21:49:55 -06:00
.gitignore
.indent.pro
build.gs GNO Makefile updates 2014-12-15 16:35:34 -06:00
LICENSE
Makefile Update the makefile for building on modern *nix systems. Rename to "Makefile" so we can build with just "make." 2014-12-15 16:47:12 -06:00
Makefile.mk Reduce stack size to 3k. 2014-12-26 16:33:17 -06:00
README.md README format fix. 2014-12-15 21:48:31 -06:00
texttogs Set things up so hush can be build with debug code turned on. 2014-11-06 11:42:17 -06:00

The hush shell for GNO

This is a port of the hush shell to the GNO multitasking environment for the Apple IIgs. Hush is a Bourne/POSIX-style shell that was originally part of BusyBox. In general, it implements most of the features you would expect, although there are a few missing ones (such as tilde expansion and aliases).

Supported features include:

  • if/then/elif/else/fi conditionals
  • for/in/do/done loops
  • while loops
  • case/esac
  • functions
  • redirections (including specifying file descriptors)
  • here documents
  • arithmetic with $((...))
  • command substitution with backticks or $(...)
  • glob pattern expansion (including globbing across multiple directory levels)
  • command line editing with history and tab completion
  • job control
  • and much more...

Installation

To use hush, you need GNO 2.0.6. Just copy the "hush" binary to a suitable location. (You may want to install it as /bin/sh to support portable scripts that expect a Bourne-type shell in that location).

To build it, you also need ORCA/C 2.1.x and plenty of memory (8MB is enough). Run make or (if the source files don't have correct filetypes) ./build.gs. You should also be able to build it on modern *nix systems by running make, although this is meant mainly for testing purposes.

GNO-specific notes and known issues

  • $PATH is expected to be in the usual GNO format (searched backwards, with spaces as separators).

  • File descriptors 0, 1, and 2 appearing in shell operations like redirections are translated to 1, 2, and 3, respectively. This maintains compatibility with Unix shell scripts that expect these to be stdin, stdout, and stderr.

  • Glob expansion doesn't work with patterns containing : directory separators. Use / separators instead.

  • Hush currently crashes when used interactively in TMTerm or GSI (scripts should work, though).

License

Hush is licensed under the GNU General Public License version 2, contained in the file LICENSE. Some individual source files contain code licensed under other GPL-compatible permissive licenses. See the individual source files for full licensing details and copyright notices.

The compiled hush binary also contains code from the ORCA/C runtime libraries, to which the following notice applies:

This program contains material from the ORCA/C Run-Time Libraries, copyright 1987-1996 by Byte Works, Inc. Used with permission.