💾 Archived View for gemini.spam.works › mirrors › textfiles › humor › COMPUTER › unixtrix.txt captured on 2022-07-17 at 02:37:05.

View Raw

More Information

⬅️ Previous capture (2022-06-12)

-=-=-=-=-=-=-

From: Nancy Blachman <decvax!decwrl!sun!idi!resonex!nancy@Ucb-Vax.ARPA>
To: net.unix, net.unix-wizards, net.sources
Subject: Actual tricks, shells, csh aliases and the like, 1 of 3
Date: 16 Oct 84 21:20:53 GMT
Organization: Resonex Inc., Sunnyvale, CA

> [Know anybody with a GREAT .login or .cshrc?]

> I'm interested in collecting the little tricks, shell scripts, awk
> hacks, csh aliases, and such that people have built to make their daily
> life a little easier or more automatic.  Being a fairly new system
> administrator I don't have the big toolbox that years of messing around
> will leave you with.  If you have any hacks you're proud of (or that
> you aren't proud of, but which work anyway), and you're willing to make
> them public, mail them to me.  I'll collect, collate, shuffle, sort,
> munge, judge, select and discard them and then "summarize to the net".

This article concentrates on  aliases, and .cshrc and .login files I received
in response to my solicitation. The second article in this series focuses
shell scripts. The third article centers on C programs and awk scripts.

/\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\/
> Nancy Blachman {allegra,hplabs,ihnp4,sun}!resonex!nancy  (408)720 8600 x37 <
/\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\/

::::::::::::::
aliases/1
::::::::::::::
Date: Thu, 13 Sep 84 07:27:35 est
From: ihnp4!pur-ee!davy (Dave Curry)
To: ihnp4!resonex!nancy
Subject: aliases

Nancy:

        Here's a few handy aliases to put your current working
directory into your prompt:

alias cd chdir \!:\* \; set prompt='${cwd}\[!\]\ ' \; setenv CWD '$cwd'
alias pd pushd \!:\* \; set prompt='${cwd}\[!\]\ ' \; setenv CWD '$cwd'
alias pp popd \!:\* \; set prompt='${cwd}\[!\]\ ' \; setenv CWD '$cwd'

These put the current directory into the environment also, this is
for an editor used here locally which uses this information.  You can delete
that part if you don't need it.

--Dave Curry
ihnp4!pur-ee!davy



::::::::::::::
aliases/2
::::::::::::::
From: hplabs!sdcrdcf!sdcsvax!greg (Greg Noel)
Date: Thu, 13 Sep 84 10:57:51 pdt
Return-Address: ucbvax!sdcsvax!greg or Greg@NOSC
Organization: NCR Corporation, Torrey Pines
To: sdcrdcf!hplabs!resonex!nancy
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

