File: driver.rst

package info (click to toggle)
thunderbird 1%3A140.8.0esr-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,625,268 kB
  • sloc: cpp: 7,722,628; javascript: 5,903,187; ansic: 3,901,239; python: 1,414,013; xml: 654,008; asm: 462,286; java: 180,927; sh: 113,543; makefile: 20,463; perl: 14,288; objc: 13,059; yacc: 4,583; pascal: 3,352; lex: 1,720; ruby: 1,222; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 70; csh: 10
file content (32 lines) | stat: -rw-r--r-- 907 bytes parent folder | download | duplicates (19)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
.. _mach_driver:

=======
Drivers
=======

Entry Points
============

It is possible to use setuptools' entry points to load commands
directly from python packages. A mach entry point is a function which
returns a list of files or directories containing mach command
providers. e.g.:

.. code-block:: python

   def list_providers():
       providers = []
       here = os.path.abspath(os.path.dirname(__file__))
       for p in os.listdir(here):
           if p.endswith('.py'):
               providers.append(os.path.join(here, p))
       return providers

See http://pythonhosted.org/setuptools/setuptools.html#dynamic-discovery-of-services-and-plugins
for more information on creating an entry point. To search for entry
point plugins, you can call
:py:meth:`mach.command_util.load_commands_from_entry_point`. e.g.:

.. code-block:: python

   load_commands_from_entry_point("mach.external.providers")