REVDEP-REBUILD
Section: Misc. Reference Manual Pages (1)
Updated: 0.3.3
Index
Return to Main Contents
NAME
revdep-rebuild - Gentoo: Reverse Dependency Rebuilder
SYNOPSIS
revdep-rebuild
[OPTIONS] [--] [EMERGE OPTIONS]
DESCRIPTION
revdep-rebuild scans libraries and binaries for missing shared library dependencies and attempts to fix them by re-emerging those broken binaries and shared libraries. It is useful when an upgraded package breaks other software packages that are dependent upon the upgraded package.
OPTIONS
- -C | --nocolor
-
Turn off colored output. (This option is also passed to portage.)
- -d | --debug
-
Print way too much information (uses bash's set -xv)
- -e | --exact
-
Emerge the most recent version of found packages, without regard to SLOT.
NOTE:
This option is not yet implemented in the python version.
- -h | --help
-
Print usage.
- -i | --ignore
-
Delete temporary files from previous runs.
- -k | --keep-temp
-
Force revdep-rebuild not to delete temporary files after it successfully rebuilds packages. This option will NOT prevent revdep-rebuild from deleting inconsistent or out-of-date temporary files.
- --library NAME | -L NAME
-
Search for reverse dependencies for a particular library or group of libraries, rather than every library on the system. This option will unconditionally emerge packages that use the named library. Note: This option is used to force packages using the named library to be rebuilt even if they are not broken. NAME can be a full path to a library or basic regular expression. (See regex(7).)
- -l | --no-ld-path
-
Do not set LD_LIBRARY_PATH. Note: Using this option will cause revdep-rebuild to report some false positives.
- -o | --no-order
-
Do not check the build order against the deep dependency list. This will make revdep-rebuild faster, but it can cause emerge failures. Please try revdep-rebuild without -o before reporting any bugs.
- -p | --pretend
-
Do a dry-run. Do not delete temporary files. (-k -p is redundant, but harmless.) --pretend is assumed when not running revdep-rebuild as root.
- -P | --no-progress
-
Turn off the progress meter
- -q | --quiet
-
Print less output and disable the progress meter. (This option is also passed to portage.)
- -u | --search-symbols
-
Searches for undefined symbols in executibles. This will most likely have false positives in the output, so it is recommended to only use this option with pretend and manually fix any legitimate issues found. Note: This is currently only implemented in revdep-rebuild.sh, it is not implemented in revdep-rebuild.py.
- -v | --verbose
-
More output. (Prints the revdep-rebuild search environment.)
- Options after -- are ignored by revdep-rebuild and passed directly to emerge.
-
CONFIGURATION
revdep-rebuild no longer uses hardcoded paths. To change the default behavior the following variables can be changed by the user.
LD_LIBRARY_MASK - Mask of specially evaluated libraries
SEARCH_DIRS - List of directories to search for executables and libraries
SEARCH_DIRS_MASK - List of directories to not search
You can prepend to these variables by setting the variable in your environment prior to execution, by placing an entry in make.conf, or by placing a file in /etc/revdep-rebuild containing the appropriate variables.
The variables are read and set in the following order:
environment settings - one time changes by user
make.conf - persistent changes by user
/etc/revdep-rebuild/* - persistent changes by ebuild authors
While a user can edit and modify the files in the /etc/revdep-rebuild directory, please be aware that the /etc/revdep-rebuild directory is not under configuration protection and files can be removed and/or overwritten by an ebuild. To change this add /etc/revdep-rebuild to the CONFIG_PROTECT variable in make.conf.
An entry of "-*" means to clear the variable from that point forward.
Example: SEARCH_DIRS="/usr/bin -*" will set SEARCH_DIRS to contain only /usr/bin
REVDEP_REBUILD_DEFAULT_OPTS - List of default emerge options for revdep-rebuild
The REVDEP_REBUILD_DEFAULT_OPTS variable can be used to override EMERGE_DEFAULT_OPTS for revdep-rebuild. This variable replaces the values of EMERGE_DEFAULT_OPTS and can still be overridden by command line options. Please note that this variable is only for options to pass to emerge and not options for revdep-rebuild itself.
revdep-rebuild honors the NOCOLOR and PORTAGE_NICENESS variables from make.conf
EXAMPLES
It is recommended that when running revdep-rebuild that the following command be used initially:
revdep-rebuild --ignore --pretend
To search the entire system, while excluding /mnt and /home:
env SEARCH_DIRS="/ -*" SEARCH_DIRS_MASK="/mnt /home" revdep-rebuild
To rebuild packages that depend on libkdecore.so.4 from KDE 3.3:
revdep-rebuild --library /usr/kde/3.3/lib/libkdecore.so.4
To rebuild packages that depend upon libImlib.so and libImlib2.so:
revdep-rebuild --library libImlib[2]*.so.*
FILES
revdep-rebuild keeps several pseudo-temporary files in /var/cache/revdep-rebuild/. Deleting these files can improve accuracy at the cost of speed:
- 0_env.rr
-
Contains environment variables
- 1_files.rr
-
Contains a list of files to search
- 2_ldpath.rr
-
Contains the LDPATH
- 3_broken.rr
-
Contains the list of broken files
- 3_errors.rr
-
Contains the ldd error output
- 4_raw.rr
-
Contains the raw list of packages
- 4_owners.rr
-
Contains the file owners
- 4_pkgs.rr
-
Contains the unsorted bare package names
- 4_ebuilds.rr
-
Contains the unsorted atoms
- 5_order.rr
-
Contains the sorted atoms
- 6_status.rr
-
Contains the ldd error output
EXIT STATUS
revdep-rebuild returns a zero exit status if it
and emerge succeeds, and a nonzero exit status otherwise.
BUGS
Report bugs to <http://bugs.gentoo.org>. Please do not report emerge failures caused by -o or -e. Please include your files from /var/cache/revdep-rebuild/, your emerge --info, and patches. ;)
SEE ALSO
emerge(1),
portage(5),
regex(7)
Index
- NAME
-
- SYNOPSIS
-
- DESCRIPTION
-
- OPTIONS
-
- CONFIGURATION
-
- EXAMPLES
-
- FILES
-
- EXIT STATUS
-
- BUGS
-
- SEE ALSO
-