I have three little gems from my bag of tricks that I'd like to show you,
all for the C shell.  The first is an alias for the `pwd' command:
        alias pwd       echo \$cwd
The built-in variable `cwd' always contains the current working directory,
and since `echo' is a built-in command, this is MUCH faster than invoking
a program to calculate the actual location.  The only problem (and I don't
have a solution) is that it gets confused by symbolic links to directories.

The second one is something that turns the directory structure from something
passive into something active:
        alias come      if -e .greg_come source .greg_come
        alias go        if -e .greg_go   source .greg_go
        alias cd        go \; set prev = \$cwd \; chdir \!\* \; \
                                echo \$prev ==\\\> \$cwd \; come
What this does is cause the shell to look for a specific file whenever it
transfers into a directory, and if it is there, source it.  Also, whenever
you leave a directory, it looks for a different file and sources that before
leaving.  I use this to set up location-specific aliases or to have something
happen auto-magicly whenever I work in some diretory -- for example, changing
into my `play' directory invokes a menu that will set up the environment and
run game programs -- different save files for `rogue' or other stuff that
I don't want to carry around with me all the time.  It's more flexible than
it seems at first glance; the only thing I can suggest is to try it and you
will keep finding new ways to use it.

The last one is really a replacement for the `pushd' and `popd' commands --
I didn't like the way they worked, so I did these.  It seperates the action
of pushing a directory from the action of changing directories.  I wanted
this since I also have a whole bunch of aliases to move between widely-
seperated portions of the filesystem (something I do a lot) and it was
easier for me to type `push; u test' (which pushes the current directory
and takes me into the `test' subdirectory of something interesting) than
to type `pushd /long/complicated/path/test'.  This isn't terribly original,
but the gem, and something I find VERY useful is the `back' command, which
takes you to the directory you last left, so you can bouce back and forth
between two directories -- one is the source location and one the test
location, for example.  Anyway, here's what it looks like:
        alias push      set dirstack = \( \$cwd \$dirstack \) \; \
                                echo Pushing \\\[\$\#dirstack] \$cwd \; \!\*
        alias pop       cd \$dirstack\[1] \; set dirstack = \( \$dirstack\[2-] \)
        alias back      set dirstack = \( \$prev \$dirstack \) \; pop
        alias pp        set x = \$dirstack\[1] dirstack\[1] = \$cwd \; cd \$x
Notice that it interacts with the previous alias for `cd' in that it expects
the variable `prev' to have the previous directory (which is what `cd' leaves
in it).  The `pp' alias is sometimes useful -- it pushes the current directory
while transfering to the old top of stack, a simultaneous push-pop.

I hope you found these interesting and entertaining.

-- Greg Noel, NCR Torrey Pines       Greg@sdcsvax.UUCP or Greg@nosc.ARPA

::::::::::::::
cshrc/1
::::::::::::::
From: <hplabs!tektronix!jerryp>
Date: Thursday, 13 Sep 84 09:48:55 PDT
To: resonex!nancy, jerryp
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

Nancy,

I'll mail you a few .cshrc and .login files.  Unfortunately, I'm short on
time... so I can't comment a lot... but I'd be glad to answer any questions
you've got about how they work.

A summary of them:

1)  This .cshrc file comes from the tektronix!tekred machine in Redmond,
Oregon.  Its neat feature is that, when a user "su"'s to someone else's
account, their prompt changes
from    %
to      account>
where the "su"'d name appears before the >.  Very nice, I think.

Also, they do a standard thing around here.  The first line [if ($?prompt)]
checks to see if the .cshrc is being scanned by an interactive shell.  If so,
the commands below are executed.  If not (like a shell escape from "vi"), the
commands aren't executed.  This really speeds up shell escapes!  (I do the
same thing, in a different way, in my .cshrc file.)


2)  This is my .login file.  I should mention that I've got my own calendar
system that's updated every morning at 1 AM by "at".  It sits in my
".calendar" directory.  You'll see a lot of that stuff in the .login file.


3 & 4)  I have *two* .cshrc files.  One, ".cshrc", is the standard file.  It
contains a limited list of aliases and setup commands.  The other, ".cshrc2",
is one I source when I'll be logged on for a long time and doing a lot of
work.  The .cshrc2 has time-saving aliases like "alias m more" in it.

At login, the .cshrc is always read.  This sets my prompt to something like
        <directory,#>
where # is the C-shell history number.  Also, since my system is so busy, I
have a "quick login" setup in .cshrc to let me see my mail immediately and
logout without doing anything else, if I want to.  This quick-login has a
        $
prompt set... the Bourne-shell prompt.

If I want an extended login, I execute the alias "res" (from .cshrc).  It sets
alarms automatically (for meetings, etc... from my .calendar directory) and
re-sets my prompt to something like
        [directory,#]
That way, I know that I've got all my aliases available.

Since my system is overloaded, this dual-.cshrc system saves me time and
hassle... .cshrc2 takes a long time to source.


--Jerry Peek, UNIX Training Instructor, Tektronix, Inc.
US Mail:   MS 76-036, P.O. Box 500, Beaverton, OR 97077
uucp:      {allegra,decvax,hplabs,ihnp4,mit-eddie,ucbvax}!tektronix!jerryp
CSnet:     jerryp@tek
ARPAnet:   jerryp.tek@csnet-relay
Phone:     503/627-1603


---------------------------------------------------------------------------
FILE #1 (.cshrc):

if ($?prompt) then
        set history=20
        set path=(. $home/bin /usr/local /usr/tek /usr/public /usr/ucb /bin /usr/bin)
        set mail=(300 /usr/spool/mail/$home:t /etc/motd)
        source ~/.aliases

        set prompt=`whoami | sed -e 's/ .*//' -e 's/user=//'`
        if ($prompt == $user || $prompt == "") then
                set prompt="% "
        else
                set prompt="$prompt> "
        endif
endif
---------------------------------------------------------------------------
FILE #2 (.login):
uptime                  # show system load
set ignoreeof           # do not logout on EOF (^D)
set noclobber           # do not overwrite files with > or >>
cp ~/.exrc8 ~/.exrc     # set up vi/ex to environment in ~/.exrc8
setenv EDIT /usr/ucb/vi # set default editor to vi
setenv PRINTER uph      # if type "man -Tlpr", use "uph" to store for printing
setenv NEWSBOX ~        # save news (readnews "s") in home directory or beneath

set noglob; eval `tset -srQm 'plugboard:?4025'`; unset noglob

stty new crt            # new tty driver, crt terminal, see newtty(4)
stty tostop hup         # stop background jobs on output, hangup hw on logout
limit filesize 2000     # do not write file > 2,000,000 bytes
limit coredumpsize 0    # prevent core dumps when csh bombs
touch .llog             # set correct last login time for finger
if ($TERM == 'tek4023' || $TERM =~ aaa*inv ) then
        # KEEP more FROM USING THE ul OPTION AND MESSING UP DISPLAY:
        setenv MORE -u
else if (($TERM == qume5) || ($TERM == dumb)) then
        mesg n
        exit 0
endif

# immediate notification (every 60 seconds) of mail:
set mail = (60 /usr/spool/mail/$user /etc/motd)

# check /etc/motd for changes; if any, show them and (maybe) add to calendar:
diff ~/.calendar/last.motd /etc/motd >! /tmp/motd.diff
if ( $status != 0 ) then
        echo "< = old MOTD ... > = new MOTD"
        more /tmp/motd.diff
        echo "To read the new MOTD into the calendar, answer y.  To ignore it, answer q."
        echo -n "Otherwise, hit RETURN: "
        set ans = {body}lt;
        if ($ans == "y") then
                cat /etc/motd | tee -a ~/.calendar/calendar >! ~/.calendar/last.motd
                vi + ~/.calendar/calendar
                echo "To reset *today's* calendars, type 'calendar.set -F'."
        else if ($ans == "q") then
                cat /etc/motd >! ~/.calendar/last.motd
        endif
endif

echo "--------------------"
inc             # put new mail, if any, in ~/.mail/inbox

echo "--------------------"

set time = 10   # for jobs that take longer than 10, show how long
# IF THERE ARE LOGIN MESSAGES, SHOW THEM:
if !(-z ~/.calendar/mesg.login) then
        echo "Here are the login messages, "`date '+%a %D'`
        echo ""
        doublespace ~/.calendar/mesg.login
endif

echo "For an uptime graph, type 'upgr'."
---------------------------------------------------------------------------
FILE #3 (.cshrc):
# if this is a non-interactive shell, quit.
if ( ! $?prompt) exit 0

# save login system search path, removing leading "." (thanx to tekig!danr):
if ( ! $?SYSPATH ) setenv SYSPATH "$path[2-]"

# set default places to find commands (put current and .bin directories first):
set path=(. ~/.bin $SYSPATH /usr/public{,/texthelp} /usr3/{barbaraz/.,tcomm/}bin)

# CHECK FOR QUICK LOGIN:
if (! $?LOGGEDIN) then
        echo -n "For quick login (Bourne shell), answer y; otherwise, press RETURN: "
        if ( "{body}lt;" =~ y* ) then
                echo "To continue with login, press control-D; to logout, type 'stty 0'"
                /bin/sh -i
                echo "Continuing with standard login..."
        endif
endif
setenv LOGGEDIN x

# set cd search path for directory names which aren't sub-directories:
set cdpath=(~ `finddirs ~/training{,/*} /usr3/tcomm/unix{,/*}` ~/.bin ~/.log ~/.mail ~/stuff ~/tape*)

set history=1000        # keep the last 1000 commands in history

# use /usr/public/prompt to get massaged directory name for prompt-setting:
set prompt = "<`prompt ~ $cwd`,"{\!}"> "

# edit my calendar:
alias calen 'vi ~/.calendar/calendar; echo '"To reset today\'s calendars, type calendar.set -F"''

# change directory, reset prompt:
alias cd 'chdir \!*; set prompt = "<`prompt ~ $cwd`,"{\!}"> "'

# add to specified .log directory
alias log 'echo "Put a .ze at end of file, unless last log of this set.";vi + ~/.log/`cat ~/.log/latestlog`/\!*'

# create newterm command to allow terminal-type change
alias newterm 'set noglob;eval `tset -srQ \!*`;unset noglob'

# sets alarms (if any) and sources '.cshrc2' (my other alias list)
alias res '~/.bin/alarm.set ; source ~/.cshrc2'

alias todo 'vi ~/todo\!*'       # change one of the "to do" lists
---------------------------------------------------------------------------
FILE #4 (.cshrc2):

# notify immediately when background jobs are finished
set notify

# prompt with current directory name, history number:
alias s_p 'set prompt = "[`prompt ~ $cwd`,"{\!}"] "'
s_p

# set 'vi' for 4-character tabs/shifts:
alias 4vi 'cp ~/.exrc{4,}; echo "MODE: programming"'

# set 'vi' for 8-character tabs/shifts:
alias 8vi 'cp ~/.exrc{8,}; echo "MODE: text"'

# set 'vi' for quick work (no .exrc file):
alias qvi 'rm ~/.exrc; echo "MODE: quick"'

# easy way to compile "C" programs (ring bell if filename ends with ".c"):
alias C 'if ("\!*" =~ *.c) yes ;mv \!* ,\!*;echo \!*.c" SENT TO cc";cc \!*.c -o \!*;if (-e \!*) chmod 311 \!*'

# show alarms that (may be) set... and message explaining them:
alias alarms 'echo "These alarms have been set:";cat ~/.calendar/mesg.alarm; \ps | fgrep ".bin/nleave"'

# change back to previous directory:
alias c- 'set x=$cwd; chdir $lastdir; s_p; set lastdir=$x'

# edit my calendar:
alias calen 'v8 ~/.calendar/calendar; echo '"To reset today\'s calendars, type calendar.set -F"''

# see today's calendars:
alias cals 'cat ~/.calendar/mesg.*'

# save current directory for 'c-', change directory, reset prompt:
alias cd 'set lastdir=$cwd; chdir \!*; s_p'

# see mail without inc'ing it:
alias checkm 'see /usr/spool/mail/jerryp'

# same as 'cd', but lists directory, too:
alias cl 'set lastdir=$cwd; chdir \!*; ls -F; s_p'

# same as 'cl', but gives long list:
alias cll 'set lastdir=$cwd; chdir \!*; ls -l; s_p'

alias f 'grep "^\!*" /etc/passwd'       # quick version of "finger -s"

alias H 'history -r | fgrep "\!*"'      # find something in history list
alias h history 5       # show last five lines
alias hi history 10     # show last ten lines
alias his history 20    # show last twenty lines
alias hist 'history 40|m'       # show last forty lines; pipe to 'more'
alias histo 'history 70|m'      # show last seventy lines; pipe to 'more'

# send output of command to 'pr' (with command as header), then to uph:
alias hpr '\!* | pr -h "\!*" | uph'

alias j 'jobs -l >! /tmp/j$; pushin /tmp/j$; rm /tmp/j$'
# show job status (process numbers, too) squeezed onto one line each

alias lc 'ls *.c'       # list all C source code in this directory

# add to specified .log directory
alias log 'echo "Put a .ze at end of file, unless last log of this set.";v8 + ~/.log/`cat ~/.log/latestlog`/\!*'

# list executable files, 5 columns, sorted across 80-wide line:
alias lx 'lf -1 | fgrep \* | pr -t -5 -l1 -w80'

alias m more            # shortened form of 'more' command

# faster pwd (singlequotes prevent expansion before it's executed):
alias pwd 'echo $cwd'

# re-start inverse video on Ann Arbors:
alias reinv 'echo "[7m";clear'

# lock terminal until ^C and login password are entered:
alias somb /usr3/jos/bin/somb

alias showm 'inc;show'  # get new mail

# give more info (how much time I've used) when using "status":
alias status 'source ~/.bin/status'

alias tcpr 'tcprint -p12 -m5 -ff \!* &'         # typical quick "tcprint" use

alias todo 'v8 ~/todo\!*'       # change one of the "to do" lists

alias up uptime

# make uptime graph:
alias upgr '(nohup uptime_graph ~/,up`date +%m%d.%H%M` &)'

# show uptime today's graph:
alias upsh 'uptime_show -20 ~/,up`date +%m%d`*'

# 'vi' for programming:
alias v4 '4vi;vi \!*'

# 'vi' for standard text:
alias v8 '8vi;vi \!*'

# call 'vi' with a search (must use 8vi because search requires a 'wrapscan')
alias vs '8vi; vi +/\!*'

alias write '/usr4/danr/bin/rite -c \!*'   # show each character as it's typed

#UNUSED ALIASES:
#alias cd 'set lastdir=$cwd;chdir \!*;set prompt="`~/.bin/prompt`"'
# change to maps directory:
#alias maps 'cd /usr/spool/news/lib/maps;echo "switching to newsa";su newsa;set $user=jerryp;c-'
# keep "at" job from dying because of long EXINIT:
#alias niterun 'setenv EXINIT "set sw=8";\niterun \!*;8vi'
#alias du ~danr/bin/du  # improved version of "directory usage" query
# format text, save in file".ty", then show it on the crt:
#alias typeup '~/.bin/type \!* >! \!*:r; more \!*:r'
# give description of 'ps' codes before doing the 'ps':
#alias ps 'cat ~/.ps.man;\ps \!*'
# easy way to compile and run "C" programs
# (ring bell if filename ends with ".c"):
#alias c 'if ("\!*" =~ *.c) yes ;mv \!* ,\!*;echo \!*.c" SENT TO cc";cc \!*.c -o \!*;echo "press ^C to stop execution";sleep 2;./\!*'
# easy way to change editor environment files:
#alias adde 'vi ~/.exrc\!*; set ex=(`cat ~/.exrc\!*`); setenv EXINIT "$ex"'
#alias rmm '\rmm \!* &'  # remove mail in background
# faster "man" listings:
#alias man 'echo "man -q:"; \man -q \!*'
# improved spell routine (write-protected dictionary):
#alias spel 'chmod +w ~/.misspell; /usr/public/spel \!*;chmod -w ~/.misspell'
# show whether using ~/.exrc4 or ~/.exrc8:
#alias vi 'echo "MODE: "$EXSTAT;/usr/ucb/vi \!*'
#alias comp '8vi;\comp \!*'     # set 'vi' for text before doing the 'comp'
# show last ten users of "tcprint" program:
#alias tcp tail /usr3/tcomm/.tcprint/log
# favorite "ps" (gives PID, PPID, STAT, TT, TIME, and long description):
#alias p 'ps lwx | cut -c12-22,53- | nfold'

::::::::::::::
cshrc/2
::::::::::::::
Date: Thu, 13 Sep 84 02:16:31 edt
From: ihnp4!seismo!umcp-cs!chris (Chris Torek)
To: ihnp4!resonex!nancy
Subject: Re:  Tricks, shell and awk scripts, ...

Actually Re: [Know anybody with a GREAT .login or .cshrc?]:

I don't know about *great*, but I'm probably one of the candidates for

on this machine (they're not the same on tove, gyre, gymble, and eneevax).

Chris

: Run this shell script with "sh" not "csh"
PATH=:/bin:/usr/bin:/usr/ucb
export PATH
all=FALSE
if [ $1x = -ax ]; then
        all=TRUE
fi
/bin/echo 'Extracting .cshrc'
sed 's/^X//' <<'//go.sysin dd *' >.cshrc
#
if ($?prompt) then
echo -n '['
set path=(. ~chris/bin ~chris/sys /usr/local/bin /g/local /usr/ucb /bin /usr/bin /usr/games /etc /usr/hosts)
echo -n 'cshrc]'
set ignoreeof history=100 time=2 mail=(10 /usr/spool/mail/chris) cdpath=(~ /g/VOTRAX ~/bin /g/chris ..) S=/usr/spool/uucp CICO=/usr/lib/uucp/uucico
alias hh history;alias h 'history 20';alias j jobs;alias o popd
alias status 'echo $status';alias so source;alias bye logout
alias p pushd;alias done 'echo ';alias kb "rm -i .*.bak *.bak .*.CKP *.CKP"
alias kc "rm -i .*.CKP *.CKP";alias e emacs;alias @@term 'kill -9 $'
alias af ~chris/af/af;alias cdl "cd \!:1;ls \!:2*";alias lsl "ls -li"
alias lsa "ls -A";alias lsla "ls -lai";alias up "cd ..";alias upl "cd ..;ls"
alias cdll "cd \!:1;lsl \!:2*";alias lsld "lsl -d";alias lslg "lsl -g"
alias upll "cd ..;lsl";alias pl "pushd \!:1;ls \!:2*";alias z logout
alias pll "pushd \!:1;lsl \!:2*";alias ol "popd;ls";alias oll "popd;lsl"
alias cdla "cd \!:1;lsla \!:2*";alias v80 'echo -n "[?2l";set term=VT52'
alias v132 'echo -n "[?2l";set term=VT52.132';alias ansi 'echo -n "<"'
alias fix 'stty newcrt erase  kill ';alias ca 'ex "+1,.|q"'
alias own 'cp \!:1 /tmp/own$;rm -f \!:1;mv /tmp/own$ \!:1'
alias save 'cp \!:1 \!:1.old;chmod a-w \!:1.old;chmod +w \!:1'
alias c80 'echo -n "[?3l";set term=DT80';alias suspend 'suspend;dirs'
alias col80 'echo -n "[?3l";colnum 80';alias a alias
alias c132 'echo -n "[?3h";set term=DT80.132'
alias col132 'echo -n "[?3h";colnum 132'
alias hold 'echo -n "[H[J[12;20H[5mI'"'"'ll be right back[m[20H";lock;echo -n "[H[J"'
alias feed '(sleep 3000;echo Feeding time\\!)&'
alias open 'set noglob;eval `/usr/chris/bin/open \!:*`;unset noglob'
alias loav /usr/mark/bin/load
setenv VISUAL /usr/ucb/vi;setenv EDITOR /usr/local/bin/emacs
setenv EPATH :/usr/chris/emacs:/usr/israel/emacs:/usr/emacs/loclib:/usr/emacs/maclib
alias dir ls;alias era rm;alias printman /usr/man/printman;alias d dirs
alias clx 'rm -f /tmp/X_lock.\!:1 /usr/spool/uucp/LCK..\!:1'
alias aasize 'set noglob;eval `/usr/local/bin/aasize \!:1`;unset noglob'
alias aasave 'set noglob;eval `/usr/local/bin/aasave \!:1`;unset noglob'
alias down 'cd `echo */|awk '\''{print $1}'\''`;echo $cwd'
alias downl 'down;ls';alias downll 'down;lsl';alias mark 'set \!:1=$cwd'
alias lso 'lsla | sort +4 -rn';alias edenv 'source ~chris/bin/edenv'
alias aibib 'echo \!*|lookbib -n -p /usr/randy/papers/airefs|page'
alias checkque /usr/lib/mmdf/checkque;alias sum-dial /usr/lib/mmdf/sum-dial
alias deliver 'sh -c "HOME=/ /usr/lib/mmdf/deliver \!:*"'
alias ll 'ls -l';alias tm 'telnet 128.8.0.8'; alias  uptime
endif
umask 22
if ($?prompt) then
        set prompt='[\!] '
        echo ''
endif
//go.sysin dd *
made=TRUE
if [ $made = TRUE ]; then
        /bin/chmod 644 .cshrc
        /bin/echo -n '  '; /bin/ls -ld .cshrc
fi
/bin/echo 'Extracting .login'
sed 's/^X//' <<'//go.sysin dd *' >.login
#
stty erase ^H kill ^X intr  decctlq nl0 cr0 ff0
cd;setenv TERMCAP /usr/chris/.termcap
# cp .exrc1 .exrc
# Set up the terminal
# 4025=Tek4025 sd=dialup x1=Xer 1750 GG=Gigi d4=GT40 aaa=AAA else DT80
# if (`slowtty` == y) then
#       cp .mailrc2 .mailrc
# else
#       cp .mailrc1 .mailrc
# endif
set wantbaud=0
top:
switch ($TERM)
case su:
case network:
        set wantbaud=1
case sd:
case unknown:
        set term=`/ful/chris/bin/selterm`
        goto top
case 4025:
        stty crt tabs;tabset.tek
        breaksw
case h6:
case hp:
case hp2623:
case hp2626:
        stty tabs crt
        breaksw
case v550:
        stty crt;set prompt='[7m[\!][m '
        breaksw
case GG:
        stty crt;unsetenv TERMCAP;set prompt='[7m[\!][m '
        breaksw
case d4:
        set term=gt40;stty crt
        breaksw
case aaa:
case aaa-60:
        set term=aaa prompt='[7m[\!][m ';stty tabs crt;unsetenv TERMCAP
        aakey -f /ful/chris/.aakeys
        if (`tty` =~ /dev/tty*) then
                echo -n 'Lines? [30] '
                set lines={body}lt;
                if ($lines != ) then
                        aasize $lines
                endif
        endif
        breaksw
case h19:
case h19a:
case kb:
        set term=h19a prompt='[7m[\!][m ';stty tabs crt crtkill
        breaksw
case Dq:
case DT80:
case D5:
case vt100:
        set term=DT80 prompt='[7m[\!][m '
        echo -n '[?4l';stty crt
        breaksw
default:
        unsetenv TERMCAP;echo "Wonder what $TERM is?"
        breaksw
endsw
if ($wantbaud == 1) then
        selbaud
endif
unset wantbaud lines
# mailcount
checknews
setenv ROGUEOPTS 'jump,ask,terse,flush,passgo,fruit=hregfx'
setenv PAGER /usr/ucb/page
setenv SPELL_LISTS /ful/chris/.splist
alias logout 'source /ful/chris/.logout.';alias exit logout
# /usr/games/fortune
w; # calend; /usr/chris/bin/ac 22:00
echo ----------------------------------------------------------
# rehist .history
//go.sysin dd *
made=TRUE
if [ $made = TRUE ]; then
        /bin/chmod 644 .login
        /bin/echo -n '  '; /bin/ls -ld .login
fi

::::::::::::::
cshrc/3
::::::::::::::
Date: Fri, 14 Sep 84 14:59:01 pdt
From: hplabs!sdcrdcf!sdcsvax!sdcc6!loral!hlb (Howard Brandell)
To: sdcc6!sdcsvax!sdcrdcf!hplabs!resonex!nancy
Subject: .cshrc

I am sending my entire .cshrc file because I have some things in it
that help me out.

Firstly, note the aliases that allow me to selectively read those
newsgroups of interest.  Aha! You may say I can put it all in the
.newsrc file and have the system inform me when there is news and
read it out simultaneously.  But, sometimes we get news during the
course of the day and I like to check my favorites continuously.

Also, not the aliases for tip.  These allow me to dial my remote
locations with both spped and accuracy. As an aside,  I have
created a .tiprc file which logs all my remote host conversation
into a file.  In this way, nothing is lost.  Note the 'rt' command
which allows me to purge tiplog.

alias a alias
a sd   "msg,gju,glw,kay,sdi"
a ds   "chmod 600 .signature"
a es   "chmod 640 .signature"
a vc   "ccalc"
a m    "mail"
a p    "more"
a rk   "readnews -n net.kids"
a ra   "readnews -n net.micro.apple"
a ri   "readnews -n net.micro.pc"
a rs   "readnews -n sdnet.computing"
a rb   "readnews -n net.sport.baseball"
a rn   "readnews -n net.columbia"
a rw   "readnews -n net.wanted"
a rl   "readnews -n net.legal"
a r    "readnews"
a logs "readnews -n net.sources -l>sources.log"
a motd "cat /etc/motd|more"
a h   "history -r \!*|more"
a t1  "tip 561-7271"
a t2   "tip 452-1869"
a t3   "tip 283-1538"
a t4   "tip 692-1961"
a t5   "tip 270-1166"
a t6   "tip 217-1900"
a rt   "rm tiplog"
a bye   logout
a cd    "cd \!* ; dirs"
a term  'set noglob; eval `tset -n -s \!*`'
a wat   "ps -au | more"
a pv    printenv
a j     "jobs -l"
a f     "finger|more"
a l     ls -F

if ( $?prompt == 1 ) then
        set prompt="\!: "
        set mail=(60 /usr/spool/mail/$USER)
endif
set history =   24
set cdpath = (. ~)

Also note the aliases for the more mundane commands, like mail
and more -c.

Hope this has been of some help.  Please disregard my earlier
transmission as I had some operational difficulties.  Thx.

::::::::::::::
cshrc/4
::::::::::::::
From: sun!dagobah!mike
Date: Mon, 17 Sep 84 23:27:05 pdt
To: sun!resonex!nancy
Subject: .cshrc

set mail=(10 /usr/spool/mail/$user)
set path=(. ~/bin /usr/lfl/bin /usr/ucb /bin /usr/bin /usr/hosts /usr/suntool)
set cdpath  = ( . .. ~ /usr /u0 /u1 /audio)
set mail=(10 /usr/spool/mail/$user)
set msgs=(10 /usr/msgs/bounds)
set history = 50

source  ~/.aliases
set D = /net/dagobah/u0/mike
set d = /net/dim/u0/mike
set k = /net/kessel/u0/mike
set n = /net/nellybell/u0/mike
if (! $?HOST) setenv HOST `hostname`
alias s_prompt 'set prompt = "[$HOST\\\!$cwd]\\
% "'
alias cd 'cd \!*; s_prompt'
s_prompt


::::::::::::::
cshrc/5
::::::::::::::
From: sun!dagobah!mike
Date: Mon, 17 Sep 84 23:27:19 pdt
To: sun!resonex!nancy
Subject: .aliases

alias alice     cu -s 1200 2016654115
alias rabbit    cu -s 1200 2016654150
alias yale      cu -s 1200 2034323510
alias ajax      cu -s 1200 2015828265

alias ts        'setenv TERM `tset - \!* -Q`;set term = $TERM;unsetenv TERMCAP;'
alias aa        "ts aaa-26; aaapf"
alias aaa       aa

alias h         history
alias l         'ls -Fa'
alias lp        l -t
alias ll        'ls -laF | more'
alias wo        /u0/td/bin/who
alias m         'make \!* >>& errors &'
alias mail      Mail
alias ml        /bin/mail
alias lm        ml
alias rml       'rm -f /usr/spool/mail/mike'
alias RM        '/bin/rm -rf'
alias clean     'rm *.o core errors a.out'
alias CLEAN     'RM *.o core errors a.out ~/.REMOVED; mkdir ~/.REMOVED'
alias die       'clear; kill -HUP $'
alias tlog      tail -f /usr/spool/uucp/LOGFILE
alias ter       tail -f errors

  #
  # For job control:
  # Use 'fg' to bring job into the foreground, 'bg' to run job in background.
  #   'v', to restart vi editor
  #   'W', to restart ice editor
  #   'j', to list out jobs
  #   'k', to kill jobs; 'k 2' kills job [2]; 'k' kills the most recent job (+).
alias v       %vi
alias j       jobs
alias k       'kill %\!*'
alias sysline ~/bin/sysline -Dhmrj


::::::::::::::
cshrc/6
::::::::::::::
Date: Fri, 21 Sep 84 01:17:43 cdt
From: ihnp4!uiucdcs!liberte (Daniel LaLiberte)
To: sun!resonex!nancy
Subject: .cshrc trick

I like my recursive prompt that shows the depth of shell calls with added
">"s.  It also gives a different prompt for my superuser which has the same
home.  Additionally, we have several vaxes, uiucdcs*, networked with
ethernet.  Upgrades are easier with the same .cshrc on all machines.


...
if (! $?PROMPT) setenv PROMPT ""        # initialize
setenv PROMPT "$PROMPT>"                # add ">"
if ($?prompt) then
        set sys = `hostname`
        if ("$prompt" == "% ") then     # regular user
                set prompt = `echo $sys | sed s/uiucdcs//`
        else if ("$prompt" == "# ") then        # super user
                set prompt = "$sys#"
        endif
        set prompt = "$prompt\!$PROMPT "
endif


My login prompt (on uiucdcs) is:

1>

A csh call will produce:

1>>

Remote login to uiucdcsb, for example:

b1>

Superuser on uiucdcsb:

uiucdcsb#1>>


I have an alarm script and a spooled rcp that both use `at`.

Daniel LaLiberte
ihnp4!uiucdcs!liberte


::::::::::::::
cshrc/7
::::::::::::::
Date: Sun, 7 Oct 84 20:35:02 pdt
From: Ken Greer <hplabs!kg>
To: resonex!nancy
Subject: Xmas is early this year...

Here's what I thought were the most interesting things in my
csh profile.

1. Prompt is (curdir hist#), or [curdir hist#] if running as su.
   The brackets stack, so if I login as kg and su to kgsu, my prompt
   is [(curdir hist#)] indicating my previous shell was non-su.
   In both cases, the current directory always appears in prompt.

2. On that subject, I heartily recommend a separate su login
   for each su-er on a system.  This lets everyone have their
   own profile, and when they quit you don't have to change the su passwd,
   just remove their su.

3. The directory stuff. (I prefer it to pushd/popd.)
   ds   - displays directory stack (set to length DSSIZE below).
   go # - go to directory item number #
   back - go to previous directory.
   cd   - stack current directory and go to a new one.  Oldest directories
          fall off end of stack (whose size is DSSIZE).

4. The "e" and "ec" commands let you edit the last or any command.
   If works with a special program.  Would you like that?

5. Delete/Undelete - special program.  Lets you recover deleted
   files up to three days (user selectable).

6. Do you know about my tcsh?  Not sure how it fits in with tricks though.

                                -Ken


# Fancy prompt...
if ($?prompt) then
if (! $?LEFTPROMPT) setenv LEFTPROMPT ""
if (! $?RIGHTPROMPT) setenv RIGHTPROMPT ""
if (`whoami` == root) then
        setenv LEFTPROMPT '['"$LEFTPROMPT"
        setenv RIGHTPROMPT "$RIGHTPROMPT"']'
   set path=(~/bin /usr/local/etc /etc /usr/local/bin /usr/ucb /bin /usr/bin .)
else
        setenv LEFTPROMPT '('"$LEFTPROMPT"
        setenv RIGHTPROMPT "$RIGHTPROMPT"')'
        set path=(~/bin /usr/local/bin /usr/ucb /bin /usr/bin .)
endif
alias setprompt 'set prompt = "${LEFTPROMPT}${cwd} \\!${RIGHTPROMPT} "'
setprompt
alias a alias

# directory manipulation...
set DSSIZE = 10
if (! $?DS) set DS = (~)
a back  'set xx=$DS[$#DS] DS[$#DS]=$cwd; chdir $xx; unset xx; setprompt'
a go    'set xx=$DS[\!*] DS[\!*]=$cwd; chdir $xx; unset xx; setprompt'
a ds    'echo $DS | tr " " "\012" | cat -n'
a cd   'if ($#DS >= $DSSIZE) shift DS; set DS = ($DS $cwd);chdir \!*; setprompt'

# virtual remove...
a rm    del
a rm!   /bin/rm

# edit command...
a e     '/usr/local/bin/ec \!-1:q'
a ec    '/usr/local/bin/ec "\!*:q"'

# misc...
a j     jobs
a ls    '/usr/ucb/ls -F'
a tag   '/usr/ucb/vi -ta \!*'
a ts    'set noglob;eval `tset -s -Q \!*`'
a wd    'echo $cwd'
endif


::::::::::::::
cshrc/8
::::::::::::::
Date: Thu, 13 Sep 84 08:36:47 edt
From: sun!decvax!genrad!teddy!dls (Diana L. Syriac)
To: genrad!decvax!decwrl!sun!idi!resonex!nancy
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

I'm sorry, I don't really have any "tricks" to make life easier, I'm also
a rather new Unix user....except for one:
        I use setenv a lot to define a bunch of directories that I use
        a lot.  For example, I have in my .cshrc:
                setenv obc ~doc/rts/obc
        So anytime I want to get to that directory (or just look at it), I
        just type:      ls $obc/filename
        These environment variables work inside of mail as well as inside of
        emacs.
I suppose you already have that one from other people.

We also have on our system some "local" programs that make life a lot easier:
We have an "lf" and "dir" that replaces "ls" and "ls -l", but with an added
feature:  directories are displayed in bold letter, executables are displayed
in reverse video and special files are displayed in flashing letters.  It's
quite easy to see at a glance what the files are or where you want to go.

We also have a "pushd" and "popd" which replace the "cd" command.
        pushd directory
will pushd a directory onto the "stack", and change to it.  After you're
finished with that directory, just typing
        popd
will put you back to where you were.  There is a "dirs" command to
allow you to look at the "stack" to see where you are, where you've been.
If you use "cd" instead, it's smart enough to change your stack and replace
the current directory with the one specified in "cd". And if you just say
"pushd" by itself, it will SWAP the current directory with the last directory
you were in, making it very easy to toggle between two directories.

Other things that we've done:
        Built a script for the nroff command that is used by most people
on the system, including macros and some "local" filters to make it look
nice on terminal, line printer, and diablo.  I have also created a little
program which can be used in conjunction with nroff to produce "change bars"
at the left margin of documents.  We used the change bars quite a lot under
vms rno.
        We have a set of programs that produce "C" listings, with a table
of contents showing all files AND routines, page numbered and file numbered,
each file has a line number at left margin indicating file and line number
(eg: 3.41 refers to file 3, line 41), and at the very end of listing, there
is a cross-reference of all tokens, giving file.line references.  Part of
this set of programs was taken directly off the net and modified for our
own use.

Well, that's all that I can think of for now.  BUT what I really mailed
to you was for something that I want.  At the last DECUS, one of the speakers
demonstrated a little program that he wrote that allowed him to keep a
running log of what he did every day.  The program started up when he logged
on, and ran in the background.  Every 15 minutes, it would beep at him,
asking him to input a line telling what he was currently doing.  If ignored,
it would beep at him every minute until he input something to it.  I don't
know who the guy was, and I lost his business card, but I'd sure like to
get that program if you have it.  Thanks much.

                        Diana L. Syriac
                        GenRad, Concord, Ma.
                        decvax!genrad!teddy!dls


::::::::::::::
logins/1
::::::::::::::
From: sun!dagobah!mike
Date: Mon, 17 Sep 84 23:26:53 pdt
To: sun!resonex!nancy
Subject: .login

#tset -m dialup:aaa-60 -Q
tset -m dialup:c100-4p -Q
setenv TERM $term
switch ($TERM)
        case dialup:
                set term = aaa-60; setenv TERM $term
                ~/bin/aaapf
                breaksw
        case c100-4:
        case c108-4p:
                sysline
        case c100-4p:
                setkeys
endsw
stty new erase "^?"

biff y
setenv notify true
setenv CWD $cwd
setenv SHELL /bin/csh
setenv MAIL ~/Mail
setenv MANPATH /u0/pn/man:/u0/mike/Man:/usr/lfl/man:/usr/man
setenv INCPATH /usr/lfl/include:/usr/include:/u0/mike/Include
setenv LIBPATH /usr/lfl/lib:/lib:/usr/lib:/u0/mike/Lib
setenv LOADPATH /usr/src/lfl/bin/emacs.unipress/emacs4.2/maclib
setenv EDITOR /usr/ucb/vi
uupoll ucbvax
msgs


::::::::::::::
logins/2
::::::::::::::
Date: Fri, 14 Sep 84 10:42:43 edt
From: Jay Weber  <amd!mordor!ut-sally!seismo!rochester!jay>
To: ut-sally!mordor!dual!amd!resonex!nancy
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

I use the hold option in my .mailrc, which keeps messages around
until you explicitly delete them.  That's a popular option since
it makes it easy to keep around descriptions of things to do, but
it gets hard to tell when you have new mail and how much.  So, I
have this in my .login:

@ newmail= `from $mail[$#mail] |awk 'END{print NR}'` - `cat .mailsize`
if ($newmail == 1) then
  echo "(There is one new mail message.)"
else
  if ($newmail > 1) echo "(There are $newmail new mail messages.)"
endif
------------
and this in my .logout:

if (-r $mail[$#mail]) then
  from $mail[$#mail] | awk 'END{print NR}' >~/.mailsize
endif
------------

Jay Weber
..!seismo!rochester!jay
jay@rochester.arpa


::::::::::::::
logins/3
::::::::::::::
Date: Fri, 14 Sep 84 15:16:00 cdt
To: ctvax!convex!allegra!resonex!nancy
From: allegra!convex!trsvax!gm  (George Moore)
Subject: neat .login's

Nancy,
   Here is some of the aliases I use, as well as part of my .login
file: (We are running 4.1BSD on a 11/780)

  alias back 'set back=$old; set old=$cwd; cd $back; unset back'
  alias cd 'set old=$cwd; chdir \!*; sp'
  alias sp 'set prompt="$cwd> "'
Those aliases allow my prompt to always be my current directory.
You never have to run "pwd" again. Looks kindof strange when you
are in a low directory like /g/usr/src/local/csh, but you get used
to it. It also allows you to cd to some low dir, and then type
"back" and you are back in the directory you started in.

I have this line in my .login:
  sh -c "$HOME/bin/firstlog &"
This line allows you to spin off a background job without the
"[1] 22934"  message messing up your screen. Firstlog is done
below. I have a security program which goes out and checks a few
key files and directories (/etc/passwd, /etc/group, /usr/lib/crontab,
/etc). If anything has changed, it sends me mail informing me of the
fact. But I only wish it run once a day, at the time I first login for
the day. (I don't want it run from crontab, that makes things too
predictable for the users)

---------------------------------------------------------------------
#! /bin/csh
#  Firstlog -- finds out if this is the first time I have logged in
#              today and start-up all sorts of neat stuff if it is.

set date=`/bin/date`
set now=`/usr/ucb/last $user`
if ($date[2] != $now[13] || $date[3] != $now[14]) then
        sh -c "$HOME/personal/security/secure &"
endif
---------------------------------------------------------------------

I hope this helps.                              George Moore
                                                gm@trsvax.UUCP


From: Nancy Blachman <decvax!decwrl!sun!idi!resonex!nancy@Ucb-Vax.ARPA>
To: net.unix,net.unix-wizards,net.sources
Subject: Actual Tricks, shells, csh aliases and the like, 2 of 3
Date: 16 Oct 84 21:22:55 GMT
Organization: Resonex Inc., Sunnyvale, CA

> [Know anybody with a GREAT .login or .cshrc?]

> I'm interested in collecting the little tricks, shell scripts, awk
> hacks, csh aliases, and such that people have built to make their daily
> life a little easier or more automatic.  Being a fairly new system
> administrator I don't have the big toolbox that years of messing around
> will leave you with.  If you have any hacks you're proud of (or that
> you aren't proud of, but which work anyway), and you're willing to make
> them public, mail them to me.  I'll collect, collate, shuffle, sort,
> munge, judge, select and discard them and then "summarize to the net".

This article focuses shell scripts I received in response to my solicitation.
The first article of this series concentrates on  aliases, and .cshrc and
.login files. The third article centers on C programs and awk scripts.

/\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\/
> Nancy Blachman {allegra,hplabs,ihnp4,sun}!resonex!nancy  (408)720 8600 x37 <
/\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\/

::::::::::::::
shells/1
::::::::::::::
Date: Thu, 13 Sep 84 12:49:57 edt
From: allegra!vax135!cornell!tesla!mac (Michael Mc Namara)
To: cornell!vax135!houxm!mhuxl!ulysses!allegra!resonex!nancy
Subject: Cute cshell - sh scripts

    If your are like most UNIX systems, you have a plethora of different
terminals that  your system  is supposed to support.  Sure, with termcap
and terminfo, and programs written to use them, the interface gets easier.
If you only ever login to one particular terminal, you can

set term = "vt131"

or

TERM=vt131
export TERM

in your .login or .profile.

But what if you,  or some of your users,  drift  around using different
terminal types-- You have a terminal room with many different terminals.

Here is a set of shell scripts & C programs that use the "echo terminal
type" command that many terminals support, to do automatic terminal type
identification and setting:  (of course I've only made it work for  the
terminals we have here at Cornell, and some day I should write more of it
in C...)

    This one is written for cshell:

##########################################
#    Identify and set terminal type (csh)#
##########################################
set noglob
echo Please wait...
stty cbreak -echo
# this sequence will cause all terminals we have to echo something
# except for adm's; those users are told to hit 'a' when they see
# please wait
echo ' CZ[c'
sleep 1
# this calls a c program to grab the id string from the terminal
# program is included later...
set type = `/usr/new/rin.login`
stty -cbreak echo new crt
#########################
# the or in the vt100 terminal type is because vt100's respond
# to both ^[Z and ^[[c, but DEC threatens to eliminate one of
# the responces (I forget which).. The extra stty back you see
# with DG terminals (Data General) is because their backspace is
# ^Y instead of ^H ( Home on DG terminals) This involves a modification
# of stty, which you would care about only if you have them--Write to me.
##################
if ( $type == "[?1;0c" || $type == "[?1;0c[?1;0c" ) then
     set term = vt100
     echo "VT101"
else if ( $type == "[?1;2c" || $type == "[?1;2c[?1;2c" ) then
     set term = vt100
     echo "VT100"
else if ( $type == "[?1;11c[?1;11c") then
     set term = ct500
     echo "[7mCIT - 500[m"
else if ( $type == "[?12;5;0;102c" ) then
     set term = vt100
     echo "VT125"
else if ($type == "[?1;2c[?1;2c") then
     set term = vt100
     echo "VT100, with Selenar Graphics"
else if ( $type == "o#\!R" ) then
     set term = dg200
     stty stop undef start undef back
     echo "DDG200E"
else if ( $type == "o#'C3" ) then
     set term = dg450
     stty back
     echo "FS11BFS00 DATA GENERAL DASHER D450"
else if ( $type == "o#'K3" ) then
     set term = dg450
     stty back
     echo "FS11BFS00 DATA GENERAL DASHER D450"
else if ( $type == "/K" ) then
     set term = vt52
     echo "Visual 50"
else if ( $type =~ "\\4*" ) then
     set term = hp2621
     echo HP2621
else if ( $type =~ "a" ) then
     set term = adm3a
     echo "adm3a"
else if ($type == "50" ) then
     set term = w50
     echo "WYSE50"
else
# Ask user for terminal type -- for some reason the above didn't work
set no_name_yet=1
set no_name_yet = 1;
while( $no_name_yet )
   echo -n "Please enter terminal type (hit return for menu) "
   set ttyname = ({body}lt; );
   switch( $ttyname )
   case d450:
   case dg450:
      set term=dg450;
      stty back
      set no_name_yet = 0;
      breaksw;
   case vt100:
      set term=vt100;
      set no_name_yet = 0;
      breaksw;
   case v50:
   case vt52:
      set term=vt52;
      set no_name_yet = 0;
      breaksw;
   case hp2621:
   case hp:
      set term=hp2621;
      set no_name_yet = 0;
      breaksw;
   case wyse50:
      set term=w100;
      set no_name_yet = 0;
      breaksw;
   case adm5:
      set term=adm5;
      set no_name_yet = 0;
      breaksw;
   case adm3+:
   case adm3:
   case adm3a:
      set term=adm3+;
      set no_name_yet = 0;
   case d200:
   case dg200:
      set term=dg200;
      stty stop undef start undef back ;
      set no_name_yet = 0;
      breaksw;
   case other:
      echo -n "Enter terminal name: "
      set term=({body}lt; );
      set no_name_yet = 0;
      breaksw;
   case '':
      echo Terminal abbreviations are:
      echo "Dasher 450 : dg450"
      echo "Dasher 200 : dg200"
      echo "Visual 50  : v50"
      echo "VT100      : vt100"
      echo "HP 2621    : hp2621"
      echo "ADM5       : adm5"
      echo "ADM3+      : adm3+"
      echo "Use 'other' to specify terminals not on this menu"
      breaksw;
   default:
      echo "I didn't understand that. Hit return for a menu."
   endsw
end
unset no_name_yet
unset ttyname
endif
stty -cbreak
stty echo
unset noglob

Ok, This one is used for Bourne shell lovers:  (I used /bin/test because
one user had an executable file called test somewhere in his path ahead
of where this program lived...That one took days to track down...)


echo "Please Wait..."
stty start  stop   crt new back  -echo cbreak
echo ' CZ[c'
sleep 1
TYPE=`/usr/new/rin.login`
stty echo -cbreak
if ( /bin/test \( $TYPE = "[?1;0c" \) -o \( $TYPE = "[?1;0c[?1;0c" \) ) then
     TERM=vt100
     echo "[7mVT101[m"
elif ( /bin/test \( $TYPE = "[?1;2c" \) -o \( $TYPE = "[?1;2c[?1;2c" \)  ) then
     TERM=vt100
     echo "#3[7mVT100[m"
     echo "#4?[7mVT100[m"
elif ( /bin/test  $TYPE = "[?1;11c[?1;11c") then
     TERM=ct500
     echo "CT 500"
elif ( /bin/test  $TYPE = "o#!R" ) then
     TERM=dg200
     stty stop undef
     stty start undef
     stty crt
     stty back
     echo "D DATA GENERAL DASHER D200E"
elif ( /bin/test $TYPE = "o#'C3" )  then
     TERM=dg450
     stty crt
     stty back
     echo "FS11BFS00 DATA GENERAL DASHER D450"
elif ( /bin/test $TYPE = "/K" ) then
     TERM=vt52
     echo "UVisual 50T"
elif ( /bin/test $TYPE = "50" ) then
     TERM=w50
     clear
     echo "WYSE 50"
elif ( /bin/test $TYPE = "\4088000" ) then
     TERM=hp2621
     echo HP2621
elif ( /bin/test $TYPE = "a" ) then
     TERM=adm3a
     echo ADM3a
else
     stty start
     stty stop
     stty new crt
     set no_name_yet=1
echo
while ($no_name_yet) do {
  echo
  echo Which terminal do you have?
  echo       Hit return for a menu.
  read INP
  case $INP
    in
100 | v | vt100) {
                  TERM=vt100
                  break
             } ;;
adm5)            {
                 TERM=adm5
                 break
             } ;;
adm3+)           {
                 TERM=adm3+
                 break
             } ;;
450 | dg450 | d450)  {
                  TERM=dg450
                  stty back
                  break
             } ;;
200 | dg200 | d200)  {
                  TERM=dg200
                  stty stop undef
                  stty start undef
                  stty back
                  break
             }  ;;
 50 | vt52 | v50)   {
                  TERM=vt52
                  break
             } ;;
 2621 | hp2621 | hp) {
                  TERM=hp2621
                  break
             } ;;
      other) {
                  echo -n Enter terminal name:
                  read tname
                  TERM=$tname
                  break
             } ;;
 ''|?|help)  {    echo Terminal abbreviations are:
                  echo
                  echo Dasher 450:  dg450
                  echo Dasher 200:  dg200
                  echo Visual  50:  vt52
                  echo VT100     :  vt100
                  echo HP 2621   :  hp2621
                  echo ADM3+     :  adm3+
                  echo ADM5      :  adm5
                  echo "Use 'other' to specify other terminals."
                  echo
             } ;;
        * )  {   echo "I did not understand that."
             } ;;
  esac
  }
