Extensions for colcon to inspect packages which have already been installed.
Project description
Extensions for colcon-core to inspect packages which have already been installed.
Overview
These colcon extensions provide a mechanism which can be used for getting information about packages outside of the workspace, which have already been built and installed prior to the current operation. In general, it works similarly to and is based on the PackageDiscoveryExtensionPoint and PackageAugmentationExtensionPoint extensions provided by colcon-core.
Differences
Installed packages don’t generally have a single directory which stores the package content and metadata. This set of extensions store the “prefix” under which the package resides rather than the package directory (e.g. ~/workspace/install instead of ~/workspace/install/share/<package_name> or ~/workspace/src/<package_name>), meaning many packages will likely share the same path attribute value.
Recursively crawling an entire system or even selective subdirectories to look for installed packages could be very slow, so this process also deviates from the Discover -> Identify -> Augment pipeline used in colcon-core. Rather than attempting identification on prospective package locations, the discovery phase generally loads a list of installed packages from a database of some kind, such as the file-based colcon index. In some cases, the database might already populate sufficient information on the descriptor to identify the package. For others, only presence can be known, and augmentation extensions must add additional information to the descriptor by searching for specific files throughout the prefix directory.
The type attribute of an installed package works similarly to workspace packages, but must always start with installed. followed by a more specific package type. If more information about a package cannot be determined and it is known only to exist under a certain prefix, the type should be set to installed.
Supported Package Types
This package provides extensions which are able to discover packages using the PrefixPathExtensionPoint to enumerate install prefixes, and FindInstalledPackagesExtensionPoint to enumerate names of packages installed under those prefixes. It can then use the colcon index in those prefixes as well as python eggs to determine dependency information and augment the packages appropriately.
Support for more package databases for discovery and augmentation can be added by other packages by implementing and registering appropriate extensions.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for colcon-installed-package-information-0.2.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | d66d9e67ff549f220d47ccd719170a6357ac7ac101218cfcc5ae5b2544c52241 |
|
MD5 | 9fd3d04405f980c618eaeb945fe15598 |
|
BLAKE2b-256 | e44dd650cb92bb7e3faaa89d2ff7a6d5005b5142f0ef5ca53ec71d995c74aadf |
Hashes for colcon_installed_package_information-0.2.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2565dc58b03732a3980446a2a325db3329b5644cdf64b729c474558fa9524d4b |
|
MD5 | dd09d0ca3e732fed93bd7ebf0efa66d7 |
|
BLAKE2b-256 | 40881ebf13282afcb47fe4e779ec2be62f504d91014151316303fd1ac4d02844 |