[net.unix] Unix Bugs and Suggestions

Laws@SRI-AI.ARPA@sri-unix.UUCP (08/31/83)

From:  Ken Laws <Laws@SRI-AI.ARPA>

The following are gripes and suggestions that I have accumulated
over several years.  Some may no longer be pertinent, or may never
have been pertinent to systems other than the one I am using.  I
operate in a VAX EUNICE environment emulating Berkeley 4.1c UNIX.
I normally use the csh shell.

					-- Ken Laws




10-Jul-82  Laws at SRI-IU
The APL batch interpreter requires different (and incorrect) syntax
from that required by the interactive interpreter.  For instance,
results do not print unless explicitly assigned to a quad.  There
seems to be a problem with the local variable declaration mechanism.
Statement labels do not work properly.  The .sg operator for negation
is undocumented, making it very difficult to enter a number with a
negative exponent.

10-Jul-82  Laws at SRI-IU
The history mechanism has a flaw.  "!26:0 !:1" fails to pick up arg
1 from command 26, despite what the csh documentation says.
Also, the form !!:s/l/r/ doesn't permit a * or \* in the l string;
evidently the history parser tries to break at the *.  (Minor point:
the csh man page documents s/l/r/ as "substitute l for r" when it
is really "substitute r for l".)

16-Jul-82  Laws at SRI-IU
The new standard I/O package seems to be incompatible with the
"script" command.  It buffers program output, making it impossible
to carry on a conversation with an interactive process.  On EUNICE
this has been fixed so that script files look like ttys to the
I/O routines and every line is flushed.

21-Jul-82  Laws at SRI-IU
BTW, what does "rc" mean?  Unix always uses rc files for
initialization, and no one seems to know the mnemonic.

26-Jul-82  Laws at SRI-IU
A "vfree" capability is needed for image processing work, as is
a contiguous storage mechanism.

26-Jul-82  Laws at SRI-IU
I-nodes should store additional bits indicating which names
are directories and which are shell scripts.  These should be
flagged by the ls command much as ls -F now flags directories.
Having the extra bits would speed up the ls -F command and
should speed up some shell actions as well.

26-Jul-82  Laws at SRI-IU
The find command should offer a "depth" limit so that one could
more easily specify an action to be performed on all of the
first-level children of a particular directory.  Also, it is
awkward that the action performed by -exec is done in the invoking
environment and not in the environment of each selected file.
(Perhaps both types of -exec are needed.)  I have tried passing
"(cd {}; <command>)" to a "find . -type d", but there is no way
to quote the semicolon without also hiding the {} so that find
can't substitute the directory name.

26-Jul-82  Laws at SRI-IU
The command "rm -f *.o foo.txt" will bomb it there is no .o file
available.  It would seem more logical for the command to bomb
(if at all) only when the entire argument list is null.  Another
place this causes trouble is with "cc -o tst tst.c *.o -I...",
which bombs if there is no .o file.  I don't even want to see a
complaint from the shell, much less have it skip the command.
(This is different from "set nonomatch" in that it would omit
the unsatisfied substitution instead of leaving it in the command
line.)