done
fi
export TERM


And here is the c program that read's in the terminal ID string:


/* rin -- read in a char string which may not be terminated */
char buf[256];
int n;
main ()
{
n = read(0,buf,256);
write(1,buf,n);
printf("\n");
}




        Use them, abuse them.  Of course you have to paw through
your terminal manuanls to discover what (if any) string they respond to,
and test for the response accordingly...

                                        ---MAC



::::::::::::::
shells/2
::::::::::::::
From: hplabs!azure!billp
To: tektronix!hplabs!resonex!nancy
Date: Thursday, 13 Sep 84 09:23:49 PDT
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

Here are some that I like and use a lot.  'del' and 'undelete' are just two
links to the same file.  This way if somebody copies one, they get the
other too
-------------------------------------------------------------------------------
::::::::::::::
: mv
::::::::::::::
: 'prompts if the destination file already exists'
/bin/mv -i $*
-------------------------------------------------------------------------------
::::::::::::::
: cp
::::::::::::::
: 'prompts if the destination file already exists'
/bin/cp -i $*
-------------------------------------------------------------------------------
::::::::::::::
: del, undelete
::::::::::::::
: '"del" throws files into the waste basket'
: 'files preceded by "," are automagically removed after 7 days'
: '"undelete" pulls files out of the waste basket'
: 'if invoked without an argument, both commands list the contents of the'
: 'waste basket.'

case $0 in

    if test -z "$1"
    then
        ls -lus $HOME/.waste_basket
    else
        for i
        do
            echo -n "deleting "
            tmp=`basename $i`
            /bin/mv -i $i $HOME/.waste_basket/,$tmp
            echo $i
        done
    fi;;


    if test -z "$1"
    then
        ls -lus $HOME/.waste_basket
    else
        for i
        do
            echo -n "recovering "
            tmp=`basename $i`
            /bin/mv -i $HOME/.waste_basket/,$tmp $i
            echo $i
        done
    fi;;
esac
-------------------------------------------------------------------------------
::::::::::::::
: vi
::::::::::::::
: 'backs up file(s) before editing them'
: 'files preceded by "," are automagically removed after 7 days'
for i
do
    if test -f $i
    then
        echo -n "backing up "
        tmp=`basename $i`
        /bin/cp -i $i $HOME/.vi_backup/,$tmp
        echo $i
    fi
done
/usr/ucb/vi $*
-------------------------------------------------------------------------------

        Bill Pfeifer
{ucbvax,decvax,ihnp4,allegra,uw-beaver,hplabs} !tektronix!tekmdp!billp

::::::::::::::
shells/3
::::::::::::::
Date: Thu, 13 Sep 84 13:58:09 pdt
From: turtlevax!ken (Ken Turkowski)
To: resonex!nancy
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

You asked for it, you've got it!  Here's ALL of my personal nifties:
                        Ken


echo x - bin
mkdir bin
echo x - bin/CC
cat >bin/CC <<'!Funky!Stuff!'
#
set outname=a.out
foreach file ($argv)
    if ("$file" =~ *.[cso]) then
        set outname=$file:r
        break
    endif
end
echo cc -o $outname $*
exec cc -o $outname $*
!Funky!Stuff!
echo x - bin/appt
cat >bin/appt <<'!Funky!Stuff!'
#
set notetype=$0
set notetype=$notetype:t
set notefile=~/.$notetype
# if ($notetype == appt) then
#     set notetype=appointment
#     set notefile=~/calendar
# endif

if ($#argv == 0) then
    test -t 0 && echo Please enter your $notetype entry '(^D to end):'
    echo ' ' >> $notefile
    exec cat >> $notefile
endif

switch ($1)
    case -:
        exec vi $notefile
    case -rm:
        cat /dev/null > $notefile
        exec echo The ${notetype}s are removed.
    case -what:
        exec cat $notefile
    default:
        echo '' >> $notefile
        echo "$*" >> $notefile
endsw
!Funky!Stuff!
echo x - bin/asfix
cat >bin/asfix <<'!Funky!Stuff!'
case $# in
    0)
        file=/tmp/afix$
        trap "cat $file; rm $file; exit" 0
        trap "rm $file; exit" 3 9
        cat > $file ;;
    1)
        file=$1 ;;
    *)
        echo Usage `basename $0` ' [ <file> ]' ;;
