syntax highlighting in vim

Eric Blake ericblake@comcast.net
Wed Nov 23 18:27:00 GMT 2005


> > The use of a trailing space in the alias controls
> > whether the next word on the command line will also
> > be subject to alias expansion;
> 
> True, but I prefer not to make assumptions about how
> people are using aliases. The space at the end of the
> alias makes it behave like the unaliased ls in that
> regard.

Wrong again - alias expansion in bash starts ONLY at the
first word, and only progresses on to the next word if
the current alias expansion ended in a space.  So if
ls is not aliased, the second word is never even checked
for alias expansion.  Therefore, putting a space at the
end of an alias for ls actually maked ls behave
DIFFERENTLY than the unaliased version, since it is now
telling bash to alias expand the next argument.

$ cd /tmp
$ touch file
$ alias ls
bash: alias: ls: not found
$ alias file=oops
$ ls file
file
$ alias ls='ls '
$ ls file
ls: oops: No such file or directory
$ \ls file
file

Furthermore, in 99.9% of the cases, a shell function
can do the same thing as an alias.

$ unalias ls
$ ls() { command ls --color=auto "$@" }
$

The exceptional cases are when you do funky things
like those mentioned in
http://www.chiark.greenend.org.uk/~sgtatham/aliases.html.

I kind of like this hack that makes find temporarily supress globbing,
so that I can type "find -name *.c" instead of "find -name '*.c'":

alias find='_find() { command find "$@"; set +f; }; set -f; _find'

--
Eric Blake
volunteer cygwin bash maintainer



--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Problem reports:       http://cygwin.com/problems.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/



More information about the Cygwin mailing list