The Discovery Module¶
This module implements discovery of packages which export various spec files.
You can use this API as follows, (examples assume use of the ‘test/discovery_workspaces/minimal’ workspace:
>>> from pprint import pprint
>>> from capabilities.discovery import package_index_from_package_path
>>> from capabilities.discovery import spec_file_index_from_package_index
>>> from capabilities.discovery import spec_index_from_spec_file_index
>>> workspaces = ['test/discovery_workspaces/minimal']
>>> package_index = package_index_from_package_path(workspaces)
>>> spec_file_index = spec_file_index_from_package_index(package_index)
>>> pprint(spec_file_index)
{'minimal_pkg': {
    'capability_interface': ['test/discovery_workspaces/minimal/minimal_pkg/interfaces/Minimal.yaml'],
    'capability_provider': [
        'test/discovery_workspaces/minimal/minimal_pkg/providers/minimal.yaml',
        'test/discovery_workspaces/minimal/minimal_pkg/providers/specific_minimal.yaml'],
    'package': <catkin_pkg.package.Package object at 0x10bb28df8>,
    'semantic_capability_interface': [
        'test/discovery_workspaces/minimal/minimal_pkg/interfaces/SpecificMinimal.yaml']}}
>>> spec_index, errors = spec_index_from_spec_file_index(spec_file_index)
>>> print(errors)
[]
>>> spec_index.names
[minimal_pkg/specific_minimal,
 minimal_pkg/Minimal,
 minimal_pkg/SpecificMinimal,
 minimal_pkg/minimal]
>>> pprint(spec_index.specs)
{minimal_pkg/minimal:
    <capabilities.specs.provider.CapabilityProvider object at 0x10391ce50>,
 minimal_pkg/specific_minimal:
    <capabilities.specs.provider.CapabilityProvider object at 0x10391cd10>,
 minimal_pkg/Minimal:
    <capabilities.specs.interface.CapabilityInterface object at 0x103952f90>,
 minimal_pkg/SpecificMinimal:
    <capabilities.specs.semantic_interface.SemanticCapabilityInterface object at 0x103952b50>}
>>> spec_index.interface_names
[minimal_pkg/Minimal]
>>> spec_index.interfaces
{minimal_pkg/Minimal: <capabilities.specs.interface.CapabilityInterface at 0x103952f90>}
>>> spec_index.interfaces['Minimal']
<capabilities.specs.interface.CapabilityInterface object at 0x10b7e3410>
>>> spec_index.semantic_interfaces
{'SpecificMinimal': <capabilities.specs.semantic_interface.SemanticCapabilityInterface object at 0x10b7bf3d0>}
>>> pprint(spec_index.providers)
{'minimal': <capabilities.specs.provider.CapabilityProvider object at 0x10b7bf750>,
 'specific_minimal': <capabilities.specs.provider.CapabilityProvider object at 0x10b7bfd10>}
- 
exception capabilities.discovery.DuplicateNameException(name, colliding_package, spec_type)[source]¶
- Raised when multiple specs with the same name are discovered - Variables: 
- 
exception capabilities.discovery.InterfaceNameNotFoundException(msg, spec_name, spec_type, spec_package)[source]¶
- Raised when a referenced interface spec is not found - This can happen, for example, when a provider depends on an interface which is not defined anywhere. - Variables: 
- 
class capabilities.discovery.SpecIndex[source]¶
- Container for capability spec file locations and respective spec classes - 
add_interface(interface, file_path, package_name)[source]¶
- Add a loaded CapabilityInterface object into the repository - Used by - spec_index_from_spec_file_index()to build the- SpecIndex.- Parameters: - interface (specs.interface.CapabilityInterface) – CapabilityInterface object which was loaded using a factory function
- file_path (str) – path to the interface spec file that was loaded
- package_name (str) – name of the package which contains the interface
 - Raises: - DuplicateNameExceptionif there is a name collision
- interface (
 - 
add_provider(provider, file_path, package_name)[source]¶
- Add a loaded CapabilityProvider object into the repository - Used by - spec_index_from_spec_file_index()to build the- SpecIndex.- Parameters: - provider (specs.provider.CapabilityProvider) – CapabilityProvider object which was loaded using a factory function
- file_path (str) – path to the provider spec file that was loaded
- package_name (str) – name of the package which contains the provider
 - Raises: - DuplicateNameExceptionif there is a name collision- Raises: - InterfaceNameNotFoundExceptionif the interface which this capability provider implements is not found.
- provider (
 - 
add_semantic_interface(semantic_interface, file_path, package_name)[source]¶
- Add a loaded SemanticCapabilityInterface object into the repository - Used by - spec_index_from_spec_file_index()to build the- SpecIndex.- Parameters: - semantic_interface (specs.semantic_interface.SemanticCapabilityInterface) – SemanticCapabilityInterface object which was loaded using a factory function
- file_path (str) – path to the semantic interface spec file that was loaded
- package_name (str) – name of the package which contains the semantic interface
 - Raises: - DuplicateNameExceptionif there is a name collision- Raises: - InterfaceNameNotFoundExceptionif the interface which this semantic capability interface redefines is not found.
- semantic_interface (
 - 
interface_paths¶
- Returns: - dict of capability interface spec paths, keyed by name - Return type: - dict{- str:- str}
 - 
interfaces¶
- Returns: - dict of capability interfaces, keyed by name - Return type: - dict{- str:- specs.interface.CapabilityInterface}
 - 
provider_paths¶
- Returns: - dict of capability provider spec paths, keyed by name - Return type: - dict{- str:- str}
 - 
providers¶
- Returns: - dict of capability providers, keyed by name - Return type: - dict{- str:- specs.provider.CapabilityProvider}
 - 
remove_interface(interface_name)[source]¶
- Removes a capability interface by name - Parameters: - interface_name (str) – name of the interface to remove - Raises: - KeyErrorif there is no interface by that name
 - 
remove_provider(provider_name)[source]¶
- Removes a capability provider by name - Parameters: - provider_name (str) – name of the interface to remove - Raises: - KeyErrorif there is no interface by that name
 - 
remove_semantic_interface(semantic_interface_name)[source]¶
- Removes a semantic capability interface by name - Parameters: - semantic_interface_name (str) – name of the interface to remove - Raises: - KeyErrorif there is no interface by that name
 - 
semantic_interface_names¶
- Returns: - list of semantic capability interface names - Return type: - list(- str)
 - 
semantic_interface_paths¶
- Returns: - dict of semantic capability interface spec paths, keyed by name - Return type: - dict{- str:- str}
 - 
semantic_interfaces¶
- Returns: - dict of semantic capability interfaces, keyed by name - Return type: - dict{- str:- specs.semantic_interface.SemanticCapabilityInterface}
 - 
specs¶
- Possible spec types: - specs.interface.CapabilityInterface
- specs.semantic_interface.SemanticCapabilityInterface
- specs.provider.CapabilityProvider
 - Returns: - dict of specs, keyed by name - Return type: - dict{- str: spec}
 
- 
- 
capabilities.discovery.package_index_from_package_path(package_paths)[source]¶
- Finds all packages on the given list of paths. - Iterates over the given list of paths in reverse order so that packages found in the paths at the beginning of the list get overlaid onto packages with the same name which were found in paths farther back in the list. - The resulting dictionary is keyed by the package name (so packages with duplicate names are overlaid) and the values are the - catkin_pkg.package.Packageclass- Parameters: - ros_package_path (list) – list of paths to search - Returns: - dictionary of package objects keyed by name of the package - Return type: - dict
- 
capabilities.discovery.spec_file_index_from_package_index(package_index)[source]¶
- Creates an index of spec files by package. - Takes a dict of package objects keyed by package name. - Returns a dict structured like this: - { '<package_name>': { 'package': package_obj, 'capability_interface': ['path to spec file', ...], 'capability_provider': ['path to spec file', ...], 'semantic_capability_interface': ['path to spec file', ...] }, ... } - This dict contains a dict for each package, keyed by package name. Those dicts contain the parsed package object, and a list of relative paths for spec files, separated by spec type. - Parameters: - package_index (dict) – dict of - catkin_pkg.package.Package‘s keyed by package name to be processed- Returns: - spec file index strucutre - Return type: - dict
- 
capabilities.discovery.spec_index_from_spec_file_index(spec_file_index)[source]¶
- Builds a - SpecIndexfrom a spec file index- Goes through each spec paths foreach package of the given spec file index and parses them into objects. The objects are stored in a - SpecIndexbefore being returned.- Duplicate Names are not allowed, even between different spec types and packages. Any duplicate names will be raised as a - DuplicateNameException.- Any other errors encountered during spec file processing will be returned as a list along with the - SpecIndex. Caught errors include:- capabilities.discovery.InterfaceNameNotFoundException
- capabilities.discovery.DuplicateNameException
- capabilities.specs.interface.InvalidInterface
- capabilities.specs.semantic_interface.InvalidSemanticInterface
- capabilities.specs.provider.InvalidProvide
 - Parameters: - spec_file_index (dict) – spec_file_index, see - spec_file_index_from_package_index()- Returns: - SpecIndex(which contains all the loaded specs) and a- listof any errors encountered while loading the spec files- Return type: - SpecIndex,- list(- Exception‘s)- Raises: - DuplicateNameExceptionwhen two interfaces have the same name