esac
ed - $file << EOF
v/[:\.]/s/^/    /
g/:./s/:/:      /
wq
EOF
!Funky!Stuff!
echo x - bin/atcat
cat >bin/atcat <<'!Funky!Stuff!'
#
if ($#argv < 2) then
    set cmd=$0
    echo Usage: "$cmd:t <time> <word> [ <word> ... ]"
    exit
endif
set atcmd="echo $argv[2-] > `tty`"
at $1 << EOF
$atcmd
EOF
!Funky!Stuff!
echo x - bin/atecho
cat >bin/atecho <<'!Funky!Stuff!'
#
if ($#argv < 2) then
    set cmd=$0
    echo Usage: "$cmd:t <time> <word> [ <word> ... ]"
    exit
endif
set atcmd="echo $argv[2-] > `tty`"
at $1 << EOF
$atcmd
EOF
!Funky!Stuff!
echo x - bin/beautify
cat >bin/beautify <<'!Funky!Stuff!'
#
set TMP=/tmp/cb$
foreach file (argv)
    echo Beautifying $file:
    cb < $file > $TMP
    cat $TMP > $file
end
rm $TMP
!Funky!Stuff!
echo x - bin/blankclean
cat >bin/blankclean <<'!Funky!Stuff!'
sed -e 's/^     $//' -e 's/ *$//' $*
!Funky!Stuff!
echo x - bin/bphone
cat >bin/bphone <<'!Funky!Stuff!'
phonefile=$HOME/.`basename $0`s

echo ' '

case $# in
    0)
        ed - $phonefile << EOF
g/./s/$/\\
/
g/      /s//\\
/g
g/;/s// /g
1,\$p
q
EOF
    exit ;;
esac

case $1 in
    -)
        chmod 644 $phonefile
        vi $phonefile
        chmod 444 $phonefile
        exit ;;
esac

trap "rm /tmp/data$; exit" 0 2
for name
do
    grep -y "$name" $phonefile >> /tmp/data$
done
ed - /tmp/data$ << EOF
g/./s/$/\\
/
g/      /s//\\
/g
g/;/s// /g
1,\$p
q
EOF
!Funky!Stuff!
echo x - bin/catalog
cat >bin/catalog <<'!Funky!Stuff!'
# catalog - produce complete file structure list from directory
#
# Parameters:   1: directory name (optional)
#               2: indentation string (empty on first call)
#
# Produces on standard output the file structure emanating from
#   the current directory.  Each descent into a subdirectory
#    is indicated by further indentation.  Directories are indicated
#    by surrounding [], and executable files are prefaced with a *.
#
if ( $#argv == 0) then
   echo "file structure from directory `pwd`"
   date
   echo ''
else
   cd $1
endif
foreach i ( * )
   if ( -d $i ) then
         echo "${2}[ $i ]"
         $0 $i "$2  . "
   endif
         if ( "$i" != '*' ) then
            if ( -x $i ) then
               echo "${2} *$i "
            else
               echo "${2}  $i "
            endif
         endif
   endif
end
!Funky!Stuff!
echo x - bin/circum
cat >bin/circum <<'!Funky!Stuff!'
there=$1
shift
otherstuff="$*"
back=`whoami`
last=`hostname`
IFS='    !
'
for link in $there
do
    back="$last!$back"
    last=$link
done
IFS='
'
echo mail $there!$back
(date; echo "$otherstuff") | mail -s "Circumlocution to $last" $there!$back
!Funky!Stuff!
echo x - bin/comfmt
cat >bin/comfmt <<'!Funky!Stuff!'
exec fmt | \
sed -e '1s/^\([  ]*\)/\1\/\* /' -e '2,$s/^\([    ]*\)/\1 \* /' -e '${P
s/\*.*/*\//
}'
!Funky!Stuff!
echo x - bin/comstrip
cat >bin/comstrip <<'!Funky!Stuff!'
exec sed -e 's/\/\*//' -e 's/\*\///' -e 's/^[   ]*\** *//'
!Funky!Stuff!
echo x - bin/decvert
cat >bin/decvert <<'!Funky!Stuff!'
#
if ($#argv == 0) then
    set args=`cat`
    if ($#args != 0) $0 $args
    exit
endif

foreach hexnum ($argv)
dc << EOF
16i
${hexnum}p
EOF
end
!Funky!Stuff!
echo x - bin/f77
cat >bin/f77 <<'!Funky!Stuff!'
PATH=/usr/bin
SPECLIB=/usr/ken/cmd/lib/libc.a
exec f77 "$@" $SPECLIB
!Funky!Stuff!
echo x - bin/famove
cat >bin/famove <<'!Funky!Stuff!'
#
if ($#argv != 2) then
    echo Usage: $0 '<source family root> <destination family root>'
    exit
endif
foreach file ($1.*)
    set suffix=`expr $file : "$1\.\(.*\)"`
    echo mv $file $2.$suffix
    mv $file $2.$suffix
end
if (-e $1) then
    echo mv $1 $2
    mv $1 $2
endif
!Funky!Stuff!
echo x - bin/gredit
cat >bin/gredit <<'!Funky!Stuff!'
#
set CAESAR=/mnt/cad/bin/caesar
set SEARCHPATH=(-p ::/usr/ken/caesar/symlib)
set COLORMAP=(-c mumap.cmap)
set GRTERM=ttyh7
set caesarfile=()
foreach parm ($argv)
    if ($?flag) then
        switch ($flag)
            case g:
                set GRTERM=$parm
                breaksw
            case p:
                set SEARCHPATH=(-p "$parm")
                breaksw
            case R:
                set SEARCHPATH=($SEARCHPATH:$parm)
                breaksw
            case c:
                set COLORMAP=(-c $parm)
                breaksw
        endsw
        unset flag
        continue
    endif
    if ($parm =~ -*) then
        switch ($parm)
            case -g:
                set flag=g
                continue
            case -p:
                set flag=p
                continue
            case -P:
                set SEARCHPATH=()
                continue
            case -R:
                set flag=R
                continue
            case -C:
                set COLORMAP=()
                continue
            case -c:
                set flag=c
                continue
        endsw
    else
        set caesarfile=($caesarfile $parm)
    endif
end
onintr -
$CAESAR -g $GRTERM $SEARCHPATH $COLORMAP $caesarfile
!Funky!Stuff!
echo x - bin/grindall
cat >bin/grindall <<'!Funky!Stuff!'
#
set flags=
set fileargs=
onintr cleanup
foreach file ($argv)
    if ($file =~ -*) then
        if ($file == -t) then
            set stdout
        else
            set flags=($flags $file)
        endif
    else
        set fileargs=($fileargs $file)
    endif
end

if ($?stdout) then
    foreach file ($fileargs)
        vgrind -t $flags $file
    end
else
    foreach file ($fileargs)
        vgrind -t $flags $file >> /usr/tmp/grind$
    end
    vpr -T $fileargs[1] -t /usr/tmp/grind$
endif

cleanup:
rm /usr/tmp/grind$
!Funky!Stuff!
echo x - bin/hardasm
cat >bin/hardasm <<'!Funky!Stuff!'
#
grasm -1 -l -x $* |& pr -f -h "grasm -l -x $*" | vpr -l
!Funky!Stuff!
echo x - bin/hexvert
cat >bin/hexvert <<'!Funky!Stuff!'
#
if ($#argv == 0) then
    set args=`cat`
    if ($#args != 0) $0 $args
    exit
endif

foreach decnum ($argv)
dc << EOF
16o
${decnum}p
EOF
end
!Funky!Stuff!
echo x - bin/job
cat >bin/job <<'!Funky!Stuff!'
PATH=/usr/ken/cmd/bin:/usr/ucb:/bin:/usr/bin
case $# in
    0)
        exec echo Usage: `basename $0` '-;' or $0 '<job description>' ;;
esac
case $1 in
    -)
        exec ex $HOME/.joblog ;;
    -h | -hr | -hrs)
        shift
        hrs=$1
        shift
        exec echo '   job:' $hrs hours # $* >> $HOME/.joblog ;;
    -tail)
        exec tail -22 $HOME/.joblog ;;
    -today)
        {
            while read line
            do
                case $line in
                    *login*)
                        login="$line" ;;
                esac
            done
            echo -n "$login" "for "
            diffdate "$login" "`date`"
        } < $HOME/.joblog ;;
    -login)
        echo ' login:' "`date`" >> $HOME/.joblog ;;
    -summary)
        cat $HOME/.joblog |
            while read line
            do
                case $line in
                    *login*)
                        login="$line" ;;
                    *logout*)
                        logout="$line"
                        echo -n "$login" "for "
                        diffdate "$login" "$logout"
                esac
            done ;;
    *)
        exec echo '   job:' "`date`" # $* >> $HOME/.joblog ;;
esac
!Funky!Stuff!
echo x - bin/ledger
cat >bin/ledger <<'!Funky!Stuff!'
#
set notetype=$0
set notetype=$notetype:t
set notefile=~/.$notetype
# if ($notetype == appt) then
#     set notetype=appointment
#     set notefile=~/calendar
# endif

if ($#argv == 0) then
    test -t 0 && echo Please enter your $notetype entry '(^D to end):'
    echo ' ' >> $notefile
    exec cat >> $notefile
endif

switch ($1)
    case -:
        exec vi $notefile
    case -rm:
        cat /dev/null > $notefile
        exec echo The ${notetype}s are removed.
    case -what:
        exec cat $notefile
    default:
        echo '' >> $notefile
        echo "$*" >> $notefile
endsw
!Funky!Stuff!
echo x - bin/lstree
cat >bin/lstree <<'!Funky!Stuff!'
#
if ($#argv == 0) then
    set root=.
else
    set root=($*)
endif
exec find $root -print | sort | sed -e 's/[^ \/]*\//    /g'
!Funky!Stuff!
echo x - bin/match
cat >bin/match <<'!Funky!Stuff!'
cat $2 |
while read x
do
    for word in $x
    do
        case $word in
            $1)
                echo $word ;;
        esac
    done
done
!Funky!Stuff!
echo x - bin/narrow
cat >bin/narrow <<'!Funky!Stuff!'
echo \!
!Funky!Stuff!
echo x - bin/outmesg
cat >bin/outmesg <<'!Funky!Stuff!'
#
set notetype=$0
set notetype=$notetype:t
set notefile=~/.$notetype
# if ($notetype == appt) then
#     set notetype=appointment
#     set notefile=~/calendar
# endif

if ($#argv == 0) then
    test -t 0 && echo Please enter your $notetype entry '(^D to end):'
    echo ' ' >> $notefile
    exec cat >> $notefile
endif

switch ($1)
    case -:
        exec vi $notefile
    case -rm:
        cat /dev/null > $notefile
        exec echo The ${notetype}s are removed.
    case -what:
        exec cat $notefile
    default:
        echo '' >> $notefile
        echo "$*" >> $notefile
endsw
!Funky!Stuff!
echo x - bin/path
cat >bin/path <<'!Funky!Stuff!'
IFS="${IFS}:"
for cmddir in $PATH
do
    test -s $cmddir/$1 && echo "        $cmddir/$1"
done
!Funky!Stuff!
echo x - bin/pphone
cat >bin/pphone <<'!Funky!Stuff!'
phonefile=$HOME/.`basename $0`s

echo ' '

case $# in
    0)
        ed - $phonefile << EOF
g/./s/$/\\
/
g/      /s//\\
/g
g/;/s// /g
1,\$p
q
EOF
    exit ;;
esac

case $1 in
    -)
        chmod 644 $phonefile
        vi $phonefile
        chmod 444 $phonefile
        exit ;;
esac

trap "rm /tmp/data$; exit" 0 2
for name
do
    grep -y "$name" $phonefile >> /tmp/data$
done
ed - /tmp/data$ << EOF
g/./s/$/\\
/
g/      /s//\\
/g
g/;/s// /g
1,\$p
q
EOF
!Funky!Stuff!
echo x - bin/progression
cat >bin/progression <<'!Funky!Stuff!'
last=
for backup in $1_??
do
    case $last in
        "")
            last=$backup
            continue;
    esac
    echo ''
    echo From $last to $backup:
    diff $last $backup
    last=$backup
done
echo ''
echo From $last to $1:
diff $last $1
!Funky!Stuff!
echo x - bin/query
cat >bin/query <<'!Funky!Stuff!'
#
set notetype=$0
set notetype=$notetype:t
set notefile=~/.$notetype
# if ($notetype == appt) then
#     set notetype=appointment
#     set notefile=~/calendar
# endif

if ($#argv == 0) then
    test -t 0 && echo Please enter your $notetype entry '(^D to end):'
    echo ' ' >> $notefile
    exec cat >> $notefile
endif

switch ($1)
    case -:
        exec vi $notefile
    case -rm:
        cat /dev/null > $notefile
        exec echo The ${notetype}s are removed.
    case -what:
        exec cat $notefile
    default:
        echo '' >> $notefile
        echo "$*" >> $notefile
endsw
!Funky!Stuff!
echo x - bin/releave
cat >bin/releave <<'!Funky!Stuff!'
#
set tty=`tty`
set tty=`expr $tty : '.*tty\(.*\)'`
set leaveproc=`ps gt$tty | grep -w leave`
kill -9 $leaveproc[1]
date
leave $*
!Funky!Stuff!
echo x - bin/reminder
cat >bin/reminder <<'!Funky!Stuff!'
#
set notetype=$0
set notetype=$notetype:t
set notefile=~/.$notetype
# if ($notetype == appt) then
#     set notetype=appointment
#     set notefile=~/calendar
# endif

if ($#argv == 0) then
    test -t 0 && echo Please enter your $notetype entry '(^D to end):'
    echo ' ' >> $notefile
    exec cat >> $notefile
endif

switch ($1)
    case -:
        exec vi $notefile
    case -rm:
        cat /dev/null > $notefile
        exec echo The ${notetype}s are removed.
    case -what:
        exec cat $notefile
    default:
        echo '' >> $notefile
        echo "$*" >> $notefile
endsw
!Funky!Stuff!
echo x - bin/reremind
cat >bin/reremind <<'!Funky!Stuff!'
#
set tty=`tty`
set tty=`expr $tty : '.*tty\(.*\)'`
set leaveproc=`ps gt$tty | awk '$5 ~ /^remind$/ { print $1 }'`
if ($#leaveproc > 1) echo $#leaveproc reminds were running
kill -9 $leaveproc
date
if ($#argv <= 1) then
    remind $*
else
    set time=$1
    shift
    remind $time "$*"
endif
!Funky!Stuff!
echo x - bin/restore
cat >bin/restore <<'!Funky!Stuff!'
# Truncate filename if necessary
set file=$1
if (`expr $file:t : '.*'` >= 11) then
    set savename=`expr $file : '\(.*\)'$file:t`
    set savename=$savename`expr $file:t : '\(...........\)'`
else
    set savename=$file
endif

switch ($#argv)
    case 1:
        set nonomatch
        set backup=(${savename}_[0-9][0-9])
        if ("$backup" == "${savename}_[0-9][0-9]") then
            echo Error: No backups found for $file
            exit
        endif
        set backup=$backup[$#backup]
        echo No backup number specified. Using latest: $backup
        breaksw
    case 2:
        set backup=${savename}_$2
        breaksw
    default:
        exec echo Usage: `basename $0` '<file>' '[<backup number>]'
endsw

if ( { cp $backup $file } ) then
    echo $file restored from $backup.
    echo -n Do you wish to keep "$backup? "
    set response={body}lt;
    if ($response !~ y*) then
        rm $backup
    endif
endif
!Funky!Stuff!
echo x - bin/rot13
cat >bin/rot13 <<'!Funky!Stuff!'
tr "A-Za-z" "N-ZA-Mn-za-m"
!Funky!Stuff!
echo x - bin/shufcol
cat >bin/shufcol <<'!Funky!Stuff!'
trap 'rm /tmp/$.*; exit' 0 2
cat > /tmp/$.0
i=1
for cols
do
    cut -f$cols < /tmp/$.0 > /tmp/$.$i
    filelist="$filelist /tmp/$.$i"
    i=`expr $i + 1`
done
paste $filelist
!Funky!Stuff!
echo x - bin/signature
cat >bin/signature <<'!Funky!Stuff!'
PATH=/bin:/usr/bin
cat
echo --
cat $HOME/.signature
!Funky!Stuff!
echo x - bin/swab
cat >bin/swab <<'!Funky!Stuff!'
#
if ($#argv == 0) then
    dd conv=swab
else
    onintr cleanup
    foreach file ($argv)
        cp $file /tmp/swab$
        dd if=/tmp/swab$ of=$file conv=swab
    end
    cleanup:
    rm /tmp/swab$
endif
!Funky!Stuff!
echo x - bin/what
cat >bin/what <<'!Funky!Stuff!'
cat $HOME/.query
echo -n 'save? (n or d to delete, e to edit) '
read response
case $response in
    n | no | d | delete)
        rm $HOME/.query && echo The query is removed. ;;
    "" | y | yes | s | save)
        exit ;;
    e | edit)
        exec vi $HOME/.query < /dev/tty
        exit ;;
    *)
        echo Bad response: "$response"
        exec $0 ;;
esac
!Funky!Stuff!
echo x - bin/whereis
cat >bin/whereis <<'!Funky!Stuff!'
N=$#
command=echo
case "$1" in
    -*)
        command=`expr "$1" : '-\(.*\)'`
        shift
        N=`expr $N - 1` ;;
esac
case $N in
    0)
        exec echo Usage: `basename $0` [ -command ] pattern file ...  ;;
    1)
        files=`fgrep -l "$1" *` ;;
    *)
        files=`fgrep -l "$@"` ;;
esac
case $files in
        "")
            echo $1 not found in any files.
            exit ;;
esac
exec $command $files
!Funky!Stuff!
echo x - bin/wide
cat >bin/wide <<'!Funky!Stuff!'
echo \"
!Funky!Stuff!
echo x - bin/xprint
cat >bin/xprint <<'!Funky!Stuff!'
case $# in
    1)
        eval $1 | eval pr -f -h \"$1\" | vpr -l ;;
    *)
        command='cat $file'
        for file
        do
            case $file in
                -*)
                    command=`expr "$file" : '-\(.*\)'`
                    case $command in
                        *\$file*)
                            ;;
                        *)
                            command="$command \$file" ;;
                    esac ;;
                *)
                    eval $command | eval pr -f -h \"$command\" | vpr -l ;;
            esac
        done
