On 12/7/11 9:43 PM, Miles Bader wrote:
> I notice that recently the behavior of bash completion w/r/t
> environment variables has changed, in a reallllly annoying way:

This has enjoyed detailed discussion in the past, on several occasions.

http://lists.gnu.org/archive/html/bug-bash/2011-09/msg00007.html
contains a basic summary and includes a patch that adds a `direxpand'
shell option to restore the 4.1 behavior.

You can download a version of bash-4.2.20 with this patch already applied
from the `direxpand' branch on the bash git tree on savannah.

> If one has an environment variable like:
> 
>    ls=/usr/local/src
> 
> and then hit <TAB> to complete the following command line:
> 
>    $ cd $ls/ema<TAB>
> 
> where the intent is to do "cd /usr/local/src/emacs", then:
> 
> * The _old_ behavior of bash was to (1) expand "$ls" to
>   "/usr/local/src", and then (2) proceed to complete
>   "/usr/local/src/ema" into "/usr/local/src/emacs".  Handy!

Not everyone considers that to be true.

> 
> * The _new_ behavior is to just add a backslash before "$" and then
>   (apparently) try to complete on the literal-$-prefixed string --
>   which of course usually fails, as there is no such subdirectory.

It's slightly more complicated than that, but that's the gist: a
filename containing a character that requires quoting gets quoted.

> Given that filenames/directories containing a literal "$" are quite
> rare in general, 

Not as rare as you might think, given the existence of Windows shares
mounted on different systems.

Chet

-- 
``The lyf so short, the craft so long to lerne.'' - Chaucer
                 ``Ars longa, vita brevis'' - Hippocrates
Chet Ramey, ITS, CWRU    c...@case.edu    http://cnswww.cns.cwru.edu/~chet/

Reply via email to