Merge pull request #715 from kiwix/win-xapian
This commit is contained in:
commit
ad72464794
|
@ -12,7 +12,7 @@ jobs:
|
|||
runs-on: windows-latest
|
||||
env:
|
||||
OS_NAME: windows
|
||||
COMPILE_CONFIG: native_dyn
|
||||
COMPILE_CONFIG: native_mixed
|
||||
HOME: 'C:\\Users\\runneradmin'
|
||||
steps:
|
||||
- name: Checkout code
|
||||
|
|
|
@ -35,10 +35,10 @@ class NativeDyn(NativeConfigInfo):
|
|||
class NativeStatic(NativeConfigInfo):
|
||||
name = "native_static"
|
||||
static = True
|
||||
compatible_hosts = ["fedora", "debian", "Darwin", "almalinux"]
|
||||
compatible_hosts = ["fedora", "debian", "Darwin", "almalinux", "Windows"]
|
||||
|
||||
|
||||
class NativeMixed(MixedMixin("native_static"), NativeConfigInfo):
|
||||
name = "native_mixed"
|
||||
static = False
|
||||
compatible_hosts = ["fedora", "debian", "Darwin", "almalinux"]
|
||||
compatible_hosts = ["fedora", "debian", "Darwin", "almalinux", "Windows"]
|
||||
|
|
|
@ -14,7 +14,7 @@ class AllBaseDependencies(Dependency):
|
|||
@classmethod
|
||||
def get_dependencies(cls, configInfo, allDeps):
|
||||
if neutralEnv("distname") == "Windows":
|
||||
return ["zlib", "zstd", "icu4c", "zim-testing-suite"]
|
||||
return ["zlib", "zstd", "icu4c", "zim-testing-suite", "xapian-core"]
|
||||
if configInfo.build == "wasm" or environ.get("OS_NAME") == "manylinux":
|
||||
return ["zlib", "lzma", "zstd", "icu4c", "xapian-core"]
|
||||
|
||||
|
|
|
@ -39,6 +39,7 @@ class Icu(Dependency):
|
|||
topdir=None,
|
||||
name=self.source_dir,
|
||||
)
|
||||
if platform.system() != "Windows":
|
||||
shutil.rmtree(
|
||||
pj(neutralEnv("source_dir"), self.source_dir, "source", "data")
|
||||
)
|
||||
|
|
|
@ -23,7 +23,7 @@ class Libzim(Dependency):
|
|||
@classmethod
|
||||
def get_dependencies(cls, configInfo, allDeps):
|
||||
if neutralEnv("distname") == "Windows":
|
||||
return ["zstd", "icu4c", "zim-testing-suite"]
|
||||
return ["zstd", "xapian-core", "icu4c", "zim-testing-suite"]
|
||||
deps = ["lzma", "zstd", "xapian-core", "icu4c"]
|
||||
if configInfo.name not in ("flatpak", "wasm"):
|
||||
deps.append("zim-testing-suite")
|
||||
|
@ -33,7 +33,7 @@ class Libzim(Dependency):
|
|||
def configure_options(self):
|
||||
configInfo = self.buildEnv.configInfo
|
||||
if neutralEnv("distname") == "Windows":
|
||||
yield "-Dwith_xapian=false"
|
||||
yield "-Dwith_xapian_fuller=false"
|
||||
yield "-Dwerror=false"
|
||||
if configInfo.build == "android":
|
||||
yield "-DUSE_BUFFER_HEADER=false"
|
||||
|
|
|
@ -1,12 +1,34 @@
|
|||
from .base import Dependency, ReleaseDownload, MakeBuilder
|
||||
from .base import Dependency, GitClone, ReleaseDownload, MakeBuilder, MesonBuilder
|
||||
|
||||
from kiwixbuild.utils import Remotefile
|
||||
from kiwixbuild._global import neutralEnv
|
||||
|
||||
import platform
|
||||
|
||||
|
||||
class Xapian(Dependency):
|
||||
name = "xapian-core"
|
||||
|
||||
if platform.system() == "Windows":
|
||||
|
||||
class Source(GitClone):
|
||||
git_remote = "https://github.com/openzim/xapian-meson.git"
|
||||
git_dir = "xapian-core"
|
||||
|
||||
class Builder(MesonBuilder):
|
||||
configure_options = [
|
||||
"-Denable-sse=false",
|
||||
"-Denable-backend-chert=false",
|
||||
"-Denable-backend-remote=false",
|
||||
]
|
||||
subsource_dir = "xapian-core"
|
||||
|
||||
@classmethod
|
||||
def get_dependencies(cls, configInfo, allDeps):
|
||||
return ["zlib"]
|
||||
|
||||
else:
|
||||
|
||||
class Source(ReleaseDownload):
|
||||
archive = Remotefile(
|
||||
"xapian-core-1.4.23.tar.xz",
|
||||
|
@ -22,16 +44,14 @@ class Xapian(Dependency):
|
|||
]
|
||||
configure_env = {
|
||||
"_format_LDFLAGS": "{env.LDFLAGS} -L{buildEnv.install_dir}/{buildEnv.libprefix}",
|
||||
"_format_CXXFLAGS": "{env.CXXFLAGS} -O3 -I{buildEnv.install_dir}/include",
|
||||
"_format_CXXFLAGS": "{env.CXXFLAGS} -I{buildEnv.install_dir}/include",
|
||||
}
|
||||
|
||||
@classmethod
|
||||
def get_dependencies(cls, configInfo, allDeps):
|
||||
if neutralEnv("distname") == "Windows":
|
||||
return ["zlib"]
|
||||
deps = ["zlib", "lzma"]
|
||||
if (
|
||||
configInfo.build in ("win32", "wasm")
|
||||
configInfo.build in ("win32", "win64", "wasm")
|
||||
or neutralEnv("distname") == "Darwin"
|
||||
):
|
||||
return deps
|
||||
|
|
|
@ -39,7 +39,7 @@ release_versions = {
|
|||
|
||||
# This is the "version" of the whole base_deps_versions dict.
|
||||
# Change this when you change base_deps_versions.
|
||||
base_deps_meta_version = "01"
|
||||
base_deps_meta_version = "02"
|
||||
|
||||
base_deps_versions = {
|
||||
"zlib": "1.2.12",
|
||||
|
@ -47,7 +47,7 @@ base_deps_versions = {
|
|||
"zstd": "1.5.2",
|
||||
"docoptcpp": "0.6.2",
|
||||
"uuid": "1.43.4",
|
||||
"xapian-core": "1.4.23",
|
||||
"xapian-core": "1.4.26",
|
||||
"mustache": "4.1",
|
||||
"pugixml": "1.2",
|
||||
"libmicrohttpd": "0.9.76",
|
||||
|
|
Loading…
Reference in New Issue