當前位置: 首頁>>代碼示例>>Python>>正文


Python modulefinder.ModuleFinder方法代碼示例

本文整理匯總了Python中modulefinder.ModuleFinder方法的典型用法代碼示例。如果您正苦於以下問題:Python modulefinder.ModuleFinder方法的具體用法?Python modulefinder.ModuleFinder怎麽用?Python modulefinder.ModuleFinder使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在modulefinder的用法示例。


在下文中一共展示了modulefinder.ModuleFinder方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __init__

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def __init__(self, *args, **kwargs):
        # In the Python 2 stdlib, ModuleFinder is an old-style class that
        # does not inherit from object, therefore we cannot use super().
        modulefinder.ModuleFinder.__init__(self, *args, **kwargs)
        logger.Loggable.__init__(self)  # Enable logging via self.logger

        # Mapping of module object to a set of its dependencies. We store the
        # dependencies in a list instead of a set to preserve ordering. While
        # not strictly necessary, it makes testing easier when the ordering
        # of nodes in the graph can be relied on. However, we must ensure that
        # each dependency is unique, so we check before adding each new
        # dependency below. This should be a significant performance issue,
        # as we only expect each module to have a relatively small number
        # of dependencies (around 10s) so O(n) adding is acceptable.
        self._module_deps = collections.defaultdict(list)
        self._curr_caller = None
        self._module_nodes = {} 
開發者ID:Morgan-Stanley,項目名稱:testplan,代碼行數:19,代碼來源:reloader.py

示例2: import_hook

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def import_hook(self, name, caller=None, *args, **kwargs):
        """
        Hook called when ``caller`` imports module ``name``. Store off the
        caller so we can use it later.

        :param name: Name of the module being imported.
        :type name: ``str``
        :param caller: Module object that is importing ``name``.
        :type caller: ``modulefinder.Module``
        :param args: Other args are passed down to
            ``modulefinder.ModuleFinder.import_hook``
        :param kwargs: Other kwargs are passed down to
            ``modulefinder.ModuleFinder.import_hook``
        :return: Return value from ``modulefinder.ModuleFinder.import_hook``
        """
        self._curr_caller = caller
        return modulefinder.ModuleFinder.import_hook(
            self, name, caller, *args, **kwargs
        ) 
開發者ID:Morgan-Stanley,項目名稱:testplan,代碼行數:21,代碼來源:reloader.py

示例3: add_dependencies

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def add_dependencies(module_dir, filename, modules):
    finder = modulefinder.ModuleFinder()
    finder.run_script(os.path.join(module_dir, filename))
    for module in finder.modules.values():
        # if the module comes from the module_dir then process it to get
        # its dependencies.
        if os.path.dirname(str(module.__file__)) == module_dir:
            mod_filename = os.path.basename(module.__file__)
            if mod_filename == filename:
                continue
            # if this module has not already been added then add it.
            if (mod_filename.endswith('_types.py') or
                    (mod_filename.find('_types_v') != -1 and
                     mod_filename.endswith('.py'))):
                if mod_filename not in modules:
                    # add the modules that this module is dependent on
                    add_dependencies(module_dir, mod_filename, modules)
                    modules.append(mod_filename) 
開發者ID:Isilon,項目名稱:isilon_sdk,代碼行數:20,代碼來源:papi_swagger_obj_defs_builder.py

示例4: _get_modules

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def _get_modules(fn):
    finder = modulefinder.ModuleFinder()
    finder.run_script(fn)
    all = []
    for m in finder.modules.values():
        if not isinstance(m, modulefinder.Module):
            continue
        if not m.__file__:
            continue
        # skip shared object files
        if m.__file__.endswith('.so'):
            continue
        # skip mac system stuff...
        # FIXME: would need to augment with  other OS's system stuff
        if m.__file__.startswith('/Library/Frameworks'):
            continue
        all.append(m)
    return all 
開發者ID:intelxed,項目名稱:xed,代碼行數:20,代碼來源:importfinder.py

示例5: _do_test

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def _do_test(self, info, report=False):
        import_this, modules, missing, maybe_missing, source = info
        create_package(source)
        try:
            mf = modulefinder.ModuleFinder(path=TEST_PATH)
            mf.import_hook(import_this)
            if report:
                mf.report()
##                # This wouldn't work in general when executed several times:
##                opath = sys.path[:]
##                sys.path = TEST_PATH
##                try:
##                    __import__(import_this)
##                except:
##                    import traceback; traceback.print_exc()
##                sys.path = opath
##                return
            modules = set(modules)
            found = set(mf.modules.keys())
            more = list(found - modules)
            less = list(modules - found)
            # check if we found what we expected, not more, not less
            self.assertEqual((more, less), ([], []))

            # check for missing and maybe missing modules
            bad, maybe = mf.any_missing_maybe()
            self.assertEqual(bad, missing)
            self.assertEqual(maybe, maybe_missing)
        finally:
            distutils.dir_util.remove_tree(TEST_DIR) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:32,代碼來源:test_modulefinder.py

