# # Helper module to build macOS version of various source ports # Copyright (C) 2020-2023 Alexey Lysiuk # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # import os import subprocess from ..state import BuildState from . import base class DzipTarget(base.CMakeStaticDependencyTarget): def __init__(self, name='dzip'): super().__init__(name) def prepare_source(self, state: BuildState): state.download_source( 'https://github.com/kugelrund/dzip/archive/refs/tags/v3.1.tar.gz', '9f057e35ef5ddda1a0911b8f877a41b2934669377cb053b45364ddb72716b520') class GlslangTarget(base.CMakeStaticDependencyTarget): # Build with --os-version-x64=10.15 command line option def __init__(self, name='glslang'): super().__init__(name) def prepare_source(self, state: BuildState): state.download_source( 'https://github.com/KhronosGroup/glslang/archive/refs/tags/13.0.0.tar.gz', 'bcda732434f829aa74414ea0e06d329ec8ac28637c38a0de45e17c8fd25a4715') def configure(self, state: BuildState): args = ('python3', 'update_glslang_sources.py') subprocess.run(args, check=True, cwd=state.source, env=state.environment) state.validate_minimum_version('10.15') # SPIRV-Tools uses state.options['ENABLE_CTEST'] = 'NO' super().configure(state) def post_build(self, state: BuildState): super().post_build(state) # Remove shared library lib_path = state.install_path / 'lib' os.unlink(lib_path / 'libSPIRV-Tools-shared.dylib') lib_cmake_path = lib_path / 'cmake' spirv_tools_module = lib_cmake_path / 'SPIRV-Tools/SPIRV-ToolsTarget-release.cmake' self.keep_module_target(state, 'SPIRV-Tools-static', (spirv_tools_module,)) # Remove deprecated files with absolute paths in them for entry in os.listdir(lib_cmake_path): if entry.endswith('.cmake'): os.unlink(lib_cmake_path / entry) class P7ZipTarget(base.CMakeTarget): def __init__(self, name='p7zip'): super().__init__(name) self.src_root = 'CPP/7zip/CMAKE/7za' def prepare_source(self, state: BuildState): state.download_source( 'https://github.com/p7zip-project/p7zip/archive/refs/tags/v17.04.tar.gz', 'ea029a2e21d2d6ad0a156f6679bd66836204aa78148a4c5e498fe682e77127ef') def detect(self, state: BuildState) -> bool: return state.has_source_file('CPP/7zip/CMAKE/CMakeLists.txt') \ and state.has_source_file('C/fast-lzma2/fast-lzma2.h') def post_build(self, state: BuildState): self.copy_to_bin(state, '7za') class PbzxTarget(base.SingleExeCTarget): def __init__(self, name='pbzx'): super().__init__(name) self.options = ('pbzx.c', '-lxar', '-llzma') def prepare_source(self, state: BuildState): state.download_source( 'https://github.com/nrosenstein-stuff/pbzx/archive/refs/tags/v1.0.2.tar.gz', '33db3cf9dc70ae704e1bbfba52c984f4c6dbfd0cc4449fa16408910e22b4fd90', 'pbzx-xar-content') def detect(self, state: BuildState) -> bool: return state.has_source_file('pbzx.c') class QPakManTarget(base.CMakeTarget): def __init__(self, name='qpakman'): super().__init__(name) def prepare_source(self, state: BuildState): state.download_source( 'https://github.com/bunder/qpakman/archive/refs/tags/v0.67.tar.gz', '0b2cfc0e66a6ea3f0e332409254e06f78f5bb9b47f6b134b90681468d701d421') def post_build(self, state: BuildState): self.copy_to_bin(state) class Radare2Target(base.MesonTarget): def __init__(self, name='radare2'): super().__init__(name) self.configure_prefix = False def prepare_source(self, state: BuildState): state.download_source( 'https://github.com/radareorg/radare2/archive/refs/tags/5.8.4.tar.gz', '8ea45bd82e5ea37e270ca14ac2a6f947c647a24f9de9e18bf8cebc71c0816dcd', patches='radare2-fix-build') def detect(self, state: BuildState) -> bool: return state.has_source_file('man/radare2.1') def configure(self, state: BuildState): option = state.options option['blob'] = 'true' option['enable_tests'] = 'false' option['enable_r2r'] = 'false' option['r2_gittip'] = 'ab809417aa6b676922f95cf77861924eb90e7ef2' option['r2_version_commit'] = '1' super().configure(state) def post_build(self, state: BuildState): super().post_build(state) bin_path = state.install_path / 'bin' os.unlink(bin_path / 'r2blob.static') os.rename(bin_path / 'r2blob', bin_path / 'radare2') class RizinTarget(base.MesonTarget): def __init__(self, name='rizin'): super().__init__(name) def prepare_source(self, state: BuildState): state.download_source( 'https://github.com/rizinorg/rizin/releases/download/v0.6.2/rizin-src-v0.6.2.tar.xz', 'e29a00a3e22004bdd10146d286b1cce0e06196d41aae4729aafc9d78321ff86b') def detect(self, state: BuildState) -> bool: return state.has_source_file('binrz/man/rizin.1') def configure(self, state: BuildState): option = state.options option['blob'] = 'true' option['enable_tests'] = 'false' option['enable_rz_test'] = 'false' option['local'] = 'enabled' option['portable'] = 'true' super().configure(state) class SeverZipTarget(base.MakeTarget): # Build with --os-version-x64=10.13 command line option def __init__(self, name='7zip'): super().__init__(name) self.src_root = 'CPP/7zip/Bundles/Alone2' def prepare_source(self, state: BuildState): state.download_source( 'https://7-zip.org/a/7z2301-src.tar.xz', '356071007360e5a1824d9904993e8b2480b51b570e8c9faf7c0f58ebe4bf9f74', patches='7zip-fix-errors') def detect(self, state: BuildState) -> bool: return state.has_source_file('CPP/7zip/cmpl_mac_arm64.mak') def configure(self, state: BuildState): state.validate_minimum_version('10.13') super().configure(state) def build(self, state: BuildState): environment = state.environment mak_suffix = self._arch_suffix(state) opts = state.options opts['-f'] = None opts[f'../../cmpl_mac_{mak_suffix}.mak'] = None opts['CFLAGS_BASE_LIST'] = environment['CFLAGS'] + ' -c' opts['LDFLAGS_STATIC_2'] = environment['LDFLAGS'] super().build(state) def post_build(self, state: BuildState): build_suffix = self._arch_suffix(state) self.copy_to_bin(state, f'{self.src_root}/b/m_{build_suffix}/7zz', '7zz') @staticmethod def _arch_suffix(state: BuildState): arch = state.architecture() return 'x64' if arch == 'x86_64' else arch class UnrarTarget(base.MakeTarget): def __init__(self, name='unrar'): super().__init__(name) def prepare_source(self, state: BuildState): state.download_source( 'https://www.rarlab.com/rar/unrarsrc-6.0.7.tar.gz', 'a7029942006cbcced3f3b7322ec197683f8e7be408972ca08099b196c038f518') def post_build(self, state: BuildState): self.copy_to_bin(state) def detect(self, state: BuildState) -> bool: return state.has_source_file('rar.hpp') class ZipTarget(base.SingleExeCTarget): def __init__(self, name='zip'): super().__init__(name) self.options = ( '-I.', '-DUNIX', '-DBZIP2_SUPPORT', '-DLARGE_FILE_SUPPORT', '-DUNICODE_SUPPORT', '-DHAVE_DIRENT_H', '-DHAVE_TERMIOS_H', '-lbz2', 'crc32.c', 'crypt.c', 'deflate.c', 'fileio.c', 'globals.c', 'trees.c', 'ttyio.c', 'unix/unix.c', 'util.c', 'zip.c', 'zipfile.c', 'zipup.c', ) def prepare_source(self, state: BuildState): state.download_source( 'https://downloads.sourceforge.net/project/infozip/Zip%203.x%20%28latest%29/3.0/zip30.tar.gz', 'f0e8bb1f9b7eb0b01285495a2699df3a4b766784c1765a8f1aeedf63c0806369', patches='zip-fix-misc') def detect(self, state: BuildState) -> bool: return state.has_source_file('zip.h')