Mercurial > piecrust2
view piecrust/commands/builtin/plugins.py @ 1188:a7c43131d871
bake: Fix file write flushing problem with Python 3.8+
Writing the cache files fails in Python 3.8 because it looks like flushing
behaviour has changed. We need to explicitly flush. And even then, in very
rare occurrences, it looks like it can still run into racing conditions,
so we do a very hacky and ugly "retry" loop when fetching cached data :(
author | Ludovic Chabant <ludovic@chabant.com> |
---|---|
date | Tue, 15 Jun 2021 22:36:23 -0700 |
parents | 2394fd689590 |
children |
line wrap: on
line source
import logging from piecrust.commands.base import ChefCommand logger = logging.getLogger(__name__) class PluginsCommand(ChefCommand): def __init__(self): super(PluginsCommand, self).__init__() self.name = 'plugins' self.description = "Manage the plugins for the current website." def setupParser(self, parser, app): subparsers = parser.add_subparsers() p = subparsers.add_parser( 'list', help="Lists the plugins installed in the current website.") p.add_argument( '-a', '--all', action='store_true', help=("Also list all the available plugins for the " "current environment. The installed one will have an " "asterix (*).")) p.set_defaults(sub_func=self._listPlugins) def checkedRun(self, ctx): from piecrust.pathutil import SiteNotFoundError if ctx.app.root_dir is None: raise SiteNotFoundError(theme=ctx.app.theme_site) if not hasattr(ctx.args, 'sub_func'): ctx.parser.parse_args(['plugins', '--help']) return ctx.args.sub_func(ctx) def _listPlugins(self, ctx): import pip names = {} installed_suffix = '' if ctx.args.all: prefix = 'PieCrust-' installed_packages = pip.get_installed_distributions() for plugin in installed_packages: if not plugin.project_name.startswith(prefix): continue name = plugin.project_name[len(prefix):] names[name] = False installed_suffix = '*' for plugin in ctx.app.plugin_loader.plugins: names[plugin.name] = True for name, inst in names.items(): logger.info("%s%s" % (name, installed_suffix if inst else ''))