26-Jul-82  Laws at SRI-IU
The csh syntax {a,b,c} is inconsistent with the normal argument
syntax of "a b c".  This interferes with using the `` mechanism
within {} to generate lists of things for shell commands to operate
on.  (Personally, I would like to see the comma form made legal
as well as the standard space form.  See the next comment.)
It also makes it difficult to format a command script nicely by
breaking lines with an escaped newline (i.e. \
because no space is allowed to come between the comma and the
next entry.

26-Jul-82  Laws at SRI-IU
The shell argument-passing mechanism should be augmented so that
a null argument could be indicated using successive commas.  The
shell would then also need syntax for testing whether an argument
was missing (as opposed to null).  This would give the necessary
hook for writing shell scripts with default arguments.

26-Jul-82  Laws at SRI-IU
The -I/dir/include syntax in the cc command, and similar flags for
other programs, are awkward because the shell can't expand the
variable in -I$var.  This could be alleviated by allowing a space
following the -I flag in the manner of most other UNIX flags.

27-Jul-82  Laws at SRI-IU
Now that UNIX is becoming a user environment, it would be helpful
to have a "nomagic" switch for the csh as there is for ex.  (This
is different from "set noglob" in that expansions could still be
invoked by quoting the special symbols.)  I would particularly
like to turn off magic handling of ? and ?? since they are seldom
used as wildcards and would be very useful as query arguments
to interactive programs.  (I would also like to use ?> as an
abbreviation for " ? ? ? ? ...", which means that "nomagic"
would have to allow the ?> syntax.)

13-Aug-82  Laws at SRI-IU
The code for whatis.c is redundant with that in man.c.  The
whatis command could now be replaced by a shell script invoking
man -f the way that apropos invokes man -k.  (Alternatively, the
man options could be dropped and apropos and whatis could both
be made separate programs.)  BTW, the error message in man
misspells "appropriate" as "apropriate".

27-Aug-82  Laws at SRI-IU
The which command does not expand aliases.  This can be very
confusing when it reports that one version will be executed
but another actually is.

11-Sep-82  Laws at SRI-IU
The spell command does not accept a -x command as documented.
It passes the x on to deroff, which can't handle it.

27-Sep-82  Laws at SRI-IU
The apropos and man systems sometimes don't coordinate.
You cannot tell from the apropos lines for feof, fabs, or strlen
what name you should give to man to get the full details.

27-Sep-82  Laws at SRI-IU
There should be a command similar to whatis that gives the
synopsis line of a program.

04-Oct-82  Laws at SRI-IU
The shell usurps the () symbols to denote lists of commands.
While this is a valuable function, I would also like to see
arguments which can be lists of subarguments.  The only
mechanism currently available is to flag each argument type
and to detect the end of the list by locating the next flag.
Such parsing gets very tricky when the order of the major
arguments is not fixed.  It would be so much easier if the
shell accepted "command -s (size1 ...) -n (name1 ...)" and
either kept the subarguments intact in the argv list or
recursively parsed them in lists pointed at by the argv list.

04-Oct-82  Laws at SRI-IU
The other major capability I see lacking in the UNIX philosophy
is property lists.  I would like to be able to annotate any
object, particularly files and directories, with comments,
applicable handler routines, backup tape archive name, etc.
I would like to see a property list concept similar to that
in LISP developed.  It shouldn't be very hard to associate
some kind of .prop file with every current UNIX file type.

15-Oct-82  Laws at SRI-IU
If you set a shell variable to a null string, "set a =", and
then ask "echo $#a", you get 1 instead of the correct 0 length.
The command "set a = `alias foobar`" gives a correct length of 0
when no alias exists.

18-Oct-82  Laws at SRI-IU
Ctags gets confused by any line which starts on the left margin
and contains a parenthesis, even if that line is inside a comment.

20-Oct-82  Laws at SRI-IU
Redirecting the standard output of a process to a log file
works fine, but doing a cat on the file will show nothing
until enough output has been generated to produce a buffer
dump.  It would be nice if a log file could be given the same
I/O buffering as a tty.

21-Oct-82  Laws at SRI-IU
It looks like the man program may have a problem, although it
hasn't caused us trouble yet.  The "search" section of the
manual() subroutine in /usr/src/cmd/man/man.c appends various
letters to the command.section string in the "work"
vector.  It neglects to put a 0 (NULL) in the following slot, so
that the action of the "stat" command depends on what garbage
was in the buffer previously.

21-Oct-82  Laws at SRI-IU
The !* history mechanism is apparently quite useful for passing
an argument list into an alias, as in

    alias foo "bar1; bar2 \!*; bar3"

It seems, however, that !* is not documented in the csh man page.
This should be done.

11-Nov-82  Laws at SRI-IU
The shell should respond to a ^U rubout with a new prompt symbol,
at least on terminals that do a LF and not just a CR.

12-Nov-82  Laws at SRI-IU
The man facility really should use tbl and neqn when formatting
files so that we could include tables and equations.  Also, it
should be better documented somewhere (e.g., in the man page for
man itself) that the man macros are those in the -man package and
are documented in man(7).

18-Nov-82  Laws at SRI-IU
The practice of creating a "lock file" to prevent multiple access
to a particular operating system service (e.g., the printer) is
somewhat awkward.  It is sometimes possible to wedge a server
if you kill a process during the time that the lock file exists
since the operating system does not support named "temporary" files
that are deleted if the process dies.  Perhaps UNIX should support a more 
fundamental locking mechanism, e.g. an "unsharable" file protection
mode or I/O access mode which would prevent more than one user
having write access at once.

18-Nov-82  Laws at SRI-IU
Denying write access to a file is not particularly meaningful if
the user can move the file where no one will ever find it (e.g.
/tmp/.tmp) and replace it with a new file.  While this can be
prevented by manipulating permissions to the directory itself,
it might be worthwhile to modify the mv command (and the routines
it uses) to refuse to move a write-protected file.

27-Nov-82  Laws at SRI-IU
There should be a way of flagging .cshrc commands that are to apply
only to explicit shell invocations (e.g., via the csh command) as
opposed to those needed for both interactive and background
processes (e.g., shells sprouted by make).

29-Nov-82  Laws at SRI-IU
The history mechanism should be able to repeat an entire foreach
command, not just the first line.

29-Nov-82  Laws at SRI-IU
Evidently the Berkeley grep command takes a -y for case fold search
instead of the documented -i.  The documentation should be
upgraded.

30-Nov-82  Laws at SRI-IU
The use of the name line in each man page to generate keywords for the
apropos system is not optimal.  It forces the documentor to make absurd
entries like the "sh" name, which includes every built-in shell command,
or to omit valuable keywords as in the "csh" entry.  It discourages the
documentation of libraries as units, and encourages separate and redundant
documention of trivial little subroutines.  It leads to man pages such as
string(3) and floor(3m) where the name of the man page is difficult
to determine from the apropos line.  One solution would be to have a
separate (and optional) "INDEX" or "KEYWORD" entry in each man page in
which the documentor could store keywords to be added to those in the
name line.  Apropos would search both the KEYWORD and NAME fields, but
would only print the NAME field.

21-Dec-82  Laws at SRI-IU
The "make" system does not expand .cshrc aliases, and is unable
to execute an "alias" command.  To get around this, put in something
like "@csh -v -c "<aliased command>".

27-Jan-83  Laws at SRI-IU
Do not use a $shellvar as a library name in a cc command if the
set shellvar = "..." command (with quotes) has a \<Carriage Return>
in it.  The loader will complain about premature EOF.

31-Jan-83  Laws at SRI-IU
It is absurd (and a real pain) that ranlib must be run every time
a file is archived (or deleted!) or an archive is moved.  If this
kludge is really necessary, it should be built into ar, mv, and cp.

03-Feb-83  Laws at SRI-IU
The documentation of "news" omits the -s argument for sending
a file to the news directory.

06-Apr-83  Laws at SRI-IU
Normal use of the the make system's intelligence has a minor
bug:  If running make produces linker errors because a library
is missing in a compile command, and if you edit the makefile
to add the library name, the make system may be fooled into
saying that all its files are now up to date.  The problem is
that the makefile itself, rather than any of its inputs or
outputs, has changed, and this change makes some of its outputs
obsolete.  Possibly the make system should check the date of
the makefile as well as the dates of its associated files.
-------

edhall@rand-unix@sri-unix.UUCP (09/01/83)

At least half of your complaints concerned problems with CSH.
After two years working with and learning about that monstrosity
I finally have to vent some steam over it.

The C-shell hardly deserves to be called `UNIX'.  It has a wealth
of features, each one not quite fully implemented and each with
an arcane syntax which, if it is similar to that of other features,
is just different enough to thwart the user's intuitions.  It is
clearly an effort of several individuals, each with their own `idea'
of what it should be.

The Bourne shell may not have some of the features, but it is clean
and elegant.  Its facilities don't seem to be at war with each other.
I almost always use it for scripts, as it seems to be much more of
a *programming language*.  By comparison, C-shell is just a grab-bag
of hacks.  (Useful hacks, to be sure...)

Don't get me wrong; I *use* C-shell as my interactive shell.  History,
job-control, and aliasing are all productive features for me.  But
someone, somewhere, has to have done a better job with them.

		-Ed Hall
		edhall@rand-unix
		decvax!randvax!edhall