From: Nancy Blachman <[email protected]>
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       [email protected] or [email protected]

::::::::::::::
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 = $<
       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 ( "$<" =~ 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
*slowest* . . . .  FYA (For Your Amusement), here's my .login and .cshrc
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=$<
               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
[email protected]


::::::::::::::
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
                                               [email protected]


From: Nancy Blachman <[email protected]>
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 = ($< );
  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=($< );
     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
*del)
   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;;

*undelete)
   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=$<
   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 <[email protected]>
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 <[email protected]>
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];
       }
}