123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- set_project("zlib")
- set_languages("c++11")
- add_rules("mode.debug", "mode.release")
- target("zlib")
- set_kind("static")
- if not is_plat("windows") then
- set_basename("z")
- end
- if is_plat("linux") then
- add_syslinks("pthread")
- end
- add_files("adler32.c", "compress.c", "cpu_features.c", "crc32.c", "deflate.c")
- add_files("gzclose.c", "gzlib.c", "gzread.c", "gzwrite.c")
- add_files("infback.c", "inffast.c", "inftrees.c", "trees.c", "uncompr.c", "zutil.c")
- add_headerfiles("zlib.h", "zconf.h", "chromeconf.h", "deflate.h", "inffast.h", "inffixed.h", "inflate.h", "inftrees.h", "zutil.h")
- add_includedirs(".", {public = true})
- -- SIMD settings
- on_load(function (target)
- import("core.tool.toolchain")
- if is_plat("android") then
- local ndk = toolchain.load("ndk"):config("ndk")
- target:add("includedirs", path.join(ndk, "sources", "android", "cpufeatures"))
- target:add("files", path.join(ndk, "sources", "android", "cpufeatures", "cpu-features.c"))
- end
- end)
- if is_plat("cross") then
- add_defines("CPU_NO_SIMD")
- add_files("inflate.c")
- elseif is_arch("i386", "x86", "x64", "x86_64") then
- add_defines("CRC32_SIMD_SSE42_PCLMUL", "DEFLATE_FILL_WINDOW_SSE2")
- add_files("crc32_simd.c", "crc_folding.c", "fill_window_sse.c")
- add_defines("ADLER32_SIMD_SSSE3", "INFLATE_CHUNK_SIMD_SSE2")
- add_files("adler32_simd.c", "contrib/optimizations/inffast_chunk.c", "contrib/optimizations/inflate.c")
- if is_plat("windows") then
- add_vectorexts("avx")
- else
- add_cflags("-msse4.2", "-mssse3", "-mpclmul")
- end
- add_defines(is_plat("windows") and "X86_WINDOWS" or "X86_NOT_WINDOWS")
- if is_arch(".+64") then
- add_defines("INFLATE_CHUNK_READ_64LE")
- end
- -- arm optimization disabled on windows, see https://github.com/xmake-mirror/chromium_zlib/blob/zlib/BUILD.gn#L73.
- elseif is_arch("arm.*") and not is_plat("windows") then
- add_defines("ADLER32_SIMD_NEON", "INFLATE_CHUNK_SIMD_NEON")
- add_files("adler32_simd.c", "contrib/optimizations/inffast_chunk.c", "contrib/optimizations/inflate.c")
- if is_arch(".+64") then
- add_defines("INFLATE_CHUNK_READ_64LE")
- end
- -- ARM v8 architecture
- add_defines("CRC32_ARMV8_CRC32")
- if not is_plat("windows", "macosx", "android", "iphoneos") then
- add_cflags("-march=armv8-a+aes+crc")
- end
- if is_plat("android") then
- add_defines("ARMV8_OS_ANDROID")
- elseif is_plat("linux") then
- add_defines("ARMV8_OS_LINUX")
- elseif is_plat("windows") then
- add_defines("ARMV8_OS_WINDOWS")
- elseif is_plat("macosx") then
- add_defines("ARMV8_OS_MACOS")
- elseif is_plat("iphoneos") then
- add_defines("ARMV8_OS_IOS")
- else
- os.raise("Unsupported ARM OS")
- end
- add_files("crc32_simd.c")
- else
- add_defines("CPU_NO_SIMD")
- add_files("inflate.c")
- end
- target("minizip")
- set_kind("static")
- add_deps("zlib")
- add_files("contrib/minizip/ioapi.c",
- "contrib/minizip/unzip.c",
- "contrib/minizip/zip.c")
- add_headerfiles("contrib/minizip/ioapi.h",
- "contrib/minizip/unzip.h",
- "contrib/minizip/zip.h")
- if is_plat("windows") then
- add_files("contrib/minizip/iowin32.c")
- add_headerfiles("contrib/minizip/iowin32.h")
- elseif is_plat("macosx", "android", "iphoneos") then
- add_defines("USE_FILE32API")
- end
- target("compression_utils_portable")
- set_kind("static")
- add_deps("zlib")
- add_files("google/compression_utils_portable.cc")
- add_headerfiles("google/compression_utils_portable.h")
|