Development Status
- 3 - Alpha
Intended Audience
- Developers
License
- OSI Approved :: Apache Software License
Programming Language
- Python :: 3
- Python :: 3.6
- Python :: 3.7
- Python :: 3.8
- Python :: 3.9
- Python :: 3.10
- Python :: 3.11
- Python :: 3.12
- Python :: 3.13
- Python :: Implementation :: CPython
- Python :: Implementation :: PyPy
Operating System
- OS Independent
findlibs
A Python package that searches for shared libraries on various platforms.
Usage
import findlibs
lib = findlibs.find("eccodes")
# If package name differs from library name use:
lib = findlibs.find(lib_name="odccore", pkg_name="odc")
Installation
pip install findlibs
Testing
git clone https://github.com/ecmwf/findlibs
cd findlibs
pip install -e ".[test]"
pytest
find
The module only contains the find() function.
def find(lib_name, pkg_name=None)
Returns the path to the selected library, or None if not found.
Arguments:
lib_namestr - Library name without thelibprefix. The name of the library to find is formed usinglib_nameand a platform specific suffix (by default ".so"). E.g. whenlib_nameis "eccodes" the library name will be "libeccodes.so" on Linux and "libeccodes.dylib" on macOS.pkg_namestr, optional - Package name if it differs from the library name.
Returns:
str or None: Path to selected library
The algorithm to find the library is as follows:
-
First, tries to find the library in an installed python module package with the given name, e.g. eccodeslib, eckitlib. Disable this search option by setting environment variable
FINDLIBS_DISABLE_PACKAGE=yes. -
Next, tries the
libandlib64directories undersys.prefixand$CONDA_PREFIX. Disable this search option by setting environment variableFINDLIBS_DISABLE_PYTHON=yes. -
Next, tries the
libandlib64directories under the paths defined by thepkg_name + "_HOME"andpkg_name + "_DIR"environment variables. Both lowercase and uppercase versions are tested. E.g. ifpkg_nameis "eccodes" it will check the paths defined by$eccodes_dir,$eccodes_home,$ECCODES_DIRand$ECCODES_HOME. Disable this search option by setting environment variableFINDLIBS_DISABLE_HOME=yes. -
Next, tries to load the search paths from the user defined
~/.findlibsor~/.config/findlibs/findlibs.confINI configuration files. Then for all the user defined search paths, thelibandlib64subdirectories are tried.Please note that only one of these files can exist. The configuration file can contain multiple search paths, but no relative paths or paths to files are allowed. The file can even be completely empty or can contain no paths at all. The file format is as follows:
[Paths] /path/to/lib_directoryDisable this search option by setting environment variable
FINDLIBS_DISABLE_CONFIG_PATHS=yes. -
Next, tries the directories defined by the
$LD_LIBRARY_PATHand$DYLD_LIBRARY_PATHenvironment variables. Disable this search option by setting environment variableFINDLIBS_DISABLE_LD_PATH=yes. -
Next, tries the
libandlib64directories under the following paths "/", "/usr/", "/usr/local/", "/opt/", "/opt/homebrew/" and "~/.local/". Disable this search option by setting environment variableFINDLIBS_DISABLE_SYS=yes. -
Finally, tries calling the
ctypes.util.find_libraryfunction. Disable this search option by setting environment variableFINDLIBS_DISABLE_CTYPES_UTIL=yes.