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


Python distutils.extension方法代碼示例

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


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

示例1: get_dllextension

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def get_dllextension() -> str:
    """Return the DLL file extension for the current operating system.

    The returned value depends on the response of function |platform.system|
    of module |platform|.  |get_dllextension| returns `.pyd` if
    |platform.system| returns the string "windows" and `.so` for
    all other strings:

    >>> from hydpy.cythons.modelutils import get_dllextension
    >>> import platform
    >>> from unittest import mock
    >>> with mock.patch.object(
    ...     platform, 'system', side_effect=lambda: 'Windows') as mocked:
    ...     get_dllextension()
    '.pyd'
    >>> with mock.patch.object(
    ...     platform, 'system', side_effect=lambda: 'Linux') as mocked:
    ...     get_dllextension()
    '.so'
    """
    if platform.system().lower() == 'windows':
        return '.pyd'
    return '.so' 
開發者ID:hydpy-dev,項目名稱:hydpy,代碼行數:25,代碼來源:modelutils.py

示例2: write

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def write(self) -> None:
        """Collect the source code and write it into a Cython extension
        file ("pyx")."""
        with open(self.pyxpath, 'w') as pxf:
            print('    * cython options')
            pxf.write(repr(self.cythonoptions))
            print('    * C imports')
            pxf.write(repr(self.cimports))
            print('    * constants (if defined)')
            pxf.write(repr(self.constants))
            print('    * parameter classes')
            pxf.write(repr(self.parameters))
            print('    * sequence classes')
            pxf.write(repr(self.sequences))
            print('    * numerical parameters')
            pxf.write(repr(self.numericalparameters))
            print('    * model class')
            print('        - model attributes')
            pxf.write(repr(self.modeldeclarations))
            print('        - standard functions')
            pxf.write(repr(self.modelstandardfunctions))
            print('        - numeric functions')
            pxf.write(repr(self.modelnumericfunctions))
            print('        - additional functions')
            pxf.write(repr(self.modeluserfunctions)) 
開發者ID:hydpy-dev,項目名稱:hydpy,代碼行數:27,代碼來源:modelutils.py

示例3: __init__

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def __init__(self, name):
        # don't invoke the original build_ext for this special extension
        Extension.__init__(self, name, sources=[]) 
開發者ID:Azure,項目名稱:azure-uamqp-python,代碼行數:5,代碼來源:setup.py

示例4: test_setuptools_compat

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def test_setuptools_compat(self):
        import distutils.core, distutils.extension, distutils.command.build_ext
        saved_ext = distutils.extension.Extension
        try:
            # on some platforms, it loads the deprecated "dl" module
            test_support.import_module('setuptools_build_ext', deprecated=True)

            # theses import patch Distutils' Extension class
            from setuptools_build_ext import build_ext as setuptools_build_ext
            from setuptools_extension import Extension

            etree_c = os.path.join(self.tmp_dir, 'lxml.etree.c')
            etree_ext = Extension('lxml.etree', [etree_c])
            dist = Distribution({'name': 'lxml', 'ext_modules': [etree_ext]})
            cmd = setuptools_build_ext(dist)
            cmd.ensure_finalized()
            cmd.inplace = 1
            cmd.distribution.package_dir = {'': 'src'}
            cmd.distribution.packages = ['lxml', 'lxml.html']
            curdir = os.getcwd()
            ext = sysconfig.get_config_var("SO")
            wanted = os.path.join(curdir, 'src', 'lxml', 'etree' + ext)
            path = cmd.get_ext_fullpath('lxml.etree')
            self.assertEqual(wanted, path)
        finally:
            # restoring Distutils' Extension class otherwise its broken
            distutils.extension.Extension = saved_ext
            distutils.core.Extension = saved_ext
            distutils.command.build_ext.Extension = saved_ext 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:31,代碼來源:test_build_ext.py

示例5: test_deployment_target_default

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def test_deployment_target_default(self):
        # Issue 9516: Test that, in the absence of the environment variable,
        # an extension module is compiled with the same deployment target as
        #  the interpreter.
        self._try_compile_deployment_target('==', None) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:7,代碼來源:test_build_ext.py

示例6: test_deployment_target_too_low

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def test_deployment_target_too_low(self):
        # Issue 9516: Test that an extension module is not allowed to be
        # compiled with a deployment target less than that of the interpreter.
        self.assertRaises(DistutilsPlatformError,
            self._try_compile_deployment_target, '>', '10.1') 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:7,代碼來源:test_build_ext.py

示例7: test_deployment_target_higher_ok

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def test_deployment_target_higher_ok(self):
        # Issue 9516: Test that an extension module can be compiled with a
        # deployment target higher than that of the interpreter: the ext
        # module may depend on some newer OS feature.
        deptarget = sysconfig.get_config_var('MACOSX_DEPLOYMENT_TARGET')
        if deptarget:
            # increment the minor version number (i.e. 10.6 -> 10.7)
            deptarget = [int(x) for x in deptarget.split('.')]
            deptarget[-1] += 1
            deptarget = '.'.join(str(i) for i in deptarget)
            self._try_compile_deployment_target('<', deptarget) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:13,代碼來源:test_build_ext.py

示例8: _get_unpatched

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def _get_unpatched(cls):
    """Protect against re-patching the distutils if reloaded

    Also ensures that no other distutils extension monkeypatched the distutils
    first.
    """
    while cls.__module__.startswith('setuptools'):
        cls, = cls.__bases__
    if not cls.__module__.startswith('distutils'):
        raise AssertionError(
            "distutils has already been patched by %r" % cls
        )
    return cls 
開發者ID:ktraunmueller,項目名稱:Computable,代碼行數:15,代碼來源:setuptools_extension.py

示例9: compile_

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def compile_(self) -> None:
        """Translate Cython code to C code and compile it."""
        argv = copy.deepcopy(sys.argv)
        sys.argv = [sys.argv[0], 'build_ext', '--build-lib='+self.buildpath]
        exc_modules = [distutils.extension.Extension(
            'hydpy.cythons.autogen.'+self.cyname,
            [self.pyxfilepath], extra_compile_args=['-O2'])]
        distutils.core.setup(ext_modules=build.cythonize(exc_modules),
                             include_dirs=[numpy.get_include()])
        sys.argv = argv 
開發者ID:hydpy-dev,項目名稱:hydpy,代碼行數:12,代碼來源:modelutils.py

示例10: __str__

# 需要導入模塊: import distutils [as 別名]
# 或者: from distutils import extension [as 別名]
def __str__(self):
        import pybind11

        return pybind11.get_include(self.user)


# build C extension for image source model 
開發者ID:LCAV,項目名稱:pyroomacoustics,代碼行數:9,代碼來源:setup.py


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