esac
!Funky!Stuff!
echo x - bin/archives
mkdir bin/archives
echo x - bin/archives/newsweed
cat >bin/archives/newsweed <<'!Funky!Stuff!'
#
cd
if ($#argv == 0) then
    if (-e .newsweed) then
        set WEEDGROUPS=`cat .newsweed`
    else
        set WEEDGROUPS=
    endif
else
    set WEEDGROUPS=$*
endif
if ($#WEEDGROUPS == 0) then
    onintr
    echo Searching for articles in all newsgroups
    readnews -l | \
    grep Subject | \
    sed -e 's/Subject: *//' -e 's/^[rR][eE]:*  *//' | \
    sort -u > /tmp/weed$a
    if (-z /tmp/weed$a) then
        echo No news.
    else
        cp /tmp/weed$a /tmp/weed$b
        echo Please remove article titles which you do not wish to read
        sleep 1
        onintr -
        vi /tmp/weed$b
        onintr cleanup
        comm -23 /tmp/weed$a /tmp/weed$b > /tmp/weed$c
        echo Removing unwanted articles
        newsec -f /tmp/weed$c
    endif
else
    foreach group ($WEEDGROUPS)
        echo Searching for articles in group\(s\):
        echo $group
        readnews -l -n $group | \
        grep Subject | \
        sed -e 's/Subject: *//' -e 's/^[rR]e:*  *//' | \
        sort -u > /tmp/weed$a
        if (-z /tmp/weed$a) then
            echo in newsgroups $group.
        else
            cp /tmp/weed$a /tmp/weed$b
            echo Please remove article titles which you do not wish to read
            sleep 1
            onintr -
            vi /tmp/weed$b
            onintr cleanup
            comm -23 /tmp/weed$a /tmp/weed$b > /tmp/weed$c
            echo Removing unwanted articles
            newsec -f /tmp/weed$c
        endif
    end
endif

cleanup:
rm /tmp/weed$?
!Funky!Stuff!
echo x - bin/archives/pk_01
cat >bin/archives/pk_01 <<'!Funky!Stuff!'
: Roff, nroff, or eqn input text
for file in `file $* | sed -n '/eqn input text$/s/:[^:]*$//p'`
do
    echo "echo x - $file"
    echo "sed 's/^x//' >$file <<'!Funky!Stuff!'"
    sed 's/^/x/' $file; echo "!Funky!Stuff!"
done
: Text files
for file in `file $* | sed -n -e '/commands text$/s/:[^:]*$//p' -e '/ascii text$/s/:[^:]*$//p'`
do
    echo "echo x - $file"
    echo "cat >$file <<'!Funky!Stuff!'"
    cat $file; echo "!Funky!Stuff!"
done
: Directories, recursively
for dir in `file $* | sed -n '/directory$/s/:.*//p'`
do
    echo "echo x - $dir"
    echo "mkdir $dir"
    file=`echo $dir/*`
    test "$file" != "$dir/*" && $0 $file
done
!Funky!Stuff!
echo x - bin/archives/pkf
cat >bin/archives/pkf <<'!Funky!Stuff!'

for dir
do
        echo "echo x - $dir"
        echo "mkdir $dir";
        for file in `file $dir/* | sed -n '/text$/s/:[^:]*$//p'`
        do
                echo "echo x - $file"
                echo "cat >$file <<'!Funky!Stuff!'"
                cat $file; echo "!Funky!Stuff!"
        done
        $0 `file $dir/* | sed -n '/directory$/s/:.*//p'`
done
!Funky!Stuff!
echo x - bin/archives/pkg
cat >bin/archives/pkg <<'!Funky!Stuff!'
for file
do
    echo "echo x - $file"
    echo "cat >$file <<'!Funky!Stuff!'"
    cat $file; echo "!Funky!Stuff!"
done
!Funky!Stuff!
echo x - bin/archives/pkn
cat >bin/archives/pkn <<'!Funky!Stuff!'

for dir
do
        echo "echo x - $dir"
        echo "mkdir $dir";
        for file in `file $dir/* | sed -n '/text$/s/:[^:]*$//p'`
        do
                echo "echo x - $file"
                echo "sed 's/^x//' >$file <<'!Funky!Stuff!'"
                sed 's/^/x/' $file; echo "!Funky!Stuff!"
        done
        $0 `file $dir/* | sed -n '/directory$/s/:.*//p'`
done
!Funky!Stuff!
echo x - bin/archives/prod
cat >bin/archives/prod <<'!Funky!Stuff!'
#
set flags=()
set syslist=()
foreach arg ($argv)
    switch ($arg)
        case -s*:
            if (`expr $arg : '.*'` > 9) then
                rm -f /usr/spool/uucp/STST.`expr $arg : '-s\(.......\)'`
            else
                rm -f /usr/spool/uucp/STST.`expr $arg : '-s\(.*\)'`
            endif
            set syslist=($syslist $arg)
            breaksw
        case -*:
            set flags=($flags $arg)
            breaksw
        default:
            if (`expr $arg : '.*'` > 7) then
                rm -f /usr/spool/uucp/STST.`expr $arg : '\(.......\)'`
            else
                rm -f /usr/spool/uucp/STST.$arg
            endif
            set syslist=($syslist -s$arg)
            breaksw
    endsw
end
foreach sys ($syslist)
    /usr/lib/uucp/uucico -r1 $flags $sys
end
!Funky!Stuff!
echo x - bin/bourne_scripts
mkdir bin/bourne_scripts
echo x - bin/bourne_scripts/lookdoc
sed 's/^x//' >bin/bourne_scripts/lookdoc <<'!Funky!Stuff!'
xtrap exit 2
xcase $# in
x    0)
x       ul | more
x       exit ;;
xesac
xfor names
xdo
x    case $names in
x       -n)
x           default=n ;;
x       -t)
x           default=t ;;
x       -m*)
x           macros="$macros $names" ;;
x       *.n | *.nr)
x           nroff $macros $names | ul | more ;;
x       *.t | *.tbl)
x           soelim $names | tbl | nroff $macros - | ul | more ;;
x       *)
x           case $default in
x               n)
x                   nroff $macros $names | ul | more ;;
x               t)
x                   soelim $names | tbl | nroff $macros - | ul | more ;;
x               "")
x                   ul $names | more ;;
x           esac
x    esac
xdone
!Funky!Stuff!
echo x - bin/bourne_scripts/CC
cat >bin/bourne_scripts/CC <<'!Funky!Stuff!'
outname=a.out
for argv
do
    case $argv in
        *.[cos])
            outname=`expr $argv : '\(.*\)\.'`
            break ;;
    esac
done
cc -o $outname $*
!Funky!Stuff!
echo x - bin/bourne_scripts/appt
cat >bin/bourne_scripts/appt <<'!Funky!Stuff!'
case $0 in
    appt)
        notetype=appointment
        notefile=$HOME/calendar ;;
    *)
        notetype=$0
        notefile=$HOME/.$0 ;;
esac

case $# in
    0)
        test -t 0 && echo Please enter your $notetype '(^D to end):'
        echo '' >> $notefile
        exec cat >> $notefile ;;
esac
case $1 in
    -)
        exec vi $notefile ;;
    -rm)
        cat /dev/null > $notefile
        exec echo The ${notetype}s are removed. ;;
    -what)
        exec cat $notefile ;;
    *)
        echo '' >> $notefile
        exec echo "$*" >> $notefile ;;
esac
!Funky!Stuff!
echo x - bin/bourne_scripts/beautify
cat >bin/bourne_scripts/beautify <<'!Funky!Stuff!'
for files
do
    echo $files:
    cb < $files > /tmp/cb$
    cat /tmp/cb$ > $files
done
rm /tmp/cb$
!Funky!Stuff!
echo x - bin/bourne_scripts/format
cat >bin/bourne_scripts/format <<'!Funky!Stuff!'
case $# in
    0)
        echo "Usage: `basename $0` [-flags] <filename> [ <filename> ... ]"
        exit 1 ;;
esac
for names
do
    case $names in
        -*)
                flags="$flags $names" ;;
        *.t)
                outfile=`expr $names : '\(.*\)\.'`.d
                soelim $names | tbl | nroff $flags - > $outfile ;;
        *.tbl)
                outfile=`expr $names : '\(.*\)\.'`.doc
                soelim $names | tbl | nroff $flags - > $outfile ;;
        *.n)
                outfile=`expr $names : '\(.*\)\.'`.d
                nroff $flags $names > $outfile ;;
        *.nr)
                outfile=`expr $names : '\(.*\)\.'`.doc
                nroff $flags $names > $outfile ;;
        *)
                echo Don\'t know what to do with $names ;;
    esac
done
!Funky!Stuff!
echo x - bin/bourne_scripts/print
cat >bin/bourne_scripts/print <<'!Funky!Stuff!'
PATH=/avsd/ava/turk/bin:/usr/local/bin:/usr/bin
indent=0
for names
do
    case $names in
        -i)
            indent=1 ;;
        *)
            args="$args $names" ;;
    esac
done
case $indent in
    0)
        pr $args | lpr ;;
    *)
        pr $args | indent | lpr ;;
esac
!Funky!Stuff!
echo x - bin/bourne_scripts/repeat
cat >bin/bourne_scripts/repeat <<'!Funky!Stuff!'
case $1 in
    -[0-9]*)
        number=`expr $1 : '-\(.*\)'`
        shift
        while test $number -gt 0
        do
            eval $*
            number=`expr $number - 1`
        done
        exit ;;
    *)
        echo Executing forever: $* 1>&2
        number=0
        trap 'echo Executed $number times.; exit' 2
        while true
        do
            eval $*
            number=`expr $number + 1`
        done ;;
esac
!Funky!Stuff!
echo x - bin/bourne_scripts/restore
cat >bin/bourne_scripts/restore <<'!Funky!Stuff!'
case $# in
    2) ;;
    *)
        exec echo Usage: `basename $0` '<file>' '<version>' ;;
esac
: Truncate filename if necessary
if test `expr $1 : '.*'` -gt 11
then
    savename=`expr $1 : '\(...........\)'`
else
    savename=$1
fi
savename=${savename}_$2
cp $savename $1 && rm $savename && echo $1 restored from $savename
!Funky!Stuff!
echo x - bin/bourne_scripts/save
cat >bin/bourne_scripts/save <<'!Funky!Stuff!'
for file
do
    if test `expr $file : '.*'` -gt 11
    then
        savename=`expr $file : '\(...........\)'`
    else
        savename=$file
    fi
    for copy in ${savename}_??
    do
        latest=$copy
    done
    if test $latest = "${savename}_??"
    then
        latest=${savename}_01
    else
        latest=`expr $latest : '.*_\([0123456789]*\)


 + 1`
        case $latest in
            ?)
                latest=0$latest
                ;;
        esac
        latest=${savename}_$latest
    fi
    cp $file $latest && echo $file saved as $latest
done
!Funky!Stuff!
echo x - bin/csh_scripts
mkdir bin/csh_scripts
echo x - bin/csh_scripts/newsweed
cat >bin/csh_scripts/newsweed <<'!Funky!Stuff!'
#
set TEMP=/tmp/weed$
set NEWSRC=~/.newsrc
set AWKFILE=/usr/ken/cmd/lib/newsweed.awk
onintr
echo Searching for articles in all newsgroups
readnews -l $* | sort -o ${TEMP}a
if (-z ${TEMP}a) then
    echo No news.
else
    cp ${TEMP}a ${TEMP}b
    echo Please remove article titles which you do not wish to read
    sleep 1
    onintr -
    vi ${TEMP}b
    onintr cleanup
    if ( { cmp -s ${TEMP}a ${TEMP}b } ) then
        echo No articles deleted.
    else
        comm -23 ${TEMP}a ${TEMP}b | sed 's/ .*//' > ${TEMP}c
        echo Removing unwanted articles
        cp $NEWSRC $NEWSRC.old
        awk -f $AWKFILE $NEWSRC.old ${TEMP}c > ${TEMP}d
        cp ${TEMP}d $NEWSRC
    endif
endif
cleanup:
rm ${TEMP}?
!Funky!Stuff!
echo x - bin/csh_scripts/pathname
cat >bin/csh_scripts/pathname <<'!Funky!Stuff!'
#
foreach cmddir ($path)
    if ( -e $cmddir/$1 ) echo " $cmddir/$1"
end
!Funky!Stuff!
echo x - bin/local
mkdir bin/local
echo x - bin/local/format
cat >bin/local/format <<'!Funky!Stuff!'
#
if ($#argv == 0) then
    set progname=$0
    set progname=$progname:t
    echo 'Usage:' $progname '[-v] [-n] [-print] [-troffflags] <filename> [ <filename> ... ]'
    exit (1)
endif
set flags
set formatter="vtroff -t"
set eqnsetter=eqn
set docsuf=v
set longdocsuf=vpr
set more=0
foreach name ($argv)
    if ($more > 0) then
        set flags="$flags $name"
        @ more--
        continue
    endif
    switch ($name)
        case -*:
            switch ($name)
                case -print:
                    set print
                    continue
                case -v:
                    set formatter="vtroff -t"
                    set eqnsetter=eqn
                    set docsuf=v
                    set longdocsuf=vpr
                    continue
                case -n:
                    set formatter=nroff
                    set eqnsetter=neqn
                    set docsuf=d
                    set longdocsuf=doc
                    continue
                case -[F123]:
                    set more=1
                default:
                    set flags="$flags $name"
            endsw
            continue
        case *.et:
            set outfile=$name:r.$docsuf
            eval soelim $name | tbl | $eqnsetter | $formatter $flags > $outfile
            breaksw
        case *.t:
            set outfile=$name:r.$docsuf
            eval soelim $name | tbl | $formatter $flags > $outfile
            breaksw
        case *.tbl:
            set outfile=$name:r.$longdocsuf
            eval soelim $name | tbl | $formatter $flags > $outfile
            breaksw
        case *.e:
            set outfile=$name:r.$docsuf
            eval $eqnsetter $name | $formatter $flags > $outfile
            breaksw
        case *.eqn:
            set outfile=$name:r.$longdocsuf
            eval $eqnsetter $name | $formatter $flags > $outfile
            breaksw
        case *.n:
            set outfile=$name:r.$docsuf
            eval $formatter $flags $name > $outfile
            breaksw
        case *.nr:
            set outfile=$name:r.$longdocsuf
            eval $formatter $flags $name > $outfile
            breaksw
        default:
            echo Don\'t know what to do with $name
            continue
    endsw
    if ($?print) then
        if ("$formatter" == nroff) then
            vpr $outfile
        else
            vpr -t $outfile
        endif
    endif
end
!Funky!Stuff!
echo x - bin/local/lntree
cat >bin/local/lntree <<'!Funky!Stuff!'
PATH=/usr/local/bin:/usr/ucb:/bin:/usr/bin
if test $1 = -v
then
    verbose=1
    shift
else
    verbose=0
fi
case $2 in
    /*)
        target=$2 ;;
    *)
        target=`pwd`/$2 ;;
esac
if test -f $2
then
    echo Error: $2 is not a directory
    exit 1
fi
cd $1
source=`pwd`
if test `expr $target : $source/` != 0
then
    echo Error: $2 may be a subdirectory of $1
    echo Try using the full path name of $2 \(no ..\'s\)
    exit 1
fi
if test $verbose = 1
then
    set -x
fi
files=`type -f`
case $files in
    "") ;;
    *)
        ln $files $target ;;
esac
for directory in `find '' -type d -a -print`
do
    mkdir $target$directory
    cd $source$directory
    files=`type -f`
    case $files in
        "") ;;
        *)
            ln $files $target$directory ;;
    esac
done
!Funky!Stuff!
echo x - bin/local/lookdoc
cat >bin/local/lookdoc <<'!Funky!Stuff!'
#
if ($#argv == 0) then
        more
        exit
endif
set macros pipespec args
foreach name ($argv)
    switch ($name)
        case -n:
            set pipespec=n
            breaksw
        case -t:
            set pipespec=t
            breaksw
        case -m*:
            set macros="$macros $name"
            breaksw
        case *.n:
        case *.nr:
            if ($pipespec != t) set pipespec=n
            set args="$args $name"
            breaksw
        case *.t:
        case *.tbl:
            set pipespec=t
            set args="$args $name"
            breaksw
        default:
            set args="$args $name"
    endsw
end

switch ($pipespec)
    case n:
        nroff $macros $args | more
        breaksw
    case t:
        soelim $args | tbl | nroff $macros - | col | more
        breaksw
    default:
        more $name
        breaksw
endsw
!Funky!Stuff!
echo x - bin/local/newsweed
cat >bin/local/newsweed <<'!Funky!Stuff!'
TEMP=/tmp/weed$
NEWSRC=$HOME/.newsrc
AWKFILE=/usr/local/lib/newsweed.awk
trap 'rm ${TEMP}?; exit' 0 2
echo Making list of article titles
readnews -l $* | sort -o ${TEMP}a
if test -s ${TEMP}a
then
    cp ${TEMP}a ${TEMP}b
    echo Please remove article titles which you do not wish to read
    sleep 1
    reset       # So that vi's CRLF doesn't get trashed by another vi
    ${EDITOR-vi} ${TEMP}b
    if cmp -s ${TEMP}a ${TEMP}b
    then
        echo No articles deleted.
    else
        comm -23 ${TEMP}a ${TEMP}b | sed 's/ .*//' > ${TEMP}c
        echo Removing unwanted articles
        cp $NEWSRC $NEWSRC.old
        awk -f $AWKFILE $NEWSRC.old ${TEMP}c > ${TEMP}d
        cp ${TEMP}d $NEWSRC
    fi
else
    echo No news.
fi
!Funky!Stuff!
echo x - bin/local/nmail
cat >bin/local/nmail <<'!Funky!Stuff!'
#/bin/csh
set found = 0
set arg = 1
while($arg <= $#argv)
        if(`echo $argv[$arg] | grep \!` != "") then
                set tuple = `echo $argv[$arg] | sed s/\\!/\ /`
                set upath = `uupath $tuple[1]`
                set found = $status
                set argv[$arg] = "$upath\!$tuple[2]"
        else
                set found = 0
        endif
        if($found != 0) then
                set argv[$arg]
        endif
        @ arg = $arg + 1
end
echo "mail $argv"
mail $argv

!Funky!Stuff!
echo x - bin/local/peopledata
cat >bin/local/peopledata <<'!Funky!Stuff!'
peoplefile=$HOME/.peopledata

echo ' '

case $# in
    0)
        ed - $peoplefile << EOF
g/./s/$/\\
/
g/      /s//\\
/g
1,\$p
q
EOF
    exit ;;
esac

case $1 in
    -)
        chmod 600 $peoplefile
        vi $peoplefile
        chmod 400 $peoplefile
        exit ;;
esac
trap "rm /tmp/data$; exit" 0 2
for name
do
    grep -y "$name" $peoplefile >> /tmp/data$
done
ed - /tmp/data$ << EOF
g/./s/$/\\
/
g/      /s//\\
/g
1,\$p
q
EOF
!Funky!Stuff!
echo x - bin/local/phone
cat >bin/local/phone <<'!Funky!Stuff!'
peoplefile=$HOME/.peopledata

case $# in
    0)
        ed - $peoplefile << EOF
        v/-/d
        g/./s/\([^      ]*\)[^-]*       \(.*-.*\)/\1    \2/
        1,\$p
EOF
        exit ;;
esac

case $1 in
    -)
        chmod 600 $peoplefile
        vi $peoplefile
        chmod 400 $peoplefile
        exit ;;
