mirror of
https://github.com/GnoConsortium/gno.git
synced 2024-11-18 19:09:31 +00:00
1850 lines
74 KiB
HTML
1850 lines
74 KiB
HTML
|
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
|
||
|
<html>
|
||
|
|
||
|
<head>
|
||
|
<meta http-equiv="Content-Type"
|
||
|
content="text/html; charset=iso-8859-1">
|
||
|
<meta name="GENERATOR" content="Microsoft FrontPage 2.0">
|
||
|
<title>GNO Shell User's Manual</title>
|
||
|
</head>
|
||
|
|
||
|
<body bgcolor="#FFFFFF">
|
||
|
|
||
|
<p><font size="6" face="Times">Chapter 5</font></p>
|
||
|
|
||
|
<p><font size="6" face="Times">Shell Variables</font></p>
|
||
|
|
||
|
<p align="right"><font size="2" face="Times">And then one day,
|
||
|
hurray! Another way for gnomes to say hooray!</font></p>
|
||
|
|
||
|
<p align="right"><font size="2" face="Times">Syd Barret, <u>The
|
||
|
Gnome</u></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>Using shell variables</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>gsh</b> supports <b>variables</b> in the
|
||
|
shell environment. These variables can be used by any shell
|
||
|
utility or script. Many EXE files and shell scripts pre-define
|
||
|
certain shell variables that contain formatting options or other
|
||
|
options for a specific utility. As an example, the <b>ls</b>
|
||
|
utility looks for the variable </font><font size="2"
|
||
|
face="Courier">TERM</font><font face="Times"> that defines the
|
||
|
terminal type currently being used. When <b>ls</b> is started, it
|
||
|
reads the value of the </font><font size="2" face="Courier">TERM</font><font
|
||
|
face="Times"> variable and avoids printing Apple II specific
|
||
|
MouseText characters if the set terminal does not support them.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>gsh</b> has set aside certain variables
|
||
|
for its specific use. Shell utilities should be aware of these
|
||
|
variables and use them appropriately. Use caution when changing
|
||
|
shell variables, because the change could affect more than just
|
||
|
the shell.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>of Shell Variables</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">There are two types of processes that are
|
||
|
involved in any discussion of a multitasking system.The original
|
||
|
process, <b>gsh</b> for example, is called a parent process. If <b>gsh</b>
|
||
|
invokes a process, such as <b>ls</b>, <b>cp</b>, or <b>mv</b>,
|
||
|
that process is called a child process. It is possible for any
|
||
|
process to define a variable. These variables will not be made
|
||
|
available to other processes unless the program that defined the
|
||
|
variable specifically makes them available. </font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">The <i>export</i> command makes variables
|
||
|
defined by one process available to its children. See the example
|
||
|
<i>gshrc</i> shell script shown in Chaper 1 <b>Customizing the
|
||
|
Shell Environment</b>. In the case of the shell, most of its
|
||
|
variables are exported and, therefore, all shell utilities can
|
||
|
read the value of a shell variable. However, programs cannot
|
||
|
change the value of a shell variable. In general, executables
|
||
|
share their environment with that of the shell, so that a utility
|
||
|
can change variables in its parent's environment. This allows
|
||
|
communication between programs and the shell.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>Description of Pre-defined Shell
|
||
|
Variables</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font face="Times">The following variables have special
|
||
|
meaning to <b>gsh</b>. Shell variables are not case sensitive.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<dir>
|
||
|
<li><font size="2" face="Courier">$0, $1, $2, ...</font><p><font
|
||
|
face="Times">String values that contain the arguments to
|
||
|
a shell script. Variable 0 contains the name of the
|
||
|
script. The first argument begins with variable 1 and so
|
||
|
on. To expand a variable, use the dollar character,
|
||
|
"$" (See Chapter 5 <b>Accessing shell variables</b>)</font></p>
|
||
|
<p><font size="2" face="Courier">$<</font><font
|
||
|
face="Times"> When encountered, the variable is expanded
|
||
|
using a value obtained from standard input. This provides
|
||
|
a means of obtaining user input in script files. Note
|
||
|
that the shell variables are expanded before the
|
||
|
command-line is executed (See Chapter 5 <b>Accessing
|
||
|
shell variables</b>) When prompting the user for input,
|
||
|
be sure that the prompt is in a separate command-line
|
||
|
than the $<. Also, if the user wishes to enter a value
|
||
|
with spaces, he must quote what he types with
|
||
|
double-quotes.</font></p>
|
||
|
<p><font size="2" face="Courier">$ECHO</font><font
|
||
|
face="Times"> A boolean value that, if defined, will
|
||
|
cause commands in a shell script to be echoed to standard
|
||
|
output.</font></p>
|
||
|
<p><font size="2" face="Courier">$FIGNORE </font><font
|
||
|
face="Times">This variable, if set, contains a list of
|
||
|
filename suffixes. When doing command or filename
|
||
|
completion, <b>gsh</b> will ignore any filename with a
|
||
|
suffix listed in </font><font size="2" face="Courier">FIGNORE</font><font
|
||
|
face="Times">. For example, you might want to </font><font
|
||
|
size="2" face="Courier">set fignore=".A .ROOT .SYM"</font><font
|
||
|
face="Times"> to ignore object files and other compiler
|
||
|
droppings.</font></p>
|
||
|
<p><font size="2" face="Courier">$HISTORY</font><font
|
||
|
face="Times"> A numeric value that contains the number of
|
||
|
history commands (command-lines) remembered. If the value
|
||
|
is 0 or </font><font size="2" face="Courier">HISTORY</font><font
|
||
|
face="Times"> is undefined, all commands will be
|
||
|
remembered. Previous command-lines can be called back
|
||
|
with the UP-ARROW and DOWN-ARROW (See Chapter 2<b>,
|
||
|
History Editing Commands</b>).</font></p>
|
||
|
<p><font size="2" face="Courier">$HOME</font><font
|
||
|
face="Times"> The </font><font size="2" face="Courier">HOME</font><font
|
||
|
face="Times"> directory is the main directory of the
|
||
|
shell; it is the directory <b>gsh</b> defaults to when it
|
||
|
starts. The tilde character ("~") can be used
|
||
|
as a shorthand method of accessing the </font><font
|
||
|
size="2" face="Courier">HOME</font><font face="Times">
|
||
|
directory (as discussed in Chapter 3, <b>Tilde Expansion</b>).</font></p>
|
||
|
<p><font size="2" face="Courier">$IGNOREEOF </font><font
|
||
|
face="Times">A boolean value that, if enabled, will
|
||
|
prevent ^D from exiting the shell.</font></p>
|
||
|
<p><font size="2" face="Courier">$NOBEEP</font><font
|
||
|
face="Times"> A boolean value that, if set, will prevent <b>gsh</b>
|
||
|
from sounding the speaker when errors occur while editing
|
||
|
a command-line.</font></p>
|
||
|
<p><font size="2" face="Courier">$NODIREXEC</font><font
|
||
|
face="Times"> A boolean value that, if set, will disable <b>gsh</b>'s
|
||
|
feature of treating directory names as commands; i.e. if
|
||
|
a directory is specified as a command, <b>gsh</b> will
|
||
|
move to that directory as though the cd command was being
|
||
|
used.</font></p>
|
||
|
<p><font size="2" face="Courier">$NOGLOB</font><font
|
||
|
face="Times"> A boolean value that, if enabled, will
|
||
|
disable filename globbing. Command arguments will be
|
||
|
passed to their commands "as-is", without any
|
||
|
wildcard expansion.</font></p>
|
||
|
<p><font size="2" face="Courier">$NONEWLINE</font><font
|
||
|
face="Times"> A boolean value that, if set, will disable
|
||
|
carriage returns being output before and after command
|
||
|
execution. Previous examples given in this manual have
|
||
|
this option set.</font></p>
|
||
|
<p><font size="2" face="Courier">$PATH</font><font
|
||
|
face="Times"> A string value that defines the pathnames
|
||
|
where shell scripts, EXE utilities, and SYS16 programs
|
||
|
can be found (See <b>Chapter 3, How gsh finds a command</b>).
|
||
|
Because GS/OS uses colons as separators in pathnames, <b>gsh</b>
|
||
|
cannot allow colons to be used as separators in the PATH
|
||
|
variable, as U</font><font size="2" face="Times">NIX</font><font
|
||
|
face="Times"> does. If one of the path entries has a
|
||
|
space within it (which is possible with the HFS FST),
|
||
|
then the space should be quoted with a backslash,
|
||
|
"\".</font></p>
|
||
|
<p><font size="2" face="Courier">$PRECMD </font><font
|
||
|
face="Times">Actually an <u>alias</u> and not a variable,
|
||
|
if </font><font size="2" face="Courier">PRECMD</font><font
|
||
|
face="Times"> is defined it will be executed just before
|
||
|
gsh prints the prompt for a command line. For example, </font><font
|
||
|
size="2" face="Courier">alias precmd qtime</font><font
|
||
|
face="Times"> will print the time in English text before
|
||
|
every prompt.</font></p>
|
||
|
<p><font size="2" face="Courier">$PROMPT</font><font
|
||
|
face="Times"> When <b>gsh</b> prompts you to enter a
|
||
|
command, the prompt that appears before the cursor can be
|
||
|
customized for your <b>gsh</b> environment. If </font><font
|
||
|
size="2" face="Courier">PROMPT</font><font face="Times">
|
||
|
is undefined, the default prompt of "% " is
|
||
|
used. The prompt string recognizes certain character
|
||
|
sequences in the </font><font size="2" face="Courier">PROMPT</font><font
|
||
|
face="Times"> variable and interprets them accordingly.
|
||
|
The following are the special characters:</font></p>
|
||
|
<p><font size="2" face="Courier">%h, %!, !</font><font
|
||
|
face="Times"> Current history number.</font></p>
|
||
|
<p><font size="2" face="Courier">%t, %@</font><font
|
||
|
face="Times"> Current time of day in 12 hour am/pm
|
||
|
format.</font></p>
|
||
|
<p><font size="2" face="Courier">%d, %/</font><font
|
||
|
face="Times"> Current working directory.</font></p>
|
||
|
<p><font size="2" face="Courier">%~</font><font
|
||
|
face="Times"> Current working directory with tilde
|
||
|
("</font><font size="2" face="Courier">~</font><font
|
||
|
face="Times">") replacement.</font></p>
|
||
|
<p><font size="2" face="Courier">%c, %C, %.</font><font
|
||
|
face="Times"> Trailing component of current working
|
||
|
directory.</font></p>
|
||
|
<p><font size="2" face="Courier">%S, %s</font><font
|
||
|
face="Times"> Inverse mode ON (</font><font size="2"
|
||
|
face="Courier">%S</font><font face="Times">) / OFF (</font><font
|
||
|
size="2" face="Courier">%s</font><font face="Times">).</font></p>
|
||
|
<p><font size="2" face="Courier">%U, %u</font><font
|
||
|
face="Times"> Begin and end Underline mode (only on
|
||
|
terminals that support underline. </font><font size="2"
|
||
|
face="Courier">gnocon</font><font face="Times"> will use
|
||
|
inverse mode instead.)</font></p>
|
||
|
<p><font size="2" face="Courier">%%</font><font
|
||
|
face="Times"> Displays a single "</font><font
|
||
|
size="2" face="Courier">%</font><font face="Times">"
|
||
|
character.</font></p>
|
||
|
<p><font size="2" face="Courier">%n</font><font
|
||
|
face="Times"> User name (contents of </font><font
|
||
|
size="2" face="Courier">$USER</font><font face="Times">
|
||
|
variable).</font></p>
|
||
|
<p><font size="2" face="Courier">%W</font><font
|
||
|
face="Times"> The date in mm/dd/yy format.</font></p>
|
||
|
<p><font size="2" face="Courier">%D</font><font
|
||
|
face="Times"> The date in yy-mm-dd format.</font></p>
|
||
|
<p><font size="2" face="Courier">\n</font><font
|
||
|
face="Times"> Newline</font></p>
|
||
|
<p><font size="2" face="Courier">\r</font><font
|
||
|
face="Times"> Carriage Return</font></p>
|
||
|
<p><font size="2" face="Courier">\t</font><font
|
||
|
face="Times"> Tab</font></p>
|
||
|
<p><font size="2" face="Courier">\b</font><font
|
||
|
face="Times"> Bell (beep)</font></p>
|
||
|
<p><font face="Times">Examples of prompts already used in
|
||
|
this manual are "</font><font face="Courier">[1]%</font><font
|
||
|
face="Times">", and "</font><font
|
||
|
face="Courier">[/user/root]%</font><font face="Times">"</font></p>
|
||
|
<p><font face="Times">These were created by using the
|
||
|
commands <b>set prompt "[%h]</b></font><font
|
||
|
face="Courier"><b>%</b></font><font face="Times">"
|
||
|
and <b>set prompt "[%d]</b></font><font
|
||
|
face="Courier"><b>%</b></font><font face="Times"><b>"</b>.</font></p>
|
||
|
<p><font size="2" face="Courier">$PUSHDSILENT</font></p>
|
||
|
<p><font face="Times">If this variable is defined, <b>gsh</b>
|
||
|
will not print the directory stack after any of the
|
||
|
directory stack commands (See Chapter 4 </font><font
|
||
|
size="2" face="Courier"><b>pushd</b></font><font
|
||
|
face="Times">, </font><font size="2" face="Courier"><b>popd</b></font><font
|
||
|
face="Times">, .) </font></p>
|
||
|
<p><font size="2" face="Courier">$SAVEHIST</font><font
|
||
|
face="Times"> A numeric value that contains the number of
|
||
|
commands to save to disk when exiting <b>gsh</b>. These
|
||
|
commands are then read back in when <b>gsh</b> is
|
||
|
restarted which allows old commands to be reused. If the
|
||
|
value is 0 or </font><font size="2" face="Courier">SAVEHIST</font><font
|
||
|
face="Times"> is undefined, no commands will be saved to
|
||
|
disk.</font></p>
|
||
|
<p><font size="2" face="Courier">$TERM </font><font
|
||
|
face="Times">This variable contains the name of the
|
||
|
terminal emulation that the shell and other applications
|
||
|
should use. By default, it is '</font><font size="2"
|
||
|
face="Courier">gnocon</font><font face="Times">'. When
|
||
|
the shell encounters a '</font><font size="2"
|
||
|
face="Courier">set term</font><font face="Times">'
|
||
|
command, it automatically calls the </font><font size="2"
|
||
|
face="Courier"><b>tset</b></font><font face="Times">
|
||
|
command to reload the termcap information. See Appendix F
|
||
|
<b>Termcaps</b>.</font></p>
|
||
|
<p><font size="2" face="Courier">$TERMCAP </font><font
|
||
|
face="Times">This variable specifies the location of the <i>termcap</i>
|
||
|
file. The shell and other applications look for <i>termcap</i>
|
||
|
in the /etc directory, but if </font><font size="2"
|
||
|
face="Courier">TERMCAP</font><font face="Times"> is set,
|
||
|
the fully specified termcap file is used instead. This
|
||
|
allows users to install custom termcap entries. See
|
||
|
Appendix F <b>Termcaps</b>.</font></p>
|
||
|
<p><font size="2" face="Courier">$USER</font><font
|
||
|
face="Times"> A string that represents the name of the
|
||
|
current user. This variable is usually set by <b>login</b>(1).</font></p>
|
||
|
</li>
|
||
|
</dir>
|
||
|
|
||
|
<p><font face="Times"><b>Accessing shell variables</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">Shell variables are defined or changed with
|
||
|
the </font><font size="2" face="Courier">set</font><font
|
||
|
face="Times"> command. The </font><font size="2" face="Courier">unset</font><font
|
||
|
face="Times"> command is used to delete a variable. See Chapter 4
|
||
|
<b>Environment Commands</b> for more information on the </font><font
|
||
|
size="2" face="Courier">set</font><font face="Times"> and </font><font
|
||
|
size="2" face="Courier">unset</font><font face="Times"> commands</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">To access shell variables from the command
|
||
|
line or a shell script, use the character "$" followed
|
||
|
by the variable name. The dollar sign character will expand the
|
||
|
variable to its value. If you wish to use the dollar sign
|
||
|
character in a string from the command line, remember to enclose
|
||
|
it in single quotes or use the "\" escape character. If
|
||
|
you use double quotes, the shell will try to expand the variable.
|
||
|
To differentiate the variable name from characters that may
|
||
|
immediately follow it, the variable name may be optionally
|
||
|
surrounded with braces, "{" and "}".This
|
||
|
provides a very powerful way of user interaction with shell
|
||
|
scripts. As an example,</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[1] 9:41pm root> <b>set</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PAGER = less</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">SAVEHIST = 25</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PATH = :hard:gno:bin
|
||
|
:right:gno:usr:bin</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">USRMAN = /usr/man</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">HISTORY = 100</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">status = 0</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">fignore = .a .root .sym</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">TERM = gnocon</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">LESS = -e</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PROMPT = [%h] %S%t%s %C> </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">HOME = :hard:gno:user:root</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">user = root</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">nonewline = 1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[2] 9:41pm root> <b>set
|
||
|
history 30 user user1 ; set</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PAGER = less</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">SAVEHIST = 25</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PATH = :hard:gno:bin
|
||
|
:right:gno:usr:bin</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">USRMAN = /usr/man</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">HISTORY = 30</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">status = 0</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">fignore = .a .root .sym</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">TERM = gnocon</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">LESS = -e</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PROMPT = [%h] %S%t%s %C> </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">HOME = :hard:gno:user:root</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">user = user1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">nonewline = 1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[3] 9:41pm root> <b>unset
|
||
|
savehist ; set</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PAGER = less</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PATH = :hard:gno:bin
|
||
|
:hard:gno:usr:bin</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">USRMAN = /usr/man</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">HISTORY = 30</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">status = 0</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">fignore = .a .root .sym</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">TERM = gnocon</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">LESS = -e</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">PROMPT = [%h] %S%t%s %c> </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">HOME = :hard:gno:user:root</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">user = user1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">nonewline = 1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[6] 9:43pm root> <b>echo
|
||
|
'Current value of $path = ' $path</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">Current value of $path =
|
||
|
:right:gno:bin :right:gno:usr:bin </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[7] 9:44pm root> <b>echo
|
||
|
"value of $path = " $path</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">value of :right:gno:bin
|
||
|
:right:gno:usr:bin = :right:gno:bin :right:gno:usr:bin </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[9] 9:45pm root> <b>set user1
|
||
|
foo</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[10] 9:45pm root> <b>echo
|
||
|
$user1</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">foo </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[11] 9:45pm root> <b>echo
|
||
|
${user}1</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">user11 </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[12] 9:46pm root> <b>echo
|
||
|
"echo '\$path = ' \$path" >> change.path</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[13] 9:46pm root> <b>echo
|
||
|
"set path \$1" >> change.path</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[14] 9:47pm root> <b>echo
|
||
|
'rehash' >> change.path</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[15] 9:47pm root> <b>cat
|
||
|
change.path</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">echo '$path = ' $path</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">set path $1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">rehash</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[16] 9:48pm root> <b>change.path
|
||
|
'/dev/gno/utilities'</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">$path = /dev/gno/orca
|
||
|
/dev/gno/utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">hashed 22 files.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[17] 9:49pm root> <b>change.path
|
||
|
$PATH</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">$path = /dev/gno/orca
|
||
|
/dev/gno/utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">hashed 55 files.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[18] 9:50pm root> <b>echo
|
||
|
this is $homeplate</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">this is </font><font size="2"
|
||
|
face="Times">{ variable </font><font size="2" face="Courier">homeplate</font><font
|
||
|
size="2" face="Times"> wasn't found }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[19] 9:51pm root> <b>echo
|
||
|
this is ${home}plate</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">this is /dev/gnoplate </font><font
|
||
|
size="2" face="Times">{ variable </font><font size="2"
|
||
|
face="Courier">home</font><font size="2" face="Times"> is found }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b></b></font> </p>
|
||
|
|
||
|
<p><font size="6" face="Times">Appendix A</font></p>
|
||
|
|
||
|
<p><font size="6" face="Times">Sample gsh session</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">The following represents a sample session
|
||
|
in gsh. Many of the features discussed in this manual are
|
||
|
reviewed here. Comments are enclosed in braces ("{}").</font></p>
|
||
|
|
||
|
<p> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[1] gno> <b>set</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">savehist = 25</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">path = /dev/orca/utilities
|
||
|
/dev/gno/orca /dev/gno/utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">history = 25</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prompt = [%h] %C> </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">user = achin</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">home = /dev/gno</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">nonewline = 1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[2] gno> <b>echo environment
|
||
|
variable PROMPT = $PROMPT</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">environment variable PROMPT =
|
||
|
[%h] %C></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[3] gno> <b>cat gshrc</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ <b>gshrc</b> is the startup
|
||
|
file. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">###</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"># GNO 2.0 gshrc file</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">###</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"># Initialize our environment</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">set path=":hard:gno:bin
|
||
|
:right:gno:usr:bin"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">set prompt="[%h] %S%t%s
|
||
|
%C> "</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">set
|
||
|
home=":hard:gno:user:root"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">set term=gnocon</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">export path prompt home term</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">setenv history=100 savehist=25</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">###</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#Set up standard prefixes for
|
||
|
utilities.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">###</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 2
|
||
|
:software:orca:libraries</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 3 :software:orca</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 4 :software:orca:shell</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 5
|
||
|
:software:orca:languages</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 6
|
||
|
:software:orca:utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 7 :tmp</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">###</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"># Set up prefixes for
|
||
|
Orca2.0(tm)'s benefit</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">###</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 13
|
||
|
:software:orca:libraries</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 14 :software:orca</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 15 :software:orca:shell</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 16
|
||
|
:software:orca:languages</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prefix 17
|
||
|
:software:orca:utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">alias ls 'ls -CF'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">alias dir 'ls -al'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">alias cp 'cp -i'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">alias rm 'cp -p rm'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">alias mv 'cp -p mv'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">setenv usrman='/usr/man'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">set fignore='.a .root .sym'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">alias zcat 'compress -cd'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">setenv pager=less</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">setenv less=-e</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">set nonewline=1</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"># Move to home directory</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">#</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">cd</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[4] gno> <b>cat gshrc >
|
||
|
.ttyb&</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ <b>.ttyb</b> is the printer
|
||
|
connected to the printer port. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[2]</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[5] gno> <b>echo File
|
||
|
\'gshrc\' sent to printer.</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">File 'gshrc' sent to printer.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[6] gno> <b>alias l 'ls -F';
|
||
|
l</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ The ls "-F" option
|
||
|
displays executable and directory files differently. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">:dev:gno</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">doc/ foo* gsh* gshrc* kern*</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">man/ message message2 orca/
|
||
|
press.release </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">release.notes samples/ todo
|
||
|
updates utilities/</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[7] gno> <b>history</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">1: set</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">2: echo environment variable
|
||
|
PROMPT = $PROMPT</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">3: cat .gshrc</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">4: cat .gshrc > .printer&</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">5: echo File \'gshrc\' sent to
|
||
|
printer.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">6: ls</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">7: history</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[8] gno> <b>no_file</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">no_file: Command not found.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[9] gno> <b>message</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">message: Not executable.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[10] gno> <b>unset USER</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ Environment variables are not
|
||
|
case sensitive. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[11] gno> <b>set PATH</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">path = /dev/orca/utilities
|
||
|
/dev/gno/orca /dev/gno/utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[12] gno> <b>set PROMPT</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">prompt = [%h] %C></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[13] gno> <b>unset PROMPT</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>cp message message2&</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[2]</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>rm doc&</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">rm: :dev:gno:doc directory</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>rm -r doc&</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[3]</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>ls *</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">:dev:gno</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">foo* gsh* gshrc* kern* man/</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">message message2 orca/
|
||
|
press.release release.notes</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">samples/ todo updates utilities/</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>echo *</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">gshrc foo message Finder.Data
|
||
|
utilities press.release man release.notes todo</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">updates gsh kern samples doc
|
||
|
orca message2</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>echo g* m*</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">gshrc gsh message man message2</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>echo g?</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">No match.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>pwd</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">/dev/gno</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>clear ; df</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">.d## Volume Device Free Total
|
||
|
Capacity System</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">---- ----------------
|
||
|
---------------- ------- ------- -------- -----------</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">.d1 :system .APPLESCSI.HD01.
|
||
|
25746 50773 49% ProDOS</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">.d2 :dev .APPLESCSI.HD01. 44868
|
||
|
65108 31% ProDOS</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">.d3 :usr .APPLESCSI.HD01. 44526
|
||
|
48725 8% ProDOS</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">.d4 :ram5 .DEV2 493 512 3%
|
||
|
ProDOS</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>which ls cp echo ps</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ls: /dev/gno/utilities/ls</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">cp: /dev/gno/utilities/cp</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">echo: Shell Built-in Command</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps: Shell Built-in Command</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>echo -n foo</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">foo % <b>l .dev2
|
||
|
.applescsi.hd01.01</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ Because of the previous
|
||
|
"echo -n", the </font><font size="2" face="Courier">PROMPT</font><font
|
||
|
size="2" face="Times"> is displayed on the line where echo output
|
||
|
ended. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">:ram5</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">df echo history ls ls.ram5 </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ls.system prefix ps set which</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">:system</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">AppleworksGS/ BASIC.System*
|
||
|
HyperCard/ ProDOS* a2fx/</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">basic.launcher* emacs.icon
|
||
|
fontasm/ gutenberg/ icons/</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">kermit/ publish.it/ review
|
||
|
shr.pic/ shrinkit/</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">snowterm/ system/</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>alias print 'echo'; alias
|
||
|
copy 'cp'; alias delete 'rm'; alias</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b>catalog 'ls -l'; alias rename
|
||
|
'mv'</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ Useful aliases for Orca fans. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>alias</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">l: ls -F</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">print: echo</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">copy: cp</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">delete: rm</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">catalog: ls -l</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">rename: mv</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">% <b>set PROMPT='[!] %C> '</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[30] gno> <b>cd samples</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[31] samples> <b>cmpl ps.c
|
||
|
keep=ps > .dev2/ps&</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[2]</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[32] samples> <b>cmpl kill.c
|
||
|
keep=kill > .dev2/kill&</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[3]</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[34] samples> <b>ls dummy_dir</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[35] samples> <b>ls -9</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ls: unrecognized option `-9'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">usage: ls [-acdfgilqrstu1ACLFR]
|
||
|
[name ...]</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[36] samples> <b>ls -9
|
||
|
>& .dev2/error</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">{ Each pathname has a device
|
||
|
name entry (cf. ps). }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[37] samples> <b>cat <
|
||
|
/ram5/error</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ls: unrecognized option `-9'</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">usage: ls [-acdfgilqrstu1ACLFR]
|
||
|
[name ...]</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[38] samples> <b>ls *.c;grep
|
||
|
\#\i\n\c\l\u\d\e [^sfd]*.c</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ grep searches for a regular
|
||
|
expression in a file and outputs the lines that match. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c dp.c edit.c ffdir.c gar.c</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">kill.c link.c ps.c setdebug.c</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">kill.c:#include <stdio.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">kill.c:#include <memory.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">kill.c:#include
|
||
|
"3/work/gno/conf.h"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">kill.c:#include
|
||
|
"3/work/gno/proc.h"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">kill.c:#include
|
||
|
"3/work/gno/kerntool.h"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">gar.c:#include <stdio.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">gar.c:#include <orca.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">gar.c:#include
|
||
|
"3/work/gno/kerntool.h"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">gar.c:#include
|
||
|
<gno/signal.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps.c:#include <stdio.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps.c:#include <memory.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps.c:#include <string.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps.c:#include <orca.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps.c:#include
|
||
|
"3/work/gno/conf.h"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps.c:#include
|
||
|
"3/work/gno/proc.h"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">ps.c:#include
|
||
|
"3/work/gno/kvm.h"</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <stdio.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <stdlib.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <string.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <ctype.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <types.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <gsos.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <shell.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <orca.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include <stddef.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include
|
||
|
<texttool.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">edit.c:#include
|
||
|
<gno/kerntool.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <stdio.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <stdlib.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <string.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <ctype.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <types.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <shell.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <gsos.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include <orca.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include
|
||
|
<texttool.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">comp.c:#include
|
||
|
<gno/kerntool.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include <stdio.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include <stdlib.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include <string.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include <ctype.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include <types.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include <shell.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include <orca.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include
|
||
|
<texttool.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">link.c:#include
|
||
|
<gno/kerntool.h></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[39] samples> <b>head link.c</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ head displays the first few
|
||
|
lines of a file. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">/* </font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">parsing code for compile, cmpl,
|
||
|
cmplg</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">The options flags are set up in
|
||
|
a bizarre format as follows:</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">76543210 76543210 76543210
|
||
|
76543210</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">yz qrstuvwx ijklmnop abcdefgh</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[40] samples> <b>set PATH</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">path =
|
||
|
/dev/orca/utilities:/dev/gno/orca:/dev/gno/utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[41] samples> <b>unset PATH</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[42] samples> <b>set PATH</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">Variable Not Found</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[43] samples> <b>rm
|
||
|
m[e][s][s]age[2]</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[44] samples> <b>rehash</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">hashed 0 files.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[45] samples> <b>rm who_cares
|
||
|
about_the parameters</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ rm will not be recognized as a
|
||
|
command because the hash-table is empty. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">rm: Command not found.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[46] samples> <b>set path =
|
||
|
/dev/orca/utilities ~/orca ~/utilities</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">/dev/orca/utilities
|
||
|
/dev/gno/orca /dev/gno/utilities =</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[47] samples> <b>set PATH</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">path = =</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[48] samples> <b>set
|
||
|
path="~/../orca/utilities ~/orca $HOME/utilities"</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Times">{ Filename expansion will be
|
||
|
performed before PATH is set. }</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[49] samples> <b>set path</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier">path = /dev/orca/utilities
|
||
|
/dev/gno/orca /dev/gno/utilities</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">[49] samples> <b>rehash</b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier">hashed 68 files.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"></font> </p>
|
||
|
|
||
|
<p><font size="6" face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="6" face="Times">Appendix B</font></p>
|
||
|
|
||
|
<p><font size="6" face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">When <b>gsh</b> is started, GS/OS assigns
|
||
|
certain values to individual prefixes, and usually the <i>gshrc</i>
|
||
|
file also sets some prefixes. A total of 32 prefixes are
|
||
|
available to the user. The following list documents each prefix
|
||
|
and the purpose of each.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<dir>
|
||
|
<li><font face="Times"><u>Number</u> <u>Description</u></font><p><font
|
||
|
face="Times">@ AppleShare prefix. If GNO resides on an
|
||
|
AppleShare volume, this prefix is set to the pathname of
|
||
|
the user's directory on the file server; otherwise, this
|
||
|
prefix is set to the same pathname as prefix number 9.</font></p>
|
||
|
<p><font face="Times">* Boot volume prefix. It is not
|
||
|
possible to modify the value of this prefix with the
|
||
|
shell's </font><font size="2" face="Courier">prefix</font><font
|
||
|
face="Times"> command. The only other way to access this
|
||
|
prefix is the GS/OS _GetBootVol call.</font></p>
|
||
|
<p><font face="Times">0 Prefix 0 is the current working
|
||
|
directory. It is the prefix that is changed by the </font><font
|
||
|
size="2" face="Courier">cd</font><font face="Times">
|
||
|
command.</font></p>
|
||
|
<p><font face="Times">1 Directory a program resides in.
|
||
|
In the shell, this is usually /bin. The kernel sets this
|
||
|
prefix (and 9/) appropriately for each program that is
|
||
|
executed.</font></p>
|
||
|
<p><font face="Times">2-8 Used by Orca 1.0 languages and
|
||
|
utilities</font></p>
|
||
|
<p><font face="Times">2 If the ORCA languages are being
|
||
|
used, prefix 2 points to the ORCA Libraries directory.</font></p>
|
||
|
<p><font face="Times">3 This prefix should point to the
|
||
|
directory that contains ORCA.SYS16.</font></p>
|
||
|
<p><font face="Times">4 ORCA Shell directory should point
|
||
|
to the directory that contains the EDITOR, SYSTABS,
|
||
|
SYSCMND, etc. files.</font></p>
|
||
|
<p><font face="Times">5 ORCA Languages directory</font></p>
|
||
|
<p><font face="Times">6 ORCA Utilities directory</font></p>
|
||
|
<p><font face="Times">7 ORCA Temp directory - setting
|
||
|
this to a RAM disk makes certain editor operations
|
||
|
faster.</font></p>
|
||
|
<p><font face="Times">9 Same as prefix 1/</font></p>
|
||
|
<p><font face="Times">10-12 Standard input, output, and
|
||
|
error device names. GNO sets these to be '.ttyco'.</font></p>
|
||
|
<p><font face="Times">13 Same as prefix 2/ above if Orca
|
||
|
2.0 languages are being used.</font></p>
|
||
|
<p><font face="Times">14 Same as prefix 3/</font></p>
|
||
|
<p><font face="Times">15 Same as prefix 4/</font></p>
|
||
|
<p><font face="Times">16 Same as prefix 5/</font></p>
|
||
|
<p><font face="Times">17 Same as prefix 6/</font></p>
|
||
|
<p><font face="Times">18 Same as prefix 7/</font></p>
|
||
|
</li>
|
||
|
</dir>
|
||
|
|
||
|
<p><font size="6" face="Times">Appendix C</font></p>
|
||
|
|
||
|
<p><font size="6" face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>gsh</b> tries, when an error occurs, to
|
||
|
output an informative error message that will lead you to the
|
||
|
solution of your problem. This appendix documents all <b>gsh</b>
|
||
|
error messages and what the probable cause of the problem might
|
||
|
be. There are five classes of errors: generic gsh, command-entry,
|
||
|
syntax, execution, and built-in. Each error is discussed
|
||
|
separately.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>Generic gsh Errors</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">These errors can typically occur at any
|
||
|
time and may not be directly related to something the user has
|
||
|
done. Some of them are trivial, and some are very serious and
|
||
|
should be reported immediately.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: There are stopped
|
||
|
jobs.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">All jobs must be killed before exiting the
|
||
|
shell. Use the jobs and kill commands.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>Command Editing Errors</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">Command editing errors occur when entering
|
||
|
information on the command-line. If you try to move the cursor
|
||
|
too far to the left or right of your command-line (i.e. before
|
||
|
the first character or after the last character), an error will
|
||
|
occur. At present, gsh indicates a command-entry error with a </font><font
|
||
|
size="2" face="Courier"><b><i>Beep</i></b></font><font
|
||
|
face="Times">. This is to notify you that the action you
|
||
|
requested is not possible.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>Syntax Errors</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">Syntax errors occur while gsh is trying to
|
||
|
understand the command you have entered on the command-line.
|
||
|
Problems arise when you wish to quote an argument (") and
|
||
|
only enter one quote.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: Missing ending
|
||
|
".</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">A second " wasn't supplied when
|
||
|
quoting text.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: Missing ending '.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">A second ' wasn't supplied when quoting
|
||
|
text.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: Too many arguments,
|
||
|
so no dessert tonight.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">The command-line contained too many
|
||
|
arguments which exceeded the available memory allocated by <b>gsh</b>.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: Not enough memory for
|
||
|
arguments.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">No memory was available for allocating
|
||
|
command-line arguments.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: Extra '<'
|
||
|
encountered.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: Extra '>' or
|
||
|
'>>' encountered.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: Extra '>&' or
|
||
|
'>>&' encountered</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">Text may be redirected to only one file.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: No file specified for
|
||
|
'<'.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: No file specified for
|
||
|
'>' or '>>'.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: No file specified for
|
||
|
'>&' or '>>&'.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">A file must be specified when redirecting
|
||
|
I/O.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: '|' conflicts with
|
||
|
'>' or '>>'.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>gsh: '|' conflicts with
|
||
|
'<'.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">Piping is another form of redirection, thus
|
||
|
pipes and redirections cannot be mixed.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>Execution Errors</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">After <b>gsh</b> parses the command-line,
|
||
|
it will then execute the command and pass any arguments to the
|
||
|
command. If, however, the command does not exist, <b>gsh</b> will
|
||
|
report an error. The reason the command does not exist could be
|
||
|
either the command name was typed wrong or the command does not
|
||
|
exist.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>$0: Command not found.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">$0 represents the command to be executed.
|
||
|
Either the command name was entered incorrectly or the command
|
||
|
does not exist. Recheck the spelling of the command and check
|
||
|
$PATH to make sure the command exists in the pathname list.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>$0: Not executable.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">$0 represents the command to be executed. </font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>heh heh, next time you'll
|
||
|
need to specify a command before redirecting.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">Redirection was specified but the
|
||
|
command-line had no command.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>Cannot fork (too many
|
||
|
processes?)</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">An error was encountered forking a process.
|
||
|
The most likely culprit is there are too many processes running. </font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>Built-in Command Errors</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">These are errors which can be returned by
|
||
|
many of the built-in commands. Every built-in also contains a
|
||
|
Usage message on the proper invocation method.</font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>cd: Not a directory</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">Tried to change the cwd to a file that
|
||
|
isn't a directory.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>prefix: could not set
|
||
|
prefix, pathname may not exist.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">GS/OS Prefix command failed, most likely
|
||
|
the pathname did not exist or the disk is damaged.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>setdebug: Unknown flag</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">An unknown flag was sent to </font><font
|
||
|
size="2" face="Courier">setdebug</font><font face="Times">. Run </font><font
|
||
|
size="2" face="Courier">setdebug</font><font face="Times"> with
|
||
|
no arguments for a list of possible flags.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>ps: error in kvm_open()</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">ps was unable to access the process data
|
||
|
structure. It would be amazing that the kernel is still running
|
||
|
for this error to occur.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>set: Variable not
|
||
|
specified</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">A variable was not passed to set, for
|
||
|
example, "</font><font size="2" face="Courier">set =bar</font><font
|
||
|
face="Times">". Make sure the variable name was specified
|
||
|
without the preceding dollar sign. For example, if foo is not
|
||
|
set, then "</font><font size="2" face="Courier">set $foo=bar</font><font
|
||
|
face="Times">" would be expanded to "</font><font
|
||
|
size="2" face="Courier">set =bar</font><font face="Times">",
|
||
|
this resulting in this error.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>kill: Invalid signal
|
||
|
number</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>kill: Invalid signal name</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">See Appendix C for a list of valid signal
|
||
|
numbers and names.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>fg: No job to foreground.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>bg: No job to background.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>stop: No job to stop.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">There aren't any jobs so this command is
|
||
|
useless.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>fg: No such job.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>bg: No such job.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>stop: No such job.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>kill: No such job.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">The specified job (or process) doesn't
|
||
|
exist.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>fg: Gee, this job is
|
||
|
already in the foreground.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>bg: Gee, this job is
|
||
|
already in the background.</i></b></font></p>
|
||
|
|
||
|
<p><font size="2" face="Courier"><b><i>stop: Gee, this job is
|
||
|
already stopped.</i></b></font></p>
|
||
|
|
||
|
<p><font face="Times">Well, this should be self-explanatory.
|
||
|
Also, some of these should be impossible to get, unless you're
|
||
|
bound and determined to crash gsh, but then, these errors will
|
||
|
keep you from crashing it, so, what's the point? </font></p>
|
||
|
|
||
|
<p><font size="6" face="Times">Appendix D</font></p>
|
||
|
|
||
|
<p><font size="6" face="Times">Signals</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">The following list describes all signals
|
||
|
present in the GNO Multitasking Environment. These signals are
|
||
|
used to communicate with processes and the GNO kernel. <b>gsh</b>
|
||
|
provides a means to send signals to processes via the kill
|
||
|
command. Furthermore, GNO/ME provides interfaces for C and
|
||
|
Assembly Language programmers to handle signals in their
|
||
|
programs. Note that not all of these signals are actually used in
|
||
|
GNO/ME 2.0.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<dir>
|
||
|
<li><font face="Times"><u>Name (Value)</u> <u>Description</u></font><p><font
|
||
|
face="Times"><b>SIGHUP</b> (1) Hangup.</font></p>
|
||
|
<p><font face="Times"><b>SIGINT</b> (2) Interrupt.</font></p>
|
||
|
<p><font face="Times"><b>SIGQUIT</b> (3) Quit.</font></p>
|
||
|
<p><font face="Times"><b>SIGILL</b> (4) Illegal
|
||
|
Instruction.</font></p>
|
||
|
<p><font face="Times"><b>SIGTRAP</b> (5) Trace trap.</font></p>
|
||
|
<p><font face="Times"><b>SIGABRT</b> (6) Abort (cf.
|
||
|
abort(3)).</font></p>
|
||
|
<p><font face="Times"><b>SIGEMT</b> (7) Emulator trap.</font></p>
|
||
|
<p><font face="Times"><b>SIGFPE</b> (8) Arithmetic
|
||
|
exception.</font></p>
|
||
|
<p><font face="Times"><b>SIGKILL</b> (9) Kill. This
|
||
|
signal cannot be caught, blocked, or ignored. If a signal
|
||
|
is not specified for the kill command, this signal is
|
||
|
sent to the process.</font></p>
|
||
|
<p><font face="Times"><b>SIGBUS</b> (10) Bus error.</font></p>
|
||
|
<p><font face="Times"><b>SIGSEGV</b> (11) Segmentation
|
||
|
violation.</font></p>
|
||
|
<p><font face="Times"><b>SIGSYS</b> (12) Bad argument to
|
||
|
system call.</font></p>
|
||
|
<p><font face="Times"><b>SIGPIPE</b> (13) Write on a pipe
|
||
|
or other socket with no one to read it.</font></p>
|
||
|
<p><font face="Times"><b>SIGALRM</b> (14) Alarm clock.</font></p>
|
||
|
<p><font face="Times"><b>SIGTERM</b> (15) Software
|
||
|
termination signal.</font></p>
|
||
|
<p><font face="Times"><b>SIGURG</b> (16) Urgent condition
|
||
|
present on socket.</font></p>
|
||
|
<p><font face="Times"><b>SIGSTOP</b> (17) Stop. This
|
||
|
signal cannot be caught, blocked, or ignored.</font></p>
|
||
|
<p><font face="Times"><b>SIGTSTP</b> (18) Stop signal
|
||
|
generated from keyboard.</font></p>
|
||
|
<p><font face="Times"><b>SIGCONT</b> (19) Continue after
|
||
|
stop. This signal cannot be blocked.</font></p>
|
||
|
<p><font face="Times"><b>SIGCHLD</b> (20) Child status
|
||
|
has changed.</font></p>
|
||
|
<p><font face="Times"><b>SIGTTIN</b> (21) Background read
|
||
|
attempted from control terminal.</font></p>
|
||
|
<p><font face="Times"><b>SIGTTOU</b> (22) Background
|
||
|
write attempted to control terminal.</font></p>
|
||
|
<p><font face="Times"><b>SIGIO</b> (23) Input/Output
|
||
|
possible signal.</font></p>
|
||
|
<p><font face="Times"><b>SIGXCPU</b> (24) Exceeded CPU
|
||
|
time limit.</font></p>
|
||
|
<p><font face="Times"><b>SIGUSR1</b> (30) User defined
|
||
|
signal 1.</font></p>
|
||
|
<p><font face="Times"><b>SIGUSR2</b> (31) User defined
|
||
|
signal 2.</font></p>
|
||
|
</li>
|
||
|
</dir>
|
||
|
|
||
|
<p><font size="6" face="Times">Appendix E</font></p>
|
||
|
|
||
|
<p><font size="6" face="Times">Non-Compliant Applications</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">GNO/ME wasn't really designed with the
|
||
|
intention of making EVERY program you currently run work under
|
||
|
GNO/ME; that task would have been impossible. Our main goal was
|
||
|
to provide a UNIX-based multitasking environment; that we have
|
||
|
done. We made sure as many existing applications as we had time
|
||
|
to track and debug worked with GNO/ME. The current list of
|
||
|
compatible and non-compatible applications can be found in the
|
||
|
file "RELEASE.NOTES" on the GNO/ME disk.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">However, due to the sheer number of
|
||
|
applications and authors, there are some programs that just plain
|
||
|
don't work; and some that mostly work, except for annoyances such
|
||
|
as two cursors appearing, or keyboard characters getting 'lost'.
|
||
|
The problem here is that some programs use their own text drivers
|
||
|
(since TextTools output was very slow at one time); since GNO/ME
|
||
|
doesn't know about these custom drivers, it goes on buffering
|
||
|
keyboard characters and displaying the cursor. There is a way,
|
||
|
however, to tell GNO/ME about these programs that break GNO/ME's
|
||
|
rules.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">We've defined an auxType for S16 and EXE
|
||
|
files, to allow distinction between programs that are GNO/ME
|
||
|
compliant and those that are not. Setting the auxType of an
|
||
|
application to $DC00 disables the interrupt driven keyboard
|
||
|
buffering and turns off the GNO/ME cursor. Desktop programs use
|
||
|
the GNO/ME keyboard I/O via the Event Manager, and thus should <i>not</i>
|
||
|
have their auxType changed.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">You can change a program's auxType with the
|
||
|
following shell command:</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Courier">chtyp -a \$DC00 filename</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">where filename is the name of the
|
||
|
application. As more programmers become aware of GNO/ME and work
|
||
|
to make their software compatible with it, this will become less
|
||
|
of a problem, but for older applications that are unlikely to
|
||
|
ever change (like the America OnLine software) $DC00 is a
|
||
|
reasonable approach.</font></p>
|
||
|
|
||
|
<p> </p>
|
||
|
|
||
|
<p><font face="Times"><b></b></font> </p>
|
||
|
|
||
|
<p><font size="6" face="Times">Appendix F</font></p>
|
||
|
|
||
|
<p><font size="6" face="Times">Termcaps</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">'Termcap' is short for 'terminal
|
||
|
capability', and is the name of a database which applications can
|
||
|
use to do full-screen output on any kind of terminal. The termcap
|
||
|
database contains records for the various supported terminals,
|
||
|
each of which contains fields that look like this:</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>cap</b>=<b>value</b></font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times"><b>cap</b> is a two-letter code that
|
||
|
represents a cursor movement, screen mode change (such as inverse
|
||
|
or underline mode), and various other things. <b>Value</b> is
|
||
|
usually a sequence of control characters that is sent to a
|
||
|
terminal to initiate the desired action. <b>Value</b> can also be
|
||
|
'boolean', or yes/no, values, for such things as "Does this
|
||
|
terminal support cursor movement?". The termcap file is
|
||
|
documented in the electronic manual entry <b>termcap</b>(5).</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">The termcap library does not specifically
|
||
|
require GNO/ME.</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">The following terminal types are supported
|
||
|
in the GNO/ME termcap file:</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">gnocon GNO Console</font></p>
|
||
|
|
||
|
<p><font face="Times">CONSOLE GS/OS .console driver</font></p>
|
||
|
|
||
|
<p><font face="Times">ptse Proterm Special Emulation</font></p>
|
||
|
|
||
|
<p><font face="Times">vt100 DEC VT-100 terminal</font></p>
|
||
|
|
||
|
<p><font face="Times">ansisys MS-DOS ANSI.SYS</font></p>
|
||
|
|
||
|
<p><font face="Times">xerox820 Xerox 820-II CP/M terminal</font></p>
|
||
|
|
||
|
<p><font face="Times">iw1 Apple ImageWriter I printer</font></p>
|
||
|
|
||
|
<p><font face="Times">iw-alt Alternate ImageWriter I printer</font></p>
|
||
|
|
||
|
<p><font face="Times">deskjet Hewlett Packard DeskJet 500 printer</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">The printer entries allow a formatted
|
||
|
electronic manual page to be sent to the printer. For example,
|
||
|
the following script would bring up the manual page for '<b>ls</b>',
|
||
|
format it for the DeskJet 500, and print it with italics and
|
||
|
boldface:</font></p>
|
||
|
|
||
|
<p><font face="Times"></font> </p>
|
||
|
|
||
|
<p><font face="Times">set temp=$term</font></p>
|
||
|
|
||
|
<p><font face="Times">set term=deskjet</font></p>
|
||
|
|
||
|
<p><font face="Times">man $1 > .ttyb</font></p>
|
||
|
|
||
|
<p><font face="Times">set term=$temp</font></p>
|
||
|
|
||
|
<dir>
|
||
|
<li><font size="6" face="Times">Glossary</font><p><font
|
||
|
face="Times"><b><i>Alias</i></b>. A name used as an
|
||
|
abbreviation for one or more commands. An alias allows
|
||
|
you to replace any command string with a short sequence
|
||
|
of characters.</font></p>
|
||
|
<p><font face="Times"><b><i>Applesoft</i></b>. An
|
||
|
implementation of BASIC for the Apple II.</font></p>
|
||
|
<p><font face="Times"><b><i>APW</i></b>. Apple
|
||
|
Programmer's Workshop. Similar to ORCA.</font></p>
|
||
|
<p><font face="Times"><b><i>BASIC</i></b>. Beginners
|
||
|
All-purpose Symbolic Instruction Code. A simple computer
|
||
|
language.</font></p>
|
||
|
<p><font face="Times"><b><i>Built-in command</i></b>. A
|
||
|
command processed by <b>gsh</b>. These commands are not
|
||
|
external to the shell, but are included within the <b>gsh</b>
|
||
|
program.</font></p>
|
||
|
<p><font face="Times"><b><i>Command</i></b>. An action
|
||
|
for <b>gsh</b> to perform. Commands can be either simple
|
||
|
or compound. A simple command is an alias assignment,
|
||
|
variable assignment, I/O redirection, or built-in
|
||
|
command. A compound command is a pipeline.</font></p>
|
||
|
<p><font face="Times"><b><i>Directory</i></b>. A special
|
||
|
type of file that contains a list of other files; usually
|
||
|
used to categorize files related in some way. </font></p>
|
||
|
<p><font face="Times"><b><i>Environment</i></b>. The
|
||
|
state of a process, which includes information such as
|
||
|
its open files, current directory (working directory),
|
||
|
and local and global variables. Three environments exist
|
||
|
under <b>gsh</b>:</font></p>
|
||
|
<p><font face="Times"><i>Child environment</i>:: The
|
||
|
environment of the child process.</font></p>
|
||
|
<p><font face="Times"><i>Current environment</i>:: The
|
||
|
environment of the current process.</font></p>
|
||
|
<p><font face="Times"><i>Parent environment</i>:: The
|
||
|
environment of the parent process.</font></p>
|
||
|
<p><font face="Times"><b><i>Environment file</i></b>. A
|
||
|
file that is interpreted by an application to allow the
|
||
|
user to customize its operation. For <b>gsh</b>, this
|
||
|
file is "gshrc".</font></p>
|
||
|
<p><font face="Times"><b><i>Export</i></b>. A way to pass
|
||
|
a variable from a parent process to child process.</font></p>
|
||
|
<p><font face="Times"><b><i>File</i></b>. An object used
|
||
|
to store data and/or programs. On the II</font><font
|
||
|
size="2" face="Times">GS</font><font face="Times">, files
|
||
|
are tagged with types such as EXE, SRC, TXT, etc.</font></p>
|
||
|
<p><font face="Times"><b><i>Filter</i></b>. A command
|
||
|
that reads from its standard input and writes to its
|
||
|
standard output. For example, a filter program could be
|
||
|
written to convert all characters to upper case. Filters
|
||
|
are used mainly in pipelines.</font></p>
|
||
|
<p><font face="Times"><b><i>Flag</i></b>. A character
|
||
|
used to represent an option to a command. Flags are
|
||
|
either short or long options whose character
|
||
|
representations are "-" and "+".</font></p>
|
||
|
<p><font face="Times"><b><i>Glob</i></b>. Slang for
|
||
|
Pathname Expansion.</font></p>
|
||
|
<p><font face="Times"><b><i>GNO/ME</i></b>. GNO
|
||
|
Multitasking Environment. The complete package including
|
||
|
the GNO kernel and the GNO Shell.</font></p>
|
||
|
<p><font face="Times"><b><i>GNO Kernel</i></b>. Heart of
|
||
|
GNO/ME. Executes processes when asked by the GNO Shell</font></p>
|
||
|
<p><font face="Times"><b><i>GNO Shell</i></b>. Provides
|
||
|
an interface between the user and the GNO kernel.</font></p>
|
||
|
<p><font face="Times"><b><i>gsh</i></b>. GNO
|
||
|
Implementation of a UNIX-like shell.</font></p>
|
||
|
<p><font face="Times"><b><i>GS/OS</i></b>. 16 bit
|
||
|
Operating System for the Apple IIgs.</font></p>
|
||
|
<p><font face="Times"><b><i>History</i></b>. A variable
|
||
|
number of command-lines saved by <b>gsh</b> for future
|
||
|
reference. The number of command-lines saved is dependent
|
||
|
on the </font><font size="2" face="Courier">$HISTORY</font><font
|
||
|
face="Times"> environment variable.</font></p>
|
||
|
<p><font face="Times"><b><i>History file</i></b>. A file
|
||
|
containing command-lines entered while in a <b>gsh</b>
|
||
|
session. The number of command-lines saved is dependent
|
||
|
on the </font><font size="2" face="Courier">$SAVEHIST</font><font
|
||
|
face="Times"> environment variable.</font></p>
|
||
|
<p><font face="Times"><b><i>Interrupt</i></b>. A signal
|
||
|
generated by a sequence of keyboard characters or by a
|
||
|
command that terminates the current executing process,
|
||
|
unless the process has set up a trap to handle the
|
||
|
interrupt signal.</font></p>
|
||
|
<p><font face="Times"><b><i>I/O Redirection</i></b>. The
|
||
|
process of changing the standard input, standard output,
|
||
|
and standard error associated with a process so that it
|
||
|
is redirected to a file instead of the console.</font></p>
|
||
|
<p><font face="Times"><b><i>Job</i></b>. A set of related
|
||
|
processes. A job can be either:</font></p>
|
||
|
<p><font face="Times"><i>Background job</i> :A process
|
||
|
that executes with the current process. Background jobs
|
||
|
are not associated with the terminal.</font></p>
|
||
|
<p><font face="Times"><i>Foreground job</i> : A process
|
||
|
that is currently executing and which is associated with
|
||
|
the terminal.</font></p>
|
||
|
<p><font face="Times"><b><i>Multiprocessing</i></b>.
|
||
|
Indicates a machine with more than one CPU.</font></p>
|
||
|
<p><font face="Times"><b><i>Multitasking</i></b>. The
|
||
|
ability to run more than one program at a time, or the
|
||
|
illusion of more than one program running at a time -
|
||
|
usually the latter.</font></p>
|
||
|
<p><font face="Times"><b><i>ORCA</i></b> Shell programing
|
||
|
environment for the Apple //gs. Also a type of whale.</font></p>
|
||
|
<p><font face="Times"><b><i>Path search</i></b>. The
|
||
|
means of searching a pathname list for a command or
|
||
|
script.</font></p>
|
||
|
<p><font face="Times"><b><i>Pathname</i></b>. A string
|
||
|
used to identify a file.</font></p>
|
||
|
<p><font face="Times"><i>Pathname completion</i>. The
|
||
|
means of generating all pathnames matching a given
|
||
|
pattern.</font></p>
|
||
|
<p><font face="Times"><i>Pathname expansion</i>. The
|
||
|
means of replacing a pattern with a list of pathnames
|
||
|
matching that pattern.</font></p>
|
||
|
<p><font face="Times"><b><i>Pattern</i></b>. A string of
|
||
|
characters used to match literal characters and/or
|
||
|
multiple characters.</font></p>
|
||
|
<p><font face="Times"><b><i>Permission</i></b>. Each file
|
||
|
has certain permissions associated with it: destroy,
|
||
|
rename, backup, invisible, write, and read.</font></p>
|
||
|
<p><font face="Times"><b><i>Pipe</i></b>. A conduit
|
||
|
through which a stream of characters can pass from one
|
||
|
process to another. This is accomplished by linking the
|
||
|
standard output of one process to the standard input of a
|
||
|
second process.</font></p>
|
||
|
<p><font face="Times"><b><i>Pipeline</i></b>. Two or more
|
||
|
processes connected together by pipes.</font></p>
|
||
|
<p><font face="Times"><b><i>Process</i></b>. A single
|
||
|
thread of execution that consists of a program and an
|
||
|
execution environment.</font></p>
|
||
|
<p><font face="Times"><i>Child process</i>: A new process
|
||
|
created by another process.</font></p>
|
||
|
<p><font face="Times"><i>Parent process</i>: A process
|
||
|
that creates a child process.</font></p>
|
||
|
<p><font face="Times"><b><i>Process id</i></b>: Each
|
||
|
active process is uniquely identified by a positive
|
||
|
integer called the process id.</font></p>
|
||
|
<p><font face="Times"><b><i>ProDOS</i></b>. 8-bit Disk
|
||
|
Operating System for Apple II computers.</font></p>
|
||
|
<p><font face="Times"><b><i>Prompt</i></b>. A message
|
||
|
displayed by <b>gsh</b> when it is ready to receive a
|
||
|
command.</font></p>
|
||
|
<p><font face="Times"><b><i>Quoting</i></b>. A means of
|
||
|
including special characters as arguments to a command or
|
||
|
as the command name. Certain characters have certain
|
||
|
meanings to <b>gsh</b> and quoting them makes <b>gsh</b>
|
||
|
ignore them.</font></p>
|
||
|
<p><font face="Times"><b><i>Reserved word</i></b>. A word
|
||
|
that is treated specially by <b>gsh</b>. This word is
|
||
|
part of the <b>gsh</b> grammar.</font></p>
|
||
|
<p><font face="Times"><b><i>Script</i></b>. A sequence of
|
||
|
commands contained in a file.</font></p>
|
||
|
<p><font face="Times"><b><i>Signal</i></b>. An
|
||
|
asynchronous message that consists of a number or name
|
||
|
that can be sent from one process to another.</font></p>
|
||
|
<p><font face="Times"><b><i>Standard Error</i></b>. The
|
||
|
file associated with error messages for a process. This
|
||
|
file is usually the terminal.</font></p>
|
||
|
<p><font face="Times"><b><i>Standard Input</i></b>. The
|
||
|
file associated with a processes input. This file is
|
||
|
usually the terminal.</font></p>
|
||
|
<p><font face="Times"><b><i>Standard Output</i></b>. The
|
||
|
file associated with a processes output. This file is
|
||
|
usually the terminal.</font></p>
|
||
|
<p><font face="Times"><b><i>Tilde Expansion</i></b>.
|
||
|
Words beginning with "<b>~</b>" are treated
|
||
|
specially by <b>gsh</b>. The "<b>~</b>" is
|
||
|
expanded to the value of the </font><font size="2"
|
||
|
face="Courier">HOME </font><font face="Times">variable.</font></p>
|
||
|
<p><font face="Times"><b><i>UNIX</i></b>. Popular
|
||
|
operating system which has growing use in education and
|
||
|
business. One of the first operating systems to support
|
||
|
multitasking.</font></p>
|
||
|
<p><font face="Times"><b><i>Variable</i></b>. A named
|
||
|
location in <b>gsh</b> that contains text. The text of a
|
||
|
variable can be expanded in a command by preceding the
|
||
|
variable name with a dollar sign ($).</font></p>
|
||
|
<p><font face="Times"><b><i>Wildcard</i></b>. See Pattern
|
||
|
and Pathname Expansion.</font></p>
|
||
|
<p><font face="Times"><b><i>Working directory</i></b>.
|
||
|
The current directory.</font></p>
|
||
|
</li>
|
||
|
</dir>
|
||
|
|
||
|
<p><font size="6" face="Times">Index</font></p>
|
||
|
|
||
|
<p><font size="2"></font> </p>
|
||
|
|
||
|
<dir>
|
||
|
<li><font size="2"></font> </li>
|
||
|
</dir>
|
||
|
|
||
|
<dir>
|
||
|
<li><font size="2"></font> </li>
|
||
|
</dir>
|
||
|
|
||
|
<dir>
|
||
|
<li><font size="2"></font> </li>
|
||
|
</dir>
|
||
|
</body>
|
||
|
</html>
|