diff env/lib/python3.7/site-packages/boto/plugin.py @ 5:9b1c78e6ba9c draft default tip

"planemo upload commit 6c0a8142489327ece472c84e558c47da711a9142"
author shellac
date Mon, 01 Jun 2020 08:59:25 -0400
parents 79f47841a781
children
line wrap: on
line diff
--- a/env/lib/python3.7/site-packages/boto/plugin.py	Thu May 14 16:47:39 2020 -0400
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,93 +0,0 @@
-# Copyright 2010 Google Inc.
-#
-# Permission is hereby granted, free of charge, to any person obtaining a
-# copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish, dis-
-# tribute, sublicense, and/or sell copies of the Software, and to permit
-# persons to whom the Software is furnished to do so, subject to the fol-
-# lowing conditions:
-#
-# The above copyright notice and this permission notice shall be included
-# in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
-# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
-# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
-# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
-# IN THE SOFTWARE.
-
-
-"""
-Implements plugin related api.
-
-To define a new plugin just subclass Plugin, like this.
-
-class AuthPlugin(Plugin):
-    pass
-
-Then start creating subclasses of your new plugin.
-
-class MyFancyAuth(AuthPlugin):
-    capability = ['sign', 'vmac']
-
-The actual interface is duck typed.
-"""
-
-import glob
-import imp
-import os.path
-
-
-class Plugin(object):
-    """Base class for all plugins."""
-
-    capability = []
-
-    @classmethod
-    def is_capable(cls, requested_capability):
-        """Returns true if the requested capability is supported by this plugin
-        """
-        for c in requested_capability:
-            if c not in cls.capability:
-                return False
-        return True
-
-
-def get_plugin(cls, requested_capability=None):
-    if not requested_capability:
-        requested_capability = []
-    result = []
-    for handler in cls.__subclasses__():
-        if handler.is_capable(requested_capability):
-            result.append(handler)
-    return result
-
-
-def _import_module(filename):
-    (path, name) = os.path.split(filename)
-    (name, ext) = os.path.splitext(name)
-
-    (file, filename, data) = imp.find_module(name, [path])
-    try:
-        return imp.load_module(name, file, filename, data)
-    finally:
-        if file:
-            file.close()
-
-_plugin_loaded = False
-
-
-def load_plugins(config):
-    global _plugin_loaded
-    if _plugin_loaded:
-        return
-    _plugin_loaded = True
-
-    if not config.has_option('Plugin', 'plugin_directory'):
-        return
-    directory = config.get('Plugin', 'plugin_directory')
-    for file in glob.glob(os.path.join(directory, '*.py')):
-        _import_module(file)