esac

trap "rm /tmp/data$; exit" 0 2
for name
do
    grep -y "$name" $peoplefile >> /tmp/data$
done
ed - /tmp/data$ << EOF
g/./s/\([^      ]*\)[^-]*       \(.*-.*\)/\1    \2/
1,\$p
q
EOF
!Funky!Stuff!
echo x - bin/local/pk
cat >bin/local/pk <<'!Funky!Stuff!'
for dir
do echo "mkdir $dir";
        for file in `file $dir/* | sed -n '/text$/s/:[^:]*$//p'`
        do      echo "echo x - $file"
                echo "cat >$file <<'#EOF#'"
                cat $file; echo "#EOF#"
        done
        pk `file $dir/* | sed -n '/directory$/s/:.*//p'`
done
!Funky!Stuff!
echo x - bin/local/save
cat >bin/local/save <<'!Funky!Stuff!'
#
if ("$1" =~ -*) then
    set suffix=`expr $1 : '-\(.*\)'`
    shift
    foreach file ($argv)
        if (`expr $file:t : '.*'` >= 11) then
            set savename=`expr $file : '\(.*\)'$file:t`
            set savename=$savename`expr $file:t : '\(...........\)'`
        else
            set savename=$file
        endif
        cp $file ${savename}_$suffix && \
                echo $file saved as ${savename}_$suffix
    end
    exit
endif
foreach file ($argv)
    if (`expr $file:t : '.*'` >= 11) then
        set savename=`expr $file : '\(.*\)'$file:t`
        set savename=$savename`expr $file:t : '\(...........\)'`
    else
        set savename=$file
    endif

    set nonomatch
    set latest=(${savename}_[0-9][0-9])
    if ("$latest" == "${savename}_[0-9][0-9]") then
        set latest=${savename}_01
    else
        set latest=$latest[$#latest]
        set latest=`expr $latest : '.*_\([0123456789]*\)


 + 1`
        if ($latest < 10) set latest=0$latest
        set latest=${savename}_$latest
    endif
    cp $file $latest && echo $file saved as $latest
end
!Funky!Stuff!
echo x - bin/local/shar
cat >bin/local/shar <<'!Funky!Stuff!'
: Roff, nroff, or eqn input text
for file in `file $* | sed -n '/eqn input text$/s/:[^:]*$//p'`
do
    echo "echo x - $file"
    echo "sed 's/^x//' >$file <<'!Funky!Stuff!'"
    sed 's/^/x/' $file; echo "!Funky!Stuff!"
done
: Text files
for file in `file $* | sed -n -e '/eqn input text$/d' -e '/text$/s/:[^:]*$//p'`
do
    echo "echo x - $file"
    echo "cat >$file <<'!Funky!Stuff!'"
    cat $file; echo "!Funky!Stuff!"
done
: Directories, recursively
for dir in `file $* | sed -n '/directory$/s/:.*//p'`
do
    echo "echo x - $dir"
    echo "mkdir $dir"
    file=`echo $dir/*`
    test "$file" != "$dir/*" && $0 $file
done
!Funky!Stuff!
echo x - bin/local/uuhosts
cat >bin/local/uuhosts <<'!Funky!Stuff!'
#!/bin/sh
# '@(#) uuhosts.sh 1.22 84/08/07'

# PATH will have to be adjusted for non-BSD systems.
PATH=/usr/local/bin:/usr/ucb:/bin:/usr/bin
LIB=/usr/lib

# Routing information produced by pathalias.
paths=$LIB/nmail.paths

# The directory $NEWSMAP should contain the USENET news map information
# from newsgroup net.news.map that is posted about once a month from
# cbosgd!map, extracted by a line like this in $LIB/news/sys:
#
#       newsmap:net.news.map:B:/usr/local/uuhosts -x
#
# Locally-known information should go in $LIB/news/net.news.map/Local.
# The directory $MAILMAP is extracted by the same command from the
# UUCP mail information posted to the same newsgroup.
NEWSMAP=$LIB/news/net.news.map
MAILMAP=$LIB/news/net.mail.map
cd $NEWSMAP

case $1 in
        -x)
                # extract a new map piece into the map directory
                temphead=/tmp/maphead.$
                temptext=/tmp/maptext.$
                awk '
BEGIN   {
        temphead = "'$temphead'";
        isnewsmap = 0; ismailmap = 0;
        shead = 0; stext = 1; snews = 2; smail = 3; scat = 4; scatting = 5;
        state = shead;
        print "Reply-To: news" >> temphead;
}
state == shead && /^From: /     {
        print "Original-" $0 >> temphead;
}
state == shead && /^Subject: /  {
        if ($2 != "Re:")
        for (x = 2; x <= NF; x++) {
                if ($x == "UUCPmap" || $x == "uucpmap" || $x == "UUCPMAP") {
                        ismailmap = 1;
                        break;
                }
                if ($x == "map" || $x == "Map" || $x == "MAP") {
                        if (x <= 2)
                                continue;
                        x--;
                        if ($x == "USENET") {
                                isnewsmap = 1;
                                break;
                        }
                        if ($x == "UUCP") {
                                ismailmap = 1;
                                break;
                        }
                        x++;
                }
        }
        if (!isnewsmap && !ismailmap) {
                print "Subject:  not a map update" >> temphead;
                print "Original-" $0 >> temphead;
        } else
                print $0 >> temphead;
}
state == shead && /^$/  {
        if (isnewsmap != 0)
                state = snews;
        else if (ismailmap != 0) {
                state = scat;
        } else
                state = stext;
        next;
}
state == scat   {
        if ($1 != "cat")
                state = scatting;
        else
                state = smail;
}
state == scatting {
        if ($1 == ":")
                state = smail;
        else
                print;
}
state == smail  {
        print | "uuhosts -u";
}
state == snews  {
        print | "/bin/sh";
}
state == stext  {
        print;
}
' > $temptext 2>&1
                cat $temphead $temptext | /bin/mail news
                rm -f $temphead $temptext
                exit 0
        ;;

        -u)
                # extract a UUCP map piece
                cd $MAILMAP
                /bin/sh
                for f in *map*.a *map*.ar
                do
                        ar xv $f
                        rm $f
                done
        ;;

        -g)
                # by geographical region
                shift
                if test $# -eq 0
                then
                        exec ls
                        exit 1
                fi
                exec cat $*
                exit 1
        ;;

        -k)
                # by keyword
                shift
                exec awk '
BEGIN           { inside = 1; outside = 0; state = outside; }
/^Name:/        { state = inside; count = 0; useit = 0; }
state == inside { block[count++] = $0; }
/'"$*"'/        { useit = 1; }
/^$/ && state == inside {
        if (useit == 1) {
                for (i = 0; i < count; i++) {
                        print block[i];
                }
        }
        state = outside;
}
' *
                exit 1
        ;;

        -*)
                # unknown option
        ;;

        "")
                # no arguments
        ;;

        *)
                # by site name
                for arg in $*
                do
                        echo 'UUCP mail path:'
                        grep '^'${arg} $paths
                        echo '
UUCP mail host information:'
                        cat $MAILMAP/${arg}* | tr % '\012'
                        echo '
USENET news host information:'
                        sed -n -e "/^Name:[     ]*${arg}/,/^$/p" *
                done
                exit 0
        ;;
esac

echo 'Usage:    'uuhosts' hostname ...
for information about a particular UUCP or USENET host or hosts, or

        'uuhosts' -g geographical-region
for information about USENET news sites in a geographical region, or

        'uuhosts' -g
for a list of known USENET geographical-regions.
'
exit 1
!Funky!Stuff!

::::::::::::::
shells/4
::::::::::::::
Date: Fri, 14 Sep 84 15:06:07 pdt
From: hplabs!sdcrdcf!sdcsvax!celerity!barto (David Barto)
To: sdcsvax!sdcrdcf!hplabs!resonex!nancy
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

Hi Nancy,
        I too am a 'new' system admin, and belive me, it won't take
        you too long to get quite a bag of tricks put together.

        Most of mine relate to source programs put together in
        shell scripts to keep track of things.

        I have 1 for news (at the end of the article) which keeps
        the active list up to date.

        Another nice program is one I call '#'.  It is owned by root
        and setuid/setgid to root/daemon.  I use it to 'become' root
        while doing 1 command
                        # mv file1 file2
        which requires root permission.  It checks to see the normal
        userid is 'me' and then allows the command.  I will send it
        along if you want it.

        I have shell scripts for doing things such as 'rootedit'
        a file.  This is an alias for "alias re  '# vi -v \!*'"

        I too would love to see the things you get back from the
        net.  As well I have a sendmail config setup for making
        your configuration a breeze.  If you want it I can send
        it under seperate cover.


        barto (david barto)     Tele : (619) 271 9940
        uucp : {decvax || ucbvax || ihnp4}!sdcsvax!celerity!barto
        uucp : akgua!celerity!barto
        arpa : sdcsvax!celerity!barto@NOSC


: This is a shar archive.  Extract with sh, not csh.
echo x - Mkactive
cat > Mkactive << '!Funky!Stuff!'
#!/bin/sh
# see Update.active for this usage
#
sed -e '1,/---/d'\
        -e '1,/---/d'\
        -e 's/^[        ]//'\
        -e 's/  \(.*\)//'\
        active.current | sort | sed -e '1,/Newsgroup/d' > current
sed -e 's/ \(.*\)//' /usr/new/lib/news/active | sort > active
diff active current > /tmp/active.diff
echo "# active newsgroups not in local active file:"
fgrep ">" /tmp/active.diff
echo "# defunct newsgroups still in active file (also local groups):"
fgrep "<" /tmp/active.diff
/bin/rm current active /tmp/active.diff
!Funky!Stuff!
echo x - Mkdead
cat > Mkdead << '!Funky!Stuff!'
#!/bin/sh
# see Update.active for usage
# change all groups that we have (but shouldn't) to be removed,
# and change all groups that we dont have (but sould) to be a comment
sed     -e '/general/d'\
        -e '/control/d' \
        -e '/junk/d' \
        -e 's/</rmgroup/' \
        -e 's/>/#/'
!Funky!Stuff!
echo x - rmgroup
cat > rmgroup << '!Funky!Stuff!'
#! /bin/sh
# from : sdcsvax!sdcrdcf!hplabs!hao!seismo!rlgvax!cvl!umcp-cs!eneevax!chris
#
# @(#)rmgroup.sh        (U of Maryland) FLB 28-Jun-1983
#                       Bug fixes 5 June 1984 Chris Torek
#
# Delete a newsgroup

lib=/usr/new/lib/news
spool=/usr/spool/news

group=$*

for group
do
        qgrp="`echo $group | sed 's/\./\\\./g'`"
        if
                grep -s "^$qgrp [0-9][0-9][0-9][0-9][0-9]$" $lib/active
        then
                ed - $lib/active << xxxFOOxxx
/^$qgrp [0-9][0-9][0-9][0-9][0-9]$/d
w
q
xxxFOOxxx
        else
                echo "$0: $group: no such active line" 2>&1
        fi

        dir=$spool/"`echo $group | sed 's/\./\//g'`"
        if
                [ -d "$dir" ]
        then
                /bin/rm -fr "$dir"
        else
                echo "$0: $dir: no spool directory" 2>&1
        fi
done
exit 0
!Funky!Stuff!

::::::::::::::
shells/5
::::::::::::::
Date: Thu, 20 Sep 84 01:20:29 pdt
From: turtlevax!ken (Ken Turkowski)
To: resonex!nancy
Subject: Handy new uucp utility: uuque

cat << EOF
I just completed a new useful uucp utility which lets you know what kind
of uucp work is in progress.  While uusnap just tells you the number of
files to be processed, uuque tells you exactly what kind of work is to
be performed.  I've only tried it on three kinds of work, namely mail,
news, and standard uucp transfers.  Give it a try, and see if it breaks
on any new types of uucp work.
                                Ken
P.S. This really should be a C program.
EOF
echo x - uuque
cat >uuque <<'!Funky!Stuff!'
#! /bin/sh
# uusnap
cd /usr/spool/uucp
LUUNAME=`uuname -l`

