diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 21:12:02 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 21:12:02 +0000 |
commit | 77e50caaf2ef81cd91075cf836fed0e75718ffb4 (patch) | |
tree | 53b7b411290b63192fc9e924a3b6b65cdf67e9d0 /debian/vendor-h2o/deps/brotli/setup.py | |
parent | Adding upstream version 1.8.3. (diff) | |
download | dnsdist-77e50caaf2ef81cd91075cf836fed0e75718ffb4.tar.xz dnsdist-77e50caaf2ef81cd91075cf836fed0e75718ffb4.zip |
Adding debian version 1.8.3-2.debian/1.8.3-2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'debian/vendor-h2o/deps/brotli/setup.py')
-rw-r--r-- | debian/vendor-h2o/deps/brotli/setup.py | 227 |
1 files changed, 227 insertions, 0 deletions
diff --git a/debian/vendor-h2o/deps/brotli/setup.py b/debian/vendor-h2o/deps/brotli/setup.py new file mode 100644 index 0000000..4540348 --- /dev/null +++ b/debian/vendor-h2o/deps/brotli/setup.py @@ -0,0 +1,227 @@ +try: + import setuptools +except: + pass +import distutils +from distutils.core import setup, Extension +from distutils.command.build_ext import build_ext +from distutils.cmd import Command +import platform +import os +import re + + +CURR_DIR = os.path.abspath(os.path.dirname(os.path.realpath(__file__))) + + +def get_version(): + """ Return BROTLI_VERSION string as defined in 'tools/version.h' file. """ + brotlimodule = os.path.join(CURR_DIR, 'tools', 'version.h') + with open(brotlimodule, 'r') as f: + for line in f: + m = re.match(r'#define\sBROTLI_VERSION\s"(.*)"', line) + if m: + return m.group(1) + return "" + + +class TestCommand(Command): + """ Run all *_test.py scripts in 'tests' folder with the same Python + interpreter used to run setup.py. + """ + + user_options = [] + + def initialize_options(self): + pass + + def finalize_options(self): + pass + + def run(self): + import sys, subprocess, glob + + test_dir = os.path.join(CURR_DIR, 'python', 'tests') + os.chdir(test_dir) + + for test in glob.glob("*_test.py"): + try: + subprocess.check_call([sys.executable, test]) + except subprocess.CalledProcessError: + raise SystemExit(1) + + +class BuildExt(build_ext): + def get_source_files(self): + filenames = build_ext.get_source_files(self) + for ext in self.extensions: + filenames.extend(ext.depends) + return filenames + + def build_extension(self, ext): + c_sources = [] + cxx_sources = [] + for source in ext.sources: + if source.endswith(".c"): + c_sources.append(source) + else: + cxx_sources.append(source) + extra_args = ext.extra_compile_args or [] + + objects = [] + for lang, sources in (("c", c_sources), ("c++", cxx_sources)): + if lang == "c++": + if self.compiler.compiler_type == "msvc": + extra_args.append("/EHsc") + + macros = ext.define_macros[:] + if platform.system() == "Darwin": + macros.append(("OS_MACOSX", "1")) + elif self.compiler.compiler_type == "mingw32": + # On Windows Python 2.7, pyconfig.h defines "hypot" as "_hypot", + # This clashes with GCC's cmath, and causes compilation errors when + # building under MinGW: http://bugs.python.org/issue11566 + macros.append(("_hypot", "hypot")) + for undef in ext.undef_macros: + macros.append((undef,)) + + objs = self.compiler.compile(sources, + output_dir=self.build_temp, + macros=macros, + include_dirs=ext.include_dirs, + debug=self.debug, + extra_postargs=extra_args, + depends=ext.depends) + objects.extend(objs) + + self._built_objects = objects[:] + if ext.extra_objects: + objects.extend(ext.extra_objects) + extra_args = ext.extra_link_args or [] + # when using GCC on Windows, we statically link libgcc and libstdc++, + # so that we don't need to package extra DLLs + if self.compiler.compiler_type == "mingw32": + extra_args.extend(['-static-libgcc', '-static-libstdc++']) + + ext_path = self.get_ext_fullpath(ext.name) + # Detect target language, if not provided + language = ext.language or self.compiler.detect_language(sources) + + self.compiler.link_shared_object( + objects, ext_path, + libraries=self.get_libraries(ext), + library_dirs=ext.library_dirs, + runtime_library_dirs=ext.runtime_library_dirs, + extra_postargs=extra_args, + export_symbols=self.get_export_symbols(ext), + debug=self.debug, + build_temp=self.build_temp, + target_lang=language) + +brotli = Extension("brotli", + sources=[ + "python/brotlimodule.cc", + "enc/backward_references.cc", + "enc/block_splitter.cc", + "enc/brotli_bit_stream.cc", + "enc/compress_fragment.cc", + "enc/compress_fragment_two_pass.cc", + "enc/encode.cc", + "enc/entropy_encode.cc", + "enc/histogram.cc", + "enc/literal_cost.cc", + "enc/metablock.cc", + "enc/static_dict.cc", + "enc/streams.cc", + "enc/utf8_util.cc", + "dec/bit_reader.c", + "dec/decode.c", + "dec/dictionary.c", + "dec/huffman.c", + "dec/state.c", + ], + depends=[ + "enc/backward_references.h", + "enc/bit_cost.h", + "enc/block_splitter.h", + "enc/brotli_bit_stream.h", + "enc/cluster.h", + "enc/command.h", + "enc/compress_fragment.h", + "enc/compress_fragment_tw_pass.h" + "enc/context.h", + "enc/dictionary.h", + "enc/dictionary_hash.h", + "enc/encode.h", + "enc/entropy_encode.h", + "enc/entropy_encode_static.h", + "enc/fast_log.h", + "enc/find_match_length.h", + "enc/hash.h", + "enc/histogram.h", + "enc/literal_cost.h", + "enc/metablock.h", + "enc/port.h", + "enc/prefix.h", + "enc/ringbuffer.h", + "enc/static_dict.h", + "enc/static_dict_lut.h", + "enc/streams.h", + "enc/transform.h", + "enc/types.h", + "enc/utf8_util.h", + "enc/write_bits.h", + "dec/bit_reader.h", + "dec/context.h", + "dec/decode.h", + "dec/dictionary.h", + "dec/huffman.h", + "dec/prefix.h", + "dec/port.h", + "dec/streams.h", + "dec/transform.h", + "dec/types.h", + "dec/state.h", + ], + language="c++", + ) + +setup( + name="Brotli", + version=get_version(), + url="https://github.com/google/brotli", + description="Python binding of the Brotli compression library", + author="Khaled Hosny", + author_email="khaledhosny@eglug.org", + license="Apache 2.0", + classifiers=[ + 'Development Status :: 4 - Beta', + 'Environment :: Console', + 'Intended Audience :: Developers', + 'License :: OSI Approved :: Apache Software License', + 'Operating System :: MacOS :: MacOS X', + 'Operating System :: Microsoft :: Windows', + 'Operating System :: POSIX :: Linux', + 'Programming Language :: C', + 'Programming Language :: C++', + 'Programming Language :: Python', + 'Programming Language :: Python :: 2', + 'Programming Language :: Python :: 2.7', + 'Programming Language :: Python :: 3', + 'Programming Language :: Python :: 3.3', + 'Programming Language :: Python :: 3.4', + 'Programming Language :: Python :: 3.5', + 'Programming Language :: Unix Shell', + 'Topic :: Software Development :: Libraries', + 'Topic :: Software Development :: Libraries :: Python Modules', + 'Topic :: System :: Archiving', + 'Topic :: System :: Archiving :: Compression', + 'Topic :: Text Processing :: Fonts', + 'Topic :: Utilities', + ], + ext_modules=[brotli], + cmdclass={ + 'build_ext': BuildExt, + 'test': TestCommand + }, +) |