示例6: import_module

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def import_module(self, *args, **kwargs):
        """
        Called a bit further down the stack when a module is imported. Update
        the internal mapping of module dependencies.

        :param args: all args are passed down to
            ``modulefinder.ModuleFinder.import_module``
        :param kwargs: all kwargs are passed down to
            ``modulefinder.ModuleFinder.import_module``
        :return: Imported module object.
        :rtype: ``modulefinder.Module``
        """
        caller = self._curr_caller
        self._curr_caller = None
        mod = modulefinder.ModuleFinder.import_module(self, *args, **kwargs)

        if (
            (caller is not None)
            and (mod is not None)
            and _has_file(mod)
            and mod not in self._module_deps[caller]
        ):
            self.logger.debug(
                "Adding %(mod)s to %(caller)s's dependencies",
                {"mod": mod.__name__, "caller": caller.__name__},
            )
            self._module_deps[caller].append(mod)

        return mod 
開發者ID:Morgan-Stanley,項目名稱:testplan,代碼行數:31,代碼來源:reloader.py

示例7: mock_reload_env

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def mock_reload_env():
    """Set up the mock environment for unit-testing the reloader module."""
    # For unmodified files, just return a fake stat result with everything set
    # to 0.
    unmodified_stat_result = os.stat_result(0 for _ in range(10))

    # For modified files, set the st_mtime to 1 day in the future. It doesn't
    # matter that the modification time is in the future - just so long as it
    # is greater than the current time. The reloader only checks st_mtime,
    # which is the value at the 8th index passed to os.stat_result.
    one_day_hence = time.time() + 24 * 60 * 60
    modified_stat_result = os.stat_result(
        0 if i != 8 else one_day_hence for i in range(10)
    )

    def mock_stat(filepath):
        if filepath in mock_stat.modified_files:
            return modified_stat_result
        else:
            return unmodified_stat_result

    mock_stat.modified_files = set()

    reloader_patch = "testplan.runnable.interactive.reloader.reload_module"
    with mock.patch("modulefinder.ModuleFinder", new=MockModuleFinder), (
        mock.patch(reloader_patch, side_effect=lambda module: module)
    ) as mock_reload, (mock.patch("os.stat", new=mock_stat)), (
        mock.patch("sys.modules", new=MOCK_SYSMODULES)
    ):

        # Despite mocking modulefinder.ModuleFinder above, we also need to
        # swap out the real ModuleFinder with our mock one in the list of
        # bases for the GraphModuleFinder.
        reloader._GraphModuleFinder.__bases__ = (
            MockModuleFinder,
            logger.Loggable,
        )
        reload_obj = reloader.ModuleReloader()

        yield reload_obj, mock_reload, mock_stat 
開發者ID:Morgan-Stanley,項目名稱:testplan,代碼行數:42,代碼來源:test_reloader.py

示例8: add_mocks

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def add_mocks(filename):
    gp = mock.patch('ansible.module_utils.basic.get_platform').start()
    gp.return_value = 'linux'

    module_mock = mock.MagicMock()
    mocks = []
    for module_class in MODULE_CLASSES:
        mocks.append(
            mock.patch('ansible.module_utils.basic.AnsibleModule',
                       new=module_mock)
        )
    for m in mocks:
        p = m.start()
        p.side_effect = AnsibleModuleCallError()

    finder = ModuleFinder()
    try:
        finder.run_script(filename)
    except:
        pass

    sys_mock = mock.MagicMock()
    sys_mock.__version__ = '0.0.0'
    sys_mocks = []
    for module, sources in finder.badmodules.items():
        if module in sys.modules:
            continue
        if [s for s in sources if s[:7] in ['ansible', '__main_']]:
            parts = module.split('.')
            for i in range(len(parts)):
                dotted = '.'.join(parts[:i+1])
                sys.modules[dotted] = sys_mock
                sys_mocks.append(dotted)

    return module_mock, mocks, sys_mocks 
開發者ID:sivel,項目名稱:ansible-testing,代碼行數:37,代碼來源:module_args.py

示例9: _do_test

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def _do_test(self, info, report=False, debug=0, replace_paths=[]):
        import_this, modules, missing, maybe_missing, source = info
        create_package(source)
        try:
            mf = modulefinder.ModuleFinder(path=TEST_PATH, debug=debug,
                                           replace_paths=replace_paths)
            mf.import_hook(import_this)
            if report:
                mf.report()