# Check for outgoing work
for cmdfile in C./*
do
    test -f $cmdfile || continue
    othersys=`expr $cmdfile : 'C./C.\(.*\).....'`
    cmd=
    dfile=
    xfile=
    ufile=
    cat $cmdfile | {
        while read cmd arg1 arg2 arg3 extra
        do
            case $cmd in
                S) ;;
                *)  echo Bad cmd in $cmdfile: $cmd $arg1 $arg2 $arg3 $extra
                    exit ;;
            esac
            case $arg1 in
                D.${LUUNAME}X????)      # Remote execute file
                    xfile=$arg1
                    ;;
                D.${LUUNAME}?????)      # Data file ref'd by the execute file
                    dfile=$arg1
                    ;;
                *)                      # Just a uucp
                    dfile=$arg1
                    ufile=$arg2
                    from=$arg3
                    ;;
            esac
        done
        case $xfile in
            "")                 # uucp transfer
                echo `wc -c < $dfile`\   uucp $dfile $othersys!$ufile \($from\)
                ;;
            *)                  # complex transfer
                cat D.${LUUNAME}X/$xfile | {
                    while read xcmd arg1 arg2 extra
                    do
                        case $xcmd in
                            U)
                                from=$arg2!$arg1
                                ;;
                            F)
                                ;;
                            I)
                                ;;
                            C)
                                echo `wc -c < D.${LUUNAME}/$dfile`\      $arg1 $othersys!$arg2 \($from\)
                                ;;
                            *)
                                echo Unknown xcmd in $xfile: $xcmd $arg1 $arg2
                                exit
                                ;;
                        esac
                    done
                }
                ;;
        esac
    }
done

# Check for incoming work
for cmdfile in X./*
do
    test -f $cmdfile || continue
    othersys=`expr $cmdfile : 'X./X.\(.*\).....'`
    cat $cmdfile | {
        while read cmd arg1 arg2 extra
        do
            case $cmd in
                U)
                    from=$arg2!$arg1
                    ;;
                Z)
                    ;;
                F)
                    if test -f D./$arg1
                    then
                        dfile=D./$arg1
                    elif test -f D./$arg2
                    then
                        dfile=D./$arg2
                    else
                        continue 2
                    fi
                    ;;
                C)
                    xcmd=$arg1
                    ;;
                *)  echo Bad cmd in $cmdfile: $cmd $arg1 $arg2 $extra
                    exit ;;
            esac
        done
        echo `wc -c < $dfile`\   $xcmd $dfile \($from\)
    }
done
!Funky!Stuff!

::::::::::::::
shells/6
::::::::::::::
Date: Sat, 22 Sep 84 01:22:39 pdt
From: turtlevax!ken (Ken Turkowski)
To: resonex!nancy
Subject: Re:  uuque

I've updated uuque to the point where it should probably instead be called
uusnoop.  Of course, it's not that interesting unless there are others on
your system that use uucp and net mail.

                        Ken

echo x - uuque
cat >uuque <<'!Funky!Stuff!'
#! /bin/sh
# The user must have access to the /usr/spool/uucp/* directories and files.
# This can be easily done by making certain users members of the daemon
# and/or uucp groups, or by becoming super-user.
# uusnap
cd /usr/spool/uucp
LUUNAME=`uuname -l`

# Check for outgoing work
for cmdfile in C./*
do
    test -f $cmdfile || continue
    othersys=`expr $cmdfile : 'C./C.\(.*\).....'`
    cmd=
    dfile=
    xfile=
    ufile=
    cat $cmdfile | {
        while read cmd arg1 arg2 arg3 extra
        do
            case $cmd in
                S)                              # uucp send
                    case $arg1 in
                        D.${LUUNAME}X????)      # Remote execute file
                            xfile=$arg1
                            ;;
                        D.${LUUNAME}?????)      # Data file ref'd by xfile
                            dfile=D.${LUUNAME}/$arg1
                            ;;
                        *)              # Just a uucp -- no intertpretation
                            echo `wc -c < $arg1`\        uucp $arg1 $othersys!$arg2 \($arg3\)
                            ;;
                    esac
                    ;;
                R)              # uucp receive
                    echo '      ' uucp $othersys!$arg1 $arg2 \($arg3\)
                    ;;
                *)  echo Bad cmd in $cmdfile: $cmd $arg1 $arg2 $arg3 $extra
                    continue ;;
            esac
        done
        case $xfile in
            "")                 # uucp transfer
                continue
                ;;
        esac
        cat D.${LUUNAME}X/$xfile | {    # complex transfer -- interpret xfile
            while read xcmd arg1 arg2 extra
            do
                case $xcmd in
                    U)
                        from=$arg2!$arg1
                        ;;
                    F)
                        ;;
                    I)
                        ;;
                    Z)
                        ;;
                    C)
                        case $arg1 in
                            rmail)
                                from=`head -1 $dfile | ( read arg1 arg2 extra; echo $arg2 )`
                                echo `wc -c < $dfile`\   $arg1 $othersys!$arg2 \($from\)
                                echo -n '        '
                                grep '^Subject:' $dfile || echo ''
                                ;;
                            rnews)
                                echo `wc -c < $dfile`\   $arg1 $othersys  \($from\)
                                echo -n '        '
                                grep '^Newsgroups:' $dfile
                                echo -n '        '
                                grep '^Subject:' $dfile
                                ;;
                            *)
                                echo `wc -c < $dfile`\   $arg1 $arg2 $extra [$othersys $dfile] \($from\)
                                ;;
                        esac
                        ;;
                    *)
                        echo Unknown xcmd in $xfile: $xcmd $arg1 $arg2
                        exit
                        ;;
                esac
            done
        }
    }
done

# Check for incoming work
for cmdfile in X./*
do
    test -f $cmdfile || continue
    othersys=`expr $cmdfile : 'X./X.\(.*\).....'`
    comment=
    cat $cmdfile | {
        while read cmd arg1 arg2 extra
        do
            case $cmd in
                U)
                    from=$arg2!$arg1
                    ;;
                Z)
                    ;;
                I)
                    ;;
                F)
                    if test -f D./$arg1
                    then
                        dfile=D./$arg1
                    elif test -f XTMP/$arg2
                    then
                        dfile=XTMP/$arg2
                        comment="(EXECUTING)"
                    else
                        continue 2
                    fi
                    ;;
                C)
                    xcmd=$arg1
                    xargs="$arg2 $extra"
                    case $arg1 in
                        rmail)
                            from=$othersys!`head -1 $dfile | ( read arg1 arg2 extra; echo $arg2 )`
                            echo -n '    '
                            grep '^Subject:' $dfile || echo ''
                            ;;
                    esac
                    ;;
                *)  echo Bad cmd in $cmdfile: $cmd $arg1 $arg2 $extra
                    continue ;;
            esac
        done
        echo `wc -c < $dfile`\   $xcmd $xargs $comment \($from\)
    }
done
!Funky!Stuff!



From: Nancy Blachman <decvax!decwrl!sun!idi!resonex!nancy@Ucb-Vax.ARPA>
To: net.unix, net.unix-wizards, net.sources
Subject: Actual tricks, shells, csh aliases and the like, 3 of 3
Date: 16 Oct 84 21:24:32 GMT
Organization: Resonex Inc., Sunnyvale, CA

> [Know anybody with a GREAT .login or .cshrc?]

> I'm interested in collecting the little tricks, shell scripts, awk
> hacks, csh aliases, and such that people have built to make their daily
> life a little easier or more automatic.  Being a fairly new system
> administrator I don't have the big toolbox that years of messing around
> will leave you with.  If you have any hacks you're proud of (or that
> you aren't proud of, but which work anyway), and you're willing to make
> them public, mail them to me.  I'll collect, collate, shuffle, sort,
> munge, judge, select and discard them and then "summarize to the net".

This article centers on C programs and awk scripts I received in response to
my solicitation.  The first article concentrates on  aliases, and .cshrc and
.login files.  The second article in this series focuses shell scripts.

/\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\/
> Nancy Blachman {allegra,hplabs,ihnp4,sun}!resonex!nancy  (408)720 8600 x37 <
/\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\//\/

::::::::::::::
programs/1
::::::::::::::
Date: Sat, 15 Sep 84 02:45:08 pdt
From: <hplabs!intelca!t4test!chip>
To: intelca!hplabs!resonex!nancy
Subject: Re: Tricks, shell and awk scripts, csh aliases and the like

One thing I've put together is a bunch of scripts which give you a
status line on a DEC type terminal.  The thing is hardwired into VTxxx
type stuff rather than termcap for two reasons.  First, the cursor
save/restore function isn't part of termcap.  Secondly, the set
scrolling region is part of termcap, but it is for VT100 type
terminals.  Since we only have DEC terminals, it doesn't hurt us too
much.

Some history:  I used to like to display my current working directory
on my prompt line.  Later I wanted my terminal line there too.  (That
was in case a terminal I was on locked up, I could quickly tell what
terminal to kill.)  Later, when I had four accounts on the machine I
thought it would be nice to display my login name in my prompt.  The
straw which broke the camel's back was that we bought another VAX, and
I wanted to be able to see which machine I was logged on.  As you might
imagine, my prompt now extended about 60 columns across the screen.  My
answer was to take everything out of my prompt except the history
number and stick it at a status line at the bottom of my screen.

Below is a shar archive of the status line files.  You do a `source
stat.init' to get stuff initialized.  Then `son' and `soff' (which are
aliased to source the two other scripts) turn the status line on and
off.  These also define a bunch of aliases which help you work with
programs which don't like the status line.  So, I put a `source
/usr/public/stat.init' followed by a `son' in my `.login'.  (I don't
turn it on with my `.cshrc', my shell escapes would then get awfully
sloooooow.)

Also, you would need to add `vt100s' and `vt131s' to /etc/termcap.
This is to keep screen stuff (e.g. more, vi, etc.) happy if you run
them with the status line on.  This is what I use:

    ################      VT131 with 24th line reserved
    ################ d13s|vt131s|VT131S|vt-131s|pt131s|pt-131s|dec
    vt131s:\
            :li#23:tc=vt131

You will definately want to change the terminal identification stuff in
`stat.init'.  We run Eunice, so I use the `grep' to convert the Unix
style terminal line identification to a VMS terminal port.

You can redefine `statin' in the `stat.init' script to put whatever you
want on the status line.

Well...after all this, I hope you use VT1xx/VT2xx terminals.
Otherwise, this won't be real exciting.  (Unless you want to rewrite
`statterm.c')

---

Chip Rosenthal, Intel/Santa Clara
{ idi|intelca|icalqa|kremvax|qubix|ucscc } ! t4test ! { chip|news }

-----  cut here  -----------------------------------------------------------

: This is a shar archive.  Extract with sh, not csh.
: This archive contains the following files
:  Makefile stat.init stat.on stat.off statterm.c
: Total number of files: 5
echo x - Makefile [file 1 of 5]
sed 's/^|//' > Makefile << '!-FUNKY-STUFF-!'
|BIN=   /usr/public
|OBJS=  statterm
|
|IOBJS= $(BIN)/statterm \
|       $(BIN)/stat.init \
|       $(BIN)/stat.on \
|       $(BIN)/stat.off
|
|SOURCES=Makefile \
|       stat.init \
|       stat.on \
|       stat.off \
|       statterm.c
|
|all:           $(OBJS)
|install:       $(IOBJS)
|shar:          stat.shar
|
|statterm:              statterm.c
|                       cc -O statterm.c -o statterm
|
|$(BIN)/statterm:       statterm
|                       cp $? $@
|                       chmod 755 $@
|
|$(BIN)/stat.init:      stat.init
|                       cp $? $@
|                       chmod 755 $@
|
|$(BIN)/stat.on:                stat.on
|                       cp $? $@
|                       chmod 755 $@
|
|$(BIN)/stat.off:       stat.off
|                       cp $? $@
|                       chmod 755 $@
|
|stat.shar:             $(SOURCES)
|                       shar $(SOURCES) > $@
|
|
!-FUNKY-STUFF-!
echo x - stat.init [file 2 of 5]
sed 's/^|//' > stat.init << '!-FUNKY-STUFF-!'
|alias a 'alias'
|
|# run statterm to verify terminal can do status line
|statterm
|if $status then
|    # status line not available on this terminal -- see if a
|    # baseterm is defined.  if so, then maybe $TERM is just
|    # messed up from earlier invocation of stat.init.
|    if $?baseterm then
|       # baseterm has been defined -- see if it will work
|       set temp=$TERM
|       setenv TERM $baseterm
|       statterm
|       if $status then
|           # nope -- baseterm will not work either
|           setenv TERM $temp
|           unset temp
|           goto failed
|       else
|           # yes -- baseterm will work
|           echo "changing terminal type from $temp to $TERM"
|           unset temp
|       endif
|    else
|       # no baseterm defined
|       goto failed
|    endif
|endif
|
|# status line will work with this terminal
|set baseterm=$TERM
|set ignoreeof
|
|# find user's system (ick)
|set system=`tr '[A-Z]' '[a-z]' < /usr/include/whoami`
|
|# find user's tty (ick ick ick)
|set temp=`tty`'



|set tty=`grep "$temp" /etc/dev.com | sed -e 's/^.*_\(.*\):.*/\1/'`
|unset temp
|
|# setup terminal strings
|set statin="`statterm in '${system}\\!${user}' '(${tty})'`"
|set statout="`statterm out`"
|set statoff="`statterm off`"
|echo -n "$statoff"
|
|# setup status commands
|#   son - turn on status mode
|#   soff - turn off status mode
|#   stat - draw status line
|#   nostat - erase status line
|#   termstat - setenv the terminal with status line protected
|#   termnorm - setenv the terminal without a status line
|#   ns - execute a command without a status line
|a son          'source /usr/public/stat.on'
|a soff         'source /usr/public/stat.off'
|a stat         ';'
|a nostat       ';'
|a termstat     ';'
|a termnorm     ';'
|a ns           'nostat ; termnorm ; \!* ; termstat ; stat ; echo ""'
|
|# alias the commands which maintain the status line
|a cd           'chdir \!* ; stat'
|a popd         'popd ; stat'
|a pushd                'pushd \!* ; stat'
|
|# alias the commands which (might) munch the status line
|a clear                'clear \!* ; stat'
|a mail         'mail \!* ; stat'
|a more         'more \!* ; stat'
|
|# alias the commands which should be done with the status line off
|a lo           'ns logout \!*'
|a LO           'ns logout \!*'
|a rn           'ns /local/bin/rn \!*'
|a pn           'ns /local/bin/pn \!*'
|a reply                'ns /local/bin/reply \!*'
|a sus          'ns suspend \!*'
|a vi           'ns /usr/ucb/vi \!*'
|a view         'ns /usr/ucb/view \!*'
|
|# that is all folks.  the status stuff is initialized
|# now all you need is a 'son' to turn it on
|exit 0
|
|failed:
|set baseterm=$TERM
|set temp="status line is not available for terminal type $TERM"
|echo $temp
|set statin=";"
|set statout=";"
|if     $?statoff == 0 then
|    set statoff=";"
|endif
|alias son echo "$temp"
|alias off 'source /usr/public/stat.off'
|unset temp
|soff
|exit 1
|
!-FUNKY-STUFF-!
echo x - stat.on [file 3 of 5]
sed 's/^|//' > stat.on << '!-FUNKY-STUFF-!'
|a stat         'echo -n "${statin}${cwd}${statout}"'
|a nostat       'echo -n "$statoff"'
|a termstat     'setenv TERM ${baseterm}s'
|a termnorm     'setenv TERM $baseterm'
|termstat
|stat
|echo ""
|set statmode
!-FUNKY-STUFF-!
echo x - stat.off [file 4 of 5]
sed 's/^|//' > stat.off << '!-FUNKY-STUFF-!'
|setenv TERM $baseterm
|echo -n "$statoff"
|unset statmode
|a termstat     ';'
|a termnorm     ';'
|a stat ';'
|a nostat ';'
!-FUNKY-STUFF-!
echo x - statterm.c [file 5 of 5]
sed 's/^|//' > statterm.c << '!-FUNKY-STUFF-!'
|/*
| * FILE:       statterm
| * VERSION:    V0.01 [preliminary]
| * DATE:       Mon Aug 27 16:43:13 PDT 1984
| * AUTHOR:      Chip Rosenthal/Intel Corporation
| * ADDRESS:    t4test!chip
| * PACKAGE:     'stat' terminal status line package
| * DESCRIPTION:        produces terminal escape sequences to implement status line
| * COMPILATION: cc -C statterm.c -o statterm
| *
| * REVISION NOTES:
| *
| * V1.00  Original program.
| *
| *
| * USAGE:
| *
| *    statterm
| *        Verifies that the status line will work with current terminal.
| *        Returns a zero exit status if it will, nonzero if it won't.
| *
| *    statterm in [arg ...]
| *        Creates a string which opens up the status line.  Any
| *        arguments are placed at the beginning of the status
| *        line, and the cursor is left there.
| *
| *    statterm out
| *        Create string which closes the status line and returns
| *        cursor to position it was in prior to the last execution
| *        of a 'statterm in' string.
| *
| *    statterm off
| *        Creates a string which removes the status line.
| *
| *
| *    EXAMPLE:
| *        # this is a cshell script
| *        statterm
| *        if $status then
| *            echo "status line will not work on this terminal"
| *            exit
| *        endif
| *        echo -n `statterm in $user`
| *        echo -n `pwd`
| *        echo `statterm out`
| *
| *
| * BUGS:
| *
| *    This program is hardwired into the DEC VT100 terminal escape sequences.
| *    This is done because (unfortunately) 'termcap' doesn't offer a cursor
| *    position save/restore feature.
| *
| */
|
|#include <stdio.h>
|#define strmatch(A,B) (strcmp((A),(B))==0)
|
|/*
| * VT100 Terminal Escape Definitions -- all parameters are strings
| */
|#define ESC          putchar(27);              /* escape character          */
|#define CSI          ESC;putchar('[');         /* command string            */
|#define DECSC        ESC;putchar('7');         /* save cursor position      */
|#define DECRC        ESC;putchar('8');         /* restore cursor position   */
|#define CUP(L,C)      CSI;printf("%s;%sH",L,C); /* set cursor to line/col    */
|#define CUU1         CSI;printf("1A");        /* cursor up one line        */
|#define CUD1         CSI;printf("1B");        /* cursor down one line      */
|#define EL(MODE)      CSI;printf("%sK",MODE);   /* erase line                */
|#define ED(MODE)      CSI;printf("%sJ",MODE);   /* erase display             */
|#define DECSETBM(T,B) CSI;printf("%s;%sr",T,B); /* top/bot of scroll area    */
|/*
| * erasing modes:
| *   mode "0" - from cursor to end
| *   mode "1" - from beginning to cursor
| *   mode "2" - entire
| */
|
|
|main(argc,argv)
|int argc;
|char *argv[];
|{
|    char *term, *getenv();
|    int i;
|
|    if ( argc == 1 ) {
|       term=getenv("TERM");
|       if ( term == NULL )
|           exit(1);
|       if ( strmatch(term,"vt100") || strmatch(term,"vt131") )
|           exit(0);
|       else
|           exit(1);
|    }
|
|    if ( strmatch(argv[1],"in") ) {
|       /*
|        * Save cursor position, go to line 24, print out the arguments, and
|        * erase the rest of the status line.  Cursor remains in status line.
|        */
|       DECSC;
|       CUP("24","1");
|       for ( i=2 ; i<argc ; ++i )
|           printf("%s  ",argv[i]);
|       EL("0");
|    } else if ( strmatch(argv[1],"out") ) {
|       /*
|        * Protect status line from scrolling and restore cursor to location
|        * prior to the last 'in' call.  Move the cursor up and down one line.
|        * This will keep it out of the status line area if it was there when
|        * 'in' was called.
|        */
|       DECSETBM("1","23");
|       DECRC;
|       CUU1;
|       CUD1;
|    } else if ( strmatch(argv[1],"off") ) {
|       /*
|        * Save the current cursor position, unprotect the status line, erase
|        * the status line, and restore the cursor position.
|        */
|       DECSC;
|       DECSETBM("1","24");
|       CUP("24","1");
|       EL("2");
|       DECRC;
|    } else
|       exit(1);
|
|}
!-FUNKY-STUFF-!
exit



::::::::::::::
programs/2
::::::::::::::
From: ihnp4!mcnc!malloy@ittral
Date: Thu, 13 Sep 84 21:35:18 edt
To: ihnp4!resonex!nancy@mcnc
Subject: Tricks

Well it depends upon what you mean. The big problem with having lots of aliases
and such is they start taking up large amounts of memory.  Take it from someone
who knows.  But here's a few things.  Some you no doubt already have, and most
are trivial, but it's better to be complete then to leave anything out.  You
can always just delete this.    == William P. Malloy (ittral!malloy}
---------------------------------------------------------------------
In a .cshrc, a warning and a work around.  Apparently not known by most people
but obvious to people have who been around.  Our users keep bumping into it
about once a year like clock work.
# reason for setting variables only if a prompt already exists
# If it sets prompt in a non-interactive shell, for instance vi(1)
# firing up a sub-shell to expand shell meta-characters, the set prompt
# will stomp on alot of shell variables used for the expansion (like ~)
#
if ( $?prompt ) then
   set mail=/usr/spool/mail/malloy
   set prompt=\`
   set histchars=",;"
endif
Note the setting of histchars.  A little known, but for me much loved feature
of csh is the ability to change the history characters "!^" from their default
values.  The pair `,;' are easier to reach, don't require shifting, and don't
appear in mail paths.  Typing `mail mcnc\!ihnp4\!resonex\!nancy' gets to be
a pain every time you want to mail someone.

alias , 'redo \,* ~/.cmd ~/.cmd1 ; source ~/.cmd1 '

This little alias allows you to have command editing in the csh.  It's quite
useful, particularly when you've got a LONG painful command line.  The , is
just the history character and is ! for most people.  The command redo is a
simple C program.
--------------- redo.c  -------------------
#include <stdio.h>

/* redo -- outputs a command file (last arg )used to edit and
   re-ex a command.  Next to last arg is dest file of the command.

   NOTE: if you use a non-standard history character, i.e. not !
   then you must `setenv HISTCHARS $histchars' in your .login
   If you do not `set histchars=",;"' for instance then it will
   automagically default to !    -- 12/2/83 wpm

   First arg is the history ref . To use:
    alias , 'redo \,* ~/cmd ~/cmd1 ; source ~/cmd1 '
    , 25    to edit & re-execute ,25
    , , or ,  to edit & re-execute ,,
    , v     to edit & re-execute ,v ,etc.



main(argc, argv)
   int argc;
   char *argv[];
{
   FILE *fp;
   char *t, *getenv();

   fp = fopen(argv[argc-1], "w");
   if ((t = getenv("HISTCHARS")) != NULL)
      t[1] = '\0';
   else
      t = "!";
   fprintf(fp, "echo \"%s", t);
   if ( (argc < 4) || (strcmp(argv[1], t) == 0) )
      fputs("-2", fp);
   else
      fputs(argv[1], fp);
   fputs(":q\" >! ", fp);
   fputs(argv[argc-2], fp);
   putc('\n', fp);
   fputs("ex +open ", fp);
   fputs(argv[argc-2], fp);
   putc('\n', fp);
   fputs("/usr/local/typein2 < ", fp);
   fputs(argv[argc-2], fp);
   putc('\n', fp);
   fclose(fp);
   exit(0);
}
------------------ (end of redo.c, begining of typein2.c) --------------------
#include <stdio.h>
#include <sgtty.h>

main(argc, argv)
        int argc;
        char **argv;
{
        register char *cp;
        struct sgttyb stb, stb2;
        int pendin = LPENDIN;
        int c,i,j;
        char buff[2];
        char buff2[256];

        i=0;
        while ((c=getchar()) != EOF) {
                        buff2[i++]=c;
        }
        ioctl(2, TIOCGETP, &stb);
        stb2 = stb;
        stb.sg_flags &= ~ECHO;
        ioctl(2, TIOCSETN, &stb);
        for (j=0; j<i; j++) {
                        ioctl(2, TIOCSTI, &buff2[j]);
                        putchar(buff2[j]);
        }
        ioctl(2, TIOCSETN, &stb2);
        ioctl(2, TIOCLBIS, &pendin);
        exit(0);
}
---------------------------- (end of typein2.c) ------------------------
A couple of oldies but still the simplest.  cd and back aliases.
alias back 'set back=$old; set old=$cwd; cd $back; unset back; dirs'
alias cd 'set old=$cwd; chdir \,*; set prompt = "< $cwd:t > "'

# this is a useful feature for vi
setenv EXINIT 'map #1 Gi/\<A\>"add@a|map #2 1G\!Gvispell|set ai sw=3'

You f2 key will run a file through the spell program, and put the words it
doesn't find in the dictionary at the bottom of the file.  Then typing f1 will
cause it to delete the last line in the file, and search for the string in
the rest of the file.
------------------------------ (source for vispell) -------------
#! /bin/sh
#
tee /tmp/vis$
echo SpellingList
spell /tmp/vis$
rm /tmp/vis$
------------------------------- (end of vispell) ------------------
Stuff from our /.cshrc file.  psa lets you see what's going on in the system
and what people are doing.  Useful to see if people are hanging themselves.
alias psa 'ps axu | sed "/getty/d" | sort -f | more'

A simple alias to compile C programs (C adm.c expands to cc adm.c -o adm).
alias C 'cc \,:* -o \,^:r'

Useful to see what's going on in the system without those !@#$% bells.
alias moremsgs "tr -d '\07' </usr/adm/messages | more"

Like fg.
alias pj '%-'

A feature we use in our root .cshrc allowing indivual superusers to get their
own enviornment.  Useful if people want their own enviornment anywhere people
share an account.
if ( $user == "malloy" ) then
   source /t/malloy/.root
endif

--------------- (here's some things I picked up off the net) --------------
From: ittvax!decvax!harpo!utah-cs!seismo!hao!denelcor!udenva!koala!aburt
Date: Fri Aug 10 09:19:37 1984
Subject: Perversions of source -h and other csh aliases
Newsgroups: net.unix,net.unix-wizards,net.sources

For your enjoyment, here are some interesting lunch hour csh aliases that
I've created.
{this is to slow, my version is a little faster}
My personal favorite is the "history editor" -- allows you to edit
you csh history.  The alias:

        alias hed history -h !* > $hed; vi + $hed; source -h $hed

will allow you to invoke 'vi' on your current history.  (If, for
instance, you typed in a long, tedious line and put in an extra space,
among other things.  The ^...^...  mechanism to remove it can be quite
tedious; 'hed's is easy.)  Before anyone starts flaming that vi is too
slow, history can do it (even if it's tough to type and you're prone to
more typos doing the history), etc. -- if you don't like it, don't use it.

Hed works particularly well if you move the command in question to the
end of the file; then '!!' will execute it after you ZZ from vi.  The
only drawback to this is that it trashes your current event numbers
(they get incremented during the source -h).  By using 'hed 10' you
only edit the last 10 entries in your history.  A temp file, which I
keep in $hed (set to /tmp/hed.$ from my .login), is used each time for
the history.  Obvious changes to this are to use /tmp/hed.$ straight
out and add "rm /tmp/hed.$" to the end of the list.  If you don't like
waiting for the rm, and your /tmp doesn't get cleared out periodically,
put a # in front of the name to make it a disposable file.

This may be slower than the vi/emacs mode in the ksh I keep hearing about, but
it does give the functionality.

A slight modification to 'hed'...

        alias hedf history -h !-0:1 > !-0:2; vi + !-0:2; source -h !-0:2

allows you to specify a file to place the history into instead of a temp
file.

Another modification yields:

        alias heh echo \!* > $hed; vi + $hed; source -h $hed

Which lets you edit then add to your history a specific history sequence.
'Heh' for History edit history.

By inserting a 'source \!-0:2' before the source -h in any of the
above has the effect of executing the commands AND placing them on the
history list (from which we may conclude that 'alias so source \!* ;
source -h \!*' is a useful item: it sources a file then places each line
into your history).

On rare occasions you'll have to put extra quotes/escapes around things
when editing the temp file so it gets sourced right.  Particularly around
aliases with raw history substitutions in them (the \!* type of thing).
The easiest is to try it first; if it fails, edit it again.  After all,
two 'hed's are better than one...

Regarding the use of !-0:1 instead of !:1 for the first argument to the
current command -- At least one csh is known to accept the former but not
the latter.  (The same csh dumps core (therefore logging you out) on receipt
of the !# history selector.  This is version 1.0 of 4.2BSD csh on a Sun-2.
The 1.1 csh exhibits this behavior:

        echo a !#
        a echo a echo

adding an extra arg 0 to the end.  Is this common to other cshs out there?)

So, for those whose csh's allow !:1, use that where I have !-0:1, etc.

Another interesting perversion is an alias'd whereis:

        alias wheres ls -l \{'`echo $path | sed "s/ /,/g"`'\}/'`echo \!-0:1 | sed "s/^./[&]/"`'

It does an ls -l on every file (passed as arg 1) in any directory on
your current path.  (No aliases, though adding an if at the front
should do the trick.)  The idea is to turn your $path list into a comma
separates list, stick that between {}, and append / and arg 1 to that.
Alas, if the file doesn't exist in one of the directories, you get
errors from ls saying it doesn't exist in a given directory.  So, arg 1
is turned into a pattern, which is allowed to fail; the pattern is,
e.g., foo --> [f]oo.  So the second arg to ls only expands to the
existing files.
---------------------------- (end of net article) ------------------------
--
Address: William P. Malloy, ITT Telecom, B & CC Engineering Group, Raleigh NC
         {ihnp4!mcnc, burl, ncsu, decvax!ittvax}!ittral!malloy


::::::::::::::
awk/1
::::::::::::::
Date:       Wed, 19 Sep 84 11:44:38 CST
From: David Chase <hplabs!ucbvax!rbbb@rice.ARPA>
Subject:    Re: Tricks, shell and awk scripts, csh aliases and the like
To: resonex!nancy@BERKELEY

Here is my favorite awk script.  It turns a list of csrc's from memory
errors on an 11/780 (with MS780C controller) into board and chip position
for certain Mostek memory boards.  This script saved me many headaches,
because the tables in the appendix of the technical manual were hard to read
and contained errors (errors that were noticed as deviations from a pattern
when entering this script).

#
# Incredible sleazy awk file to attack memory errors
# Included here is the local configuration, because some decoding
# is board specific
#
BEGIN   {
# Boards understood by this program

#       mk4118 = mostek mk8016 fully populated with mk4116 chips (512k)
        known["mk4118"] = 1

#       mk4116 = mostek mk8016 half populated with mk4116 chips (256k)
        known["mk4116"] = 1

#       mk8016 = mostek mk8016 fully populated with mk4108 chips (256k)
        known["mk4108"] = 1

#       m8210 = DEC 256k board; don't know how to decode this guy (256k)
        known["m8210"] = 0

# To add different boards, (i.e., not conforming to this system)
# append to the "pos" map, and make "keys[<array><bank><new board>]"
# reference the appended chip addresses.

# Local configuration
# boards is indexed by slot number
        boards["0"] = "m8210"
        boards["1"] = "m8210"
        boards["2"] = "m8210"
        boards["3"] = "m8210"
        boards["4"] = "m8210"
        boards["5"] = "m8210"
        boards["6"] = "mk4116"
        boards["7"] = "mk4116"
        boards["8"] = "mk4116"
        boards["9"] = "mk4116"
        boards["a"] = "mk4116"
        boards["b"] = "mk4116"
        boards["c"] = "mk4118"
        boards["d"] = "mk4118"
        boards["e"] = "mk4118"
        boards["f"] = "mk4118"

#       bit in error for a given CRC calculation
#       bits are identified by "u" (upper), "l" (lower), and "c" (check)
#       folowed by the bit number.

        bit["01"] = "c0"
        bit["02"] = "c1"
        bit["04"] = "c2"
        bit["08"] = "c3"
        bit["10"] = "c4"
        bit["19"] = "l01"
        bit["1a"] = "l02"
        bit["1c"] = "l04"
        bit["1f"] = "l07"
        bit["20"] = "c5"
        bit["38"] = "l00"
        bit["3b"] = "l03"
        bit["3d"] = "l05"
        bit["3e"] = "l06"
        bit["40"] = "c6"
        bit["49"] = "l09"
        bit["4a"] = "l10"
        bit["4c"] = "l12"
        bit["4f"] = "l15"
        bit["51"] = "l17"
        bit["52"] = "l18"
        bit["54"] = "l20"
        bit["57"] = "l23"
        bit["58"] = "l24"
        bit["5b"] = "l27"
        bit["5d"] = "l29"
        bit["5e"] = "l30"
        bit["68"] = "l08"
        bit["6b"] = "l11"
        bit["6d"] = "l13"
        bit["6e"] = "l14"
        bit["70"] = "l16"
        bit["73"] = "l19"
        bit["75"] = "l21"
        bit["76"] = "l22"
        bit["79"] = "l25"
        bit["7a"] = "l26"
        bit["7c"] = "l28"
        bit["7e"] = "l31"
        bit["80"] = "c7"
        bit["89"] = "u01"
        bit["8a"] = "u02"
        bit["8c"] = "u04"
        bit["8f"] = "u07"
        bit["91"] = "u09"
        bit["92"] = "u10"
        bit["94"] = "u12"
        bit["97"] = "u15"
        bit["98"] = "u16"
        bit["9b"] = "u19"
        bit["9d"] = "u21"
        bit["9e"] = "u22"
        bit["a8"] = "u00"
        bit["ab"] = "u03"
        bit["ad"] = "u05"
        bit["ae"] = "u06"
        bit["b0"] = "u08"
        bit["b3"] = "u11"
        bit["b5"] = "u13"
        bit["b6"] = "u14"
        bit["b9"] = "u17"
        bit["ba"] = "u18"
        bit["bc"] = "u20"
        bit["bf"] = "u23"
        bit["c1"] = "u25"
        bit["c2"] = "u26"
        bit["c4"] = "u28"
        bit["c7"] = "u31"
        bit["e0"] = "u24"
        bit["e3"] = "u27"
        bit["e5"] = "u29"
        bit["e6"] = "u30"

#       binary decoding of hex digits

        hex["0"]  = "0000"
        hex["1"]  = "0001"
        hex["2"]  = "0010"
        hex["3"]  = "0011"
        hex["4"]  = "0100"
        hex["5"]  = "0101"
        hex["6"]  = "0110"
        hex["7"]  = "0111"
        hex["8"]  = "1000"
        hex["9"]  = "1001"
        hex["a"]  = "1010"
        hex["b"]  = "1011"
        hex["c"]  = "1100"
        hex["d"]  = "1101"
        hex["e"]  = "1110"
        hex["f"]  = "1111"

#       chip positions for a given bit, collected across all possible
#       boards.  Each group of 3 letters represents a position.
#       See keys for a better description.

        pos["u31"] =  "i01h01g01f01"
        pos["u30"] =  "e01d01c01b01"
        pos["u29"] =  "i02h02g02f02"
        pos["u28"] =  "e02d02c02b02"
        pos["u27"] =  "i03h03g03f03"
        pos["u26"] =  "e03d03c03b03"
        pos["u25"] =  "i04h04g04f04"
        pos["u24"] =  "e04d04c04b04"
        pos["u23"] =  "a01a02a03a04"
        pos["u22"] =  "i05h05g05f05"
        pos["u21"] =  "e05d05c05b05"
        pos["u20"] =  "i06h06g06f06"
        pos["u19"] =  "e06d06c06b06"
        pos["u18"] =  "i07h07g07f07"
        pos["u17"] =  "e07d07c07b07"
        pos["u16"] =  "i08h08g08f08"
        pos["u15"] =  "e08d08c08b08"
        pos["u14"] =  "a05a06a07a08"
        pos["u13"] =  "i09h09g09f09"
        pos["u12"] =  "e09d09c09b09"
        pos["u11"] =  "i10h10g10f10"
        pos["u10"] =  "e10d10c10b10"
        pos["u09"] =  "i11h11g11f11"
        pos["u08"] =  "e11d11c11b11"
        pos["u07"] =  "i12h12g12f12"
        pos["u06"] =  "e12d12c12b12"
        pos["u05"] =  "a09a10a11a12"
        pos["u04"] =  "i13h13g13f13"
        pos["u03"] =  "e13d13c13b13"
        pos["u02"] =  "i14h14g14f14"
        pos["u01"] =  "e14d14c14b14"
        pos["u00"] =  "i15h15g15f15"
        pos["c7"] =   "e15d15c15b15"
        pos["c6"] =   "i16h16g16f16"
        pos["c5"] =   "e16d16c16b16"
        pos["c4"] =   "a13a14a15a16"
        pos["l31"] =  "i17h17g17f17"
        pos["l30"] =  "e17d17c17b17"
        pos["l29"] =  "i18h18g18f18"
        pos["l28"] =  "e18d18c18b18"
        pos["l27"] =  "i19h19g19f19"
        pos["l26"] =  "e19d19c19b19"
        pos["l25"] =  "i20h20g20f20"
        pos["l24"] =  "e20d20c20b20"
        pos["l23"] =  "a17a18a19a20"
        pos["l22"] =  "i21h21g21f21"
        pos["l21"] =  "e21d21c21b21"
        pos["l20"] =  "i22h22g22f22"
        pos["l19"] =  "e22d22c22b22"
        pos["l18"] =  "i23h23g23f23"
        pos["l17"] =  "e23d23c23b23"
        pos["l16"] =  "i24h24g24f24"
        pos["l15"] =  "e24d24c24b24"
        pos["l14"] =  "a21a22a23a24"
        pos["l13"] =  "i25h25g25f25"
        pos["l12"] =  "e25d25c25b25"
        pos["l11"] =  "i26h26g26f26"
        pos["l10"] =  "e26d26c26b26"
        pos["l09"] =  "i27h27g27f27"
        pos["l08"] =  "e27d27c27b27"
        pos["l07"] =  "i28h28g28f28"
        pos["l06"] =  "e28d28c28b28"
        pos["l05"] =  "a25a26a27a28"
        pos["l04"] =  "i29h29g29f29"
        pos["l03"] =  "e29d29c29b29"
        pos["l02"] =  "i30h30g30f30"
        pos["l01"] =  "e30d30c30b30"
        pos["l00"] =  "i31h31g31f31"
        pos["c3"] =   "e31d31c31b31"
        pos["c2"] =   "i32h32g32f32"
        pos["c1"] =   "e32d32c32b32"
        pos["c0"] =   "a29a30a31a32"

#       keys is indexed by <board #> <bank> <board type>
#       and yields an index into  a particular pos string
#       for example, board 0, bit 0 on an mk4118 board
#       gives a key of 4.  If the bit in error was c0, then
#       the chip in error is a32 (from the 4th group of 3
#       in pos["c0"].  To change this map, create new keys
#       and (if necessary) append to the pos entries.
#       If it could be more than one chip, then use a multiple
#       digit key (e.g, see the keys for the mk4108 board).

        keys["00mk4118"] = "4"
        keys["20mk4118"] = "4"
        keys["40mk4118"] = "4"
        keys["60mk4118"] = "4"
        keys["80mk4118"] = "4"
        keys["a0mk4118"] = "4"
        keys["c0mk4118"] = "4"
        keys["e0mk4118"] = "4"
        keys["01mk4118"] = "2"
        keys["21mk4118"] = "2"
        keys["41mk4118"] = "2"
        keys["61mk4118"] = "2"
        keys["81mk4118"] = "2"
        keys["a1mk4118"] = "2"
        keys["c1mk4118"] = "2"
        keys["e1mk4118"] = "2"
        keys["10mk4118"] = "3"
        keys["30mk4118"] = "3"
        keys["50mk4118"] = "3"
        keys["70mk4118"] = "3"
        keys["90mk4118"] = "3"
        keys["b0mk4118"] = "3"
        keys["d0mk4118"] = "3"
        keys["f0mk4118"] = "3"
        keys["11mk4118"] = "1"
        keys["31mk4118"] = "1"
        keys["51mk4118"] = "1"
        keys["71mk4118"] = "1"
        keys["91mk4118"] = "1"
        keys["b1mk4118"] = "1"
        keys["d1mk4118"] = "1"
        keys["f1mk4118"] = "1"

        keys["00mk4116"] = "4"
        keys["20mk4116"] = "4"
        keys["40mk4116"] = "4"
        keys["60mk4116"] = "4"
        keys["80mk4116"] = "4"
        keys["a0mk4116"] = "4"
        keys["c0mk4116"] = "4"
        keys["e0mk4116"] = "4"
        keys["01mk4116"] = "2"
        keys["21mk4116"] = "2"
        keys["41mk4116"] = "2"
        keys["61mk4116"] = "2"
        keys["81mk4116"] = "2"
        keys["a1mk4116"] = "2"
        keys["c1mk4116"] = "2"
        keys["e1mk4116"] = "2"
        keys["10mk4116"] = "4"
        keys["30mk4116"] = "4"
        keys["50mk4116"] = "4"
        keys["70mk4116"] = "4"
        keys["90mk4116"] = "4"
        keys["b0mk4116"] = "4"
        keys["d0mk4116"] = "4"
        keys["f0mk4116"] = "4"
        keys["11mk4116"] = "2"
        keys["31mk4116"] = "2"
        keys["51mk4116"] = "2"
        keys["71mk4116"] = "2"
        keys["91mk4116"] = "2"
        keys["b1mk4116"] = "2"
        keys["d1mk4116"] = "2"
        keys["f1mk4116"] = "2"

        keys["00mk4108"] = "34"
        keys["20mk4108"] = "34"
        keys["40mk4108"] = "34"
        keys["60mk4108"] = "34"
        keys["80mk4108"] = "34"
        keys["a0mk4108"] = "34"
        keys["c0mk4108"] = "34"
        keys["e0mk4108"] = "34"
        keys["01mk4108"] = "12"
        keys["21mk4108"] = "12"
        keys["41mk4108"] = "12"
        keys["61mk4108"] = "12"
        keys["81mk4108"] = "12"
        keys["a1mk4108"] = "12"
        keys["c1mk4108"] = "12"
        keys["e1mk4108"] = "12"
        keys["10mk4108"] = "34"
        keys["30mk4108"] = "34"
        keys["50mk4108"] = "34"
        keys["70mk4108"] = "34"
        keys["90mk4108"] = "34"
        keys["b0mk4108"] = "34"
        keys["d0mk4108"] = "34"
        keys["f0mk4108"] = "34"
        keys["11mk4108"] = "12"
        keys["31mk4108"] = "12"
        keys["51mk4108"] = "12"
        keys["71mk4108"] = "12"
        keys["91mk4108"] = "12"
        keys["b1mk4108"] = "12"
        keys["d1mk4108"] = "12"
        keys["f1mk4108"] = "12"
        }

        {csrc     = $1
        syndrome = substr (csrc,7,2)
        board    = substr (csrc,2,1)
        boardtype = boards[board]
        bank     = substr (hex [substr (csrc,3,1)],1,1)
        chips    = bit[syndrome]
        if (known[boardtype])
        {  where         = pos[chips]
           key   = keys[board bank boardtype]
           sbegin   = 3 * (substr(key,1,1) - 1) + 1
           thechip  = substr(where,sbegin,3)
           if (length(key) > 1)
           {   sbegin   = 3 * (substr(key,2,1) - 1) + 1
               thechip  = thechip " and/or " substr(where,sbegin,3)
           }
#          printf "\n"
#          print "csrc =      " csrc
#          print "syndrome =  " syndrome
#          print "board =     " board
#          print "bank =      " bank
#          print "chips =     " chips
#          print "locations = " where
#          print "boardtype = " boardtype
#          print "key =       " key
#          print "the chip is " thechip
           errors[board "-" thechip]++;
        }
        else
        {
#          printf "\n"
#          print "Board type " boardtype " is unknown"
           errors["unknown-unknown"]++;
        }
}

END { for (i in errors) {
        n = split(i,list,"-");
        printf "%d errors for board %s, chip %s\n",errors[i],list[1],list[2];
        }
}