##// END OF EJS Templates
packaging: add Cosmic and Disco, remove Trusty and Artful...
packaging: add Cosmic and Disco, remove Trusty and Artful - Trusty was publicly supported until 2019-04-30 - Artful was publicly supported until 2018-07-19 - Cosmic was publicly supported until 2019-07-18 - Disco will be publicly supported until 2020-01 Cosmic is officially out-of-date, but since it still may be in use, and because we didn't add it when it first came out, I think it would be nice to support it until the next time somebody decides to update this list of Ubuntu releases. Differential Revision: https://phab.mercurial-scm.org/D6761

File last commit:

r42237:675775c3 default
r43076:0363bb08 stable
Show More
__init__.py
65 lines | 2.4 KiB | text/x-python | PythonLexer
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 # Copyright (c) 2017-present, Gregory Szorc
# All rights reserved.
#
# This software may be modified and distributed under the terms
# of the BSD license. See the LICENSE file for details.
"""Python interface to the Zstandard (zstd) compression library."""
from __future__ import absolute_import, unicode_literals
# This module serves 2 roles:
#
# 1) Export the C or CFFI "backend" through a central module.
# 2) Implement additional functionality built on top of C or CFFI backend.
import os
import platform
# Some Python implementations don't support C extensions. That's why we have
# a CFFI implementation in the first place. The code here import one of our
# "backends" then re-exports the symbols from this module. For convenience,
# we support falling back to the CFFI backend if the C extension can't be
# imported. But for performance reasons, we only do this on unknown Python
# implementation. Notably, for CPython we require the C extension by default.
# Because someone will inevitably want special behavior, the behavior is
# configurable via an environment variable. A potentially better way to handle
# this is to import a special ``__importpolicy__`` module or something
# defining a variable and `setup.py` could write the file with whatever
# policy was specified at build time. Until someone needs it, we go with
# the hacky but simple environment variable approach.
_module_policy = os.environ.get('PYTHON_ZSTANDARD_IMPORT_POLICY', 'default')
if _module_policy == 'default':
if platform.python_implementation() in ('CPython',):
from zstd import *
backend = 'cext'
elif platform.python_implementation() in ('PyPy',):
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 backend = 'cffi'
else:
try:
from zstd import *
backend = 'cext'
except ImportError:
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 backend = 'cffi'
elif _module_policy == 'cffi_fallback':
try:
from zstd import *
backend = 'cext'
except ImportError:
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 backend = 'cffi'
elif _module_policy == 'cext':
from zstd import *
backend = 'cext'
elif _module_policy == 'cffi':
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 backend = 'cffi'
else:
raise ImportError('unknown module import policy: %s; use default, cffi_fallback, '
'cext, or cffi' % _module_policy)
Gregory Szorc
zstandard: vendor python-zstandard 0.10.1...
r40157
# Keep this in sync with python-zstandard.h.
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 __version__ = '0.11.0'