##                # This wouldn't work in general when executed several times:
##                opath = sys.path[:]
##                sys.path = TEST_PATH
##                try:
##                    __import__(import_this)
##                except:
##                    import traceback; traceback.print_exc()
##                sys.path = opath
##                return
            modules = sorted(set(modules))
            found = sorted(mf.modules)
            # check if we found what we expected, not more, not less
            self.assertEqual(found, modules)

            # check for missing and maybe missing modules
            bad, maybe = mf.any_missing_maybe()
            self.assertEqual(bad, missing)
            self.assertEqual(maybe, maybe_missing)
        finally:
            shutil.rmtree(TEST_DIR) 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:31,代碼來源:test_modulefinder.py

示例10: _

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def _(
    module_name=each("test_apples", "apples"), rv=each(True, False),
):
    module = ModuleInfo(ModuleFinder(), module_name, False)
    assert is_test_module(module) == rv 
開發者ID:darrenburns,項目名稱:ward,代碼行數:7,代碼來源:test_collect.py

示例11: patched

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def patched(self, project_dir, spec, sack):
        """ Find python dependencies """
        for item in list(project_dir.glob('**/*.py')):
            try:
                mod = ModuleFinder()
                mod.run_script(str(item))
                for _, mod in mod.modules.items():
                    if mod.__file__ and mod.__file__.startswith("/usr/lib"):
                        spec.required_files.add(mod.__file__)
            except ImportError as ie:
                logging.warn("Exception was raised by ModuleFinder:\n" +
                             str(ie) + "\nOn file: " + str(item)) 
開發者ID:rh-lab-q,項目名稱:rpg,代碼行數:14,代碼來源:python.py

示例12: __init__

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def __init__(self, baseDir, *args, **kw):
        self.caller = None
        self.deps = {}
        self.missing = {}
        self.baseDir = baseDir
        modulefinder.ModuleFinder.__init__(self, *args, **kw) 
開發者ID:sassoftware,項目名稱:conary,代碼行數:8,代碼來源:pydeps.py

示例13: scan_code

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def scan_code(self, co, m):
        # caller is the module doing the importing; remember it for when
        # import_module is called further down the stack.
        oldCaller = self.caller
        self.caller = m.__file__
        try:
            return modulefinder.ModuleFinder.scan_code(self, co, m)
        finally:
            self.caller = oldCaller 
開發者ID:sassoftware,項目名稱:conary,代碼行數:11,代碼來源:pydeps.py

示例14: import_module

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def import_module(self, partname, fqname, parent):
        m = modulefinder.ModuleFinder.import_module(self, partname, fqname,
                                                    parent)
        if self.caller and m and m.__file__:
            self.deps.setdefault(self.caller, set()).add(m.__file__)
        return m 
開發者ID:sassoftware,項目名稱:conary,代碼行數:8,代碼來源:pydeps.py

示例15: find_imported_packages

# 需要導入模塊: import modulefinder [as 別名]
# 或者: from modulefinder import ModuleFinder [as 別名]
def find_imported_packages(filename, executable_path, debug=0, exclude_stdlib=True):
    """
    Find all imported top-level packages for a given Python file.

    We cannot assume that the version of Python being used to run Sumatra is the
    same as that used to run the simulation/analysis. Therefore we need to run
    all the dependency finding and version checking in a subprocess with the
    correct version of Python.
    """
    # Actually, we could check whether executable_path matches sys.executable, and
    # then do it in this process. On the other hand, the dependency finding
    # could run in parallel with the simulation (good for multicore): we could
    # move setting of dependencies to after the simulation, rather than having it
    # in record.register()

    # HACK Added excludes=['jinja2.asyncsupport']
    script = textwrap.dedent("""
        from modulefinder import ModuleFinder
        import sys, os
        import distutils.sysconfig
        stdlib_path = distutils.sysconfig.get_python_lib(standard_lib=True)
        stdlib_paths = (stdlib_path,
                        os.path.join(stdlib_path, "plat-mac"),
                        os.path.join(stdlib_path, "plat-mac", "lib-scriptpackages"))
        exclude_stdlib = %s
        finder = ModuleFinder(path=sys.path, debug=%d, excludes=['jinja2.asyncsupport'])
        try:
            finder.run_script("%s")
        except Exception as ex:
            sys.stdout.write("Determining dependencies failed for some Python modules.")
        top_level_packages = {}
        for name, module in finder.modules.items():
            if module.__path__ and "." not in name:
                if not(exclude_stdlib and os.path.dirname(module.__path__[0]) in stdlib_paths):
                    top_level_packages[name] = module
        sys.stdout.write("%s" + str(top_level_packages))""" % (exclude_stdlib, int(debug), filename, SENTINEL))
    return run_script(executable_path, script) 
開發者ID:open-research,項目名稱:sumatra,代碼行數:39,代碼來源:python.py


注:本文中的modulefinder.ModuleFinder方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。