Artifact 3e4d9074a242b326a3ee59e8aa5c5d8761e3a8a05489908da586d84110d4c32a:

Wiki page [pluginconf] by mario on 2022-10-31 12:07:15.
D 2022-10-31T12:07:15.114
L pluginconf
N text/x-markdown
P 2f210d8bb33543bbc24dd425d00ef558c2941baca9009b12ef9f8462a38a3b4a
U mario
W 1574
## pluginconf

Is a Python implementation of [PMD](wiki/Plugin+Meta+Data).

| Project | URL                                       |
|---------|-------------------------------------------|
| Repo    | <https://fossil.include-once.org/pluginspec/tree/pluginconf> |
| API     | <https://fossil.include-once.org/pluginspec/doc/tip/html/index.html> |
| pypi    | <https://pypi.org/project/pluginconf/> |
| freshcode | - |

It [originated](http://fossil.include-once.org/streamtuner2/wiki/plugin+meta+data)
in streamtuner2. But has since gained some config dialog implementation of its own
(for modseccfg and other small tools). Simplifies configuration management, and has
a pretty terse API.

 * Only supports Python `#` comments.
 * Works from within pyz/zip packages.
 * Additionally wraps setup() and flit package builds.

### sample

    # api: python
    # title: example
    # description: shows plugin_meta() reading
    ##type: main
    # version: 0.1
    # 
    # Imagine this being a real Python script.

    import pluginconf
    meta = pluginconf.plugin_meta(filename=__file__)
    print(meta.title)

    pluginconf.plugin_base = ["plugins", "contrib"]
    print(pluginconf.all_plugin_meta())

There's also a simplified interface now ([pluginconf.bind](doc/tip/html/bind.html))
for most common use cases. Though of course it makes most sense if there are actual
script/extension downloads.

The double-escaped `##type:` is a concession to pylint. It's not actually
required, espcially if `#category:` or `#class:` could alternatively be
used for extension grouping.

Z a843ae115d4c1c156e4a7c0c1084cc47