ianmacd dc5e5a1cfc - _rpm(): handle query of uninstalled packages when options are not
concatenated, i.e. rpm -qp worked, but rpm -q -p did not. Further
   complicated by fact that other options could be interspersed,
   e.g. rpm -q -l -p -i, and that partial concatenation could be given,
   e.g. rpm -q -ipl
2002-03-07 16:16:43 +00:00

$Id: README,v 1.7 2002/03/02 01:09:41 ianmacd Exp $


INSTALLATION
------------

If you are installing the source file manually as opposed to using a packaging
system such as dpkg or rpm, put it somewhere on your system and source it from
either /etc/bashrc or ~/.bashrc.

Here's one possible way of doing that from /etc/bashrc:

bash=${BASH_VERSION%.*}; bmajor=${bash%.*}; bminor=${bash#*.}
if [ "$PS1" ] && [ $bmajor -eq 2 ] && [ $bminor '>' 04 ] \
   && [ -f /etc/bash_completion ]; then # interactive shell
        # Source completion code
        . /etc/bash_completion
fi
unset bash bmajor bminor

This code checks that the version of bash that is parsing the code is later
than 2.04 and, if so, sources the bash completion code.

While this code may, at first, seem overly complex, the advantage of using it
is that it will also parse correctly when interpreted by bash 1.x. If you have
bash 1.x and bash 2.x users on your system, you must avoid using constructs
that were not valid under 1.x syntax.

If you are putting the bash completion source file somewhere other than
/etc/bash_completion, you will need to edit the top of the file to make
$BASH_COMPLETION point to the correct location.

The line you need to adjust is this one:

[ -z "$BASH_COMPLETION" ] && declare -r BASH_COMPLETION=/etc/bash_completion


TROUBLESHOOTING
---------------

If you get errors about 'complete' or 'compgen' not accepting the -g flag,
you are probably running bash 2.05 and should either apply the group completion
patch, download a prepatched bash binary of 2.05, or upgrade to 2.05a or later.

If you find that some commands, such as 'cd /usr<Tab>', end with a trailing
space instead of appending a /, you are probably running the base version of
bash 2.05, which suffers from a bug that causes the '-o filenames' option to
the complete built-in to be ignored. You can fix this by applying the following
the following official patch from the bash maintainer:

	ftp://ftp.cwru.edu/pub/bash/bash-2.05-patches/bash205-006

If you get errors about 'complete' not accepting the -o flag, you are probably
running bash 2.04. In this case, you should upgrade to bash 2.05a or later.

Copies of the patches and prepatched versions of bash are available from:

			http://www.caliban.org/bash/

If you find that a given function is producing errors under certain
circumstances when you attempt completion, try running 'set -v' or 'set -x'
prior to attempting the completion again. This will produce useful debugging
output that will aid me in fixing the problem if you are unable to do so
yourself. Turn off the trace output by running either 'set +v' or 'set +x'.

KNOWN PROBLEMS
--------------

I.

There seems to be some issue with using the bash built-in cd within Makefiles.
When invoked as /bin/sh within Makefiles, bash seems to have a problem changing
directory via the cd command. A work-around for this is to define
SHELL=/bin/bash within your Makefile. This is believed to be a bug in bash.

II.

The have() function is used to conserve memory by only installing completion
functions for those programs that are actually present on your system. The
current method of determining whether or not a given binary is present is
whether or not it is in your $PATH.

This approach has the disadvantage that sudo completion will not be able to
perform sub-completion on, say, service, if /sbin is not in your path, which,
as an unprivileged user, it typically isn't.

The work-around for this is to put all directories of binaries for which you
require completion into your $PATH variable prior to sourcing bash_completion.

III.

Many of the completion functions assume GNU versions of the various text
utilities that they call (e.g. grep, sed and awk). Your mileage may vary.

FAQ
---

Q. How can I insert my own local completions without having to reinsert them
   every time you issue a new release?

A. Put them in ~/.bash_completion, which is parsed at the end of the main
   completion script.


-- 
Ian Macdonald <ian@caliban.org>
Description
No description provided
Readme 7.8 MiB
Languages
Shell 97.1%
Makefile 2.3%
Perl 0.3%
Python 0.2%