2023-08-18 10:32:19 +00:00
|
|
|
from conans import ConanFile
|
2022-12-13 03:27:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
class MilvusConan(ConanFile):
|
|
|
|
settings = "os", "compiler", "build_type", "arch"
|
|
|
|
requires = (
|
2023-11-16 08:36:19 +00:00
|
|
|
"rocksdb/6.29.5@milvus/dev",
|
2023-08-03 09:29:07 +00:00
|
|
|
"boost/1.82.0",
|
2023-11-01 01:00:14 +00:00
|
|
|
"onetbb/2021.9.0",
|
2023-03-27 10:22:02 +00:00
|
|
|
"nlohmann_json/3.11.2",
|
2023-06-20 02:00:41 +00:00
|
|
|
"zstd/1.5.4",
|
2023-02-16 09:26:35 +00:00
|
|
|
"lz4/1.9.4",
|
|
|
|
"snappy/1.1.9",
|
|
|
|
"lzo/2.10",
|
2023-12-05 08:48:54 +00:00
|
|
|
"arrow/12.0.1",
|
2023-10-08 11:17:31 +00:00
|
|
|
"openssl/3.1.2",
|
2022-12-13 03:27:21 +00:00
|
|
|
"aws-sdk-cpp/1.9.234",
|
2023-05-28 17:05:28 +00:00
|
|
|
"googleapis/cci.20221108",
|
2022-12-13 03:27:21 +00:00
|
|
|
"benchmark/1.7.0",
|
2024-01-10 05:16:57 +00:00
|
|
|
"gtest/1.13.0",
|
2023-03-21 08:31:57 +00:00
|
|
|
"protobuf/3.21.4",
|
2022-12-13 03:27:21 +00:00
|
|
|
"rapidxml/1.13",
|
|
|
|
"yaml-cpp/0.7.0",
|
|
|
|
"marisa/0.2.6",
|
|
|
|
"zlib/1.2.13",
|
2023-01-17 06:53:42 +00:00
|
|
|
"libcurl/7.86.0",
|
2023-02-16 09:26:35 +00:00
|
|
|
"glog/0.6.0",
|
2023-05-24 05:05:26 +00:00
|
|
|
"fmt/9.1.0",
|
2023-02-16 09:26:35 +00:00
|
|
|
"gflags/2.2.2",
|
|
|
|
"double-conversion/3.2.1",
|
|
|
|
"libevent/2.1.12",
|
|
|
|
"libdwarf/20191104",
|
|
|
|
"libiberty/9.1.0",
|
|
|
|
"libsodium/cci.20220430",
|
|
|
|
"xsimd/9.0.1",
|
2023-02-20 09:08:25 +00:00
|
|
|
"xz_utils/5.4.0",
|
2023-04-03 11:22:23 +00:00
|
|
|
"prometheus-cpp/1.1.0",
|
2023-05-04 11:46:38 +00:00
|
|
|
"re2/20230301",
|
2023-12-18 04:04:42 +00:00
|
|
|
"folly/2023.10.30.05@milvus/dev",
|
2023-05-28 17:05:28 +00:00
|
|
|
"google-cloud-cpp/2.5.0@milvus/dev",
|
2023-03-21 08:31:57 +00:00
|
|
|
"opentelemetry-cpp/1.8.1.1@milvus/dev",
|
2023-07-13 07:34:33 +00:00
|
|
|
"librdkafka/1.9.1",
|
2023-12-11 13:54:37 +00:00
|
|
|
"abseil/20230125.3"
|
2022-12-13 03:27:21 +00:00
|
|
|
)
|
2023-02-07 08:12:04 +00:00
|
|
|
generators = ("cmake", "cmake_find_package")
|
2022-12-13 03:27:21 +00:00
|
|
|
default_options = {
|
2023-12-18 04:04:42 +00:00
|
|
|
"libevent:shared": True,
|
|
|
|
"double-conversion:shared": True,
|
|
|
|
"folly:shared": True,
|
2023-07-13 07:34:33 +00:00
|
|
|
"librdkafka:shared": True,
|
2023-07-21 05:21:00 +00:00
|
|
|
"librdkafka:zstd": True,
|
2023-08-29 05:58:25 +00:00
|
|
|
"librdkafka:ssl": True,
|
|
|
|
"librdkafka:sasl": True,
|
2022-12-13 03:27:21 +00:00
|
|
|
"rocksdb:shared": True,
|
2023-06-15 07:12:39 +00:00
|
|
|
"rocksdb:with_zstd": True,
|
2023-12-05 08:48:54 +00:00
|
|
|
"arrow:filesystem_layer": True,
|
2022-12-13 03:27:21 +00:00
|
|
|
"arrow:parquet": True,
|
|
|
|
"arrow:compute": True,
|
2023-08-28 10:04:26 +00:00
|
|
|
"arrow:with_re2": True,
|
2022-12-13 03:27:21 +00:00
|
|
|
"arrow:with_zstd": True,
|
2023-08-28 10:04:26 +00:00
|
|
|
"arrow:with_boost": True,
|
|
|
|
"arrow:with_thrift": True,
|
2022-12-16 10:27:24 +00:00
|
|
|
"arrow:with_jemalloc": True,
|
2023-08-28 10:04:26 +00:00
|
|
|
"arrow:shared": False,
|
2023-12-05 08:48:54 +00:00
|
|
|
"arrow:with_s3": True,
|
|
|
|
"aws-sdk-cpp:config": True,
|
2022-12-13 03:27:21 +00:00
|
|
|
"aws-sdk-cpp:text-to-speech": False,
|
|
|
|
"aws-sdk-cpp:transfer": False,
|
|
|
|
"gtest:build_gmock": False,
|
2023-03-21 08:31:57 +00:00
|
|
|
"boost:without_locale": False,
|
2023-07-27 11:49:02 +00:00
|
|
|
"glog:with_gflags": True,
|
|
|
|
"glog:shared": True,
|
2023-04-14 09:56:29 +00:00
|
|
|
"prometheus-cpp:with_pull": False,
|
2023-06-02 06:56:32 +00:00
|
|
|
"fmt:header_only": True,
|
2023-08-18 10:32:19 +00:00
|
|
|
"onetbb:tbbmalloc": False,
|
2023-08-04 10:37:08 +00:00
|
|
|
"onetbb:tbbproxy": False,
|
2023-08-18 10:32:19 +00:00
|
|
|
"openblas:shared": True,
|
|
|
|
"openblas:dynamic_arch": True,
|
2022-12-13 03:27:21 +00:00
|
|
|
}
|
|
|
|
|
2022-12-19 07:05:24 +00:00
|
|
|
def configure(self):
|
2023-02-03 09:21:53 +00:00
|
|
|
if self.settings.os == "Macos":
|
2023-03-21 08:31:57 +00:00
|
|
|
# Macos M1 cannot use jemalloc
|
2023-02-03 09:21:53 +00:00
|
|
|
if self.settings.arch not in ("x86_64", "x86"):
|
2023-02-16 09:26:35 +00:00
|
|
|
del self.options["folly"].use_sse4_2
|
2023-12-11 13:54:37 +00:00
|
|
|
# By default abseil use static link but can not be compatible with macos X86
|
|
|
|
self.options["abseil"].shared = True
|
2023-02-16 09:26:35 +00:00
|
|
|
self.options["arrow"].with_jemalloc = False
|
2023-08-18 10:32:19 +00:00
|
|
|
if self.settings.arch == "armv8":
|
|
|
|
self.options["openblas"].dynamic_arch = False
|
|
|
|
|
|
|
|
def requirements(self):
|
|
|
|
if self.settings.os != "Macos":
|
|
|
|
# MacOS does not need openblas
|
|
|
|
self.requires("openblas/0.3.23@milvus/dev")
|
2023-12-04 06:06:40 +00:00
|
|
|
self.requires("libunwind/1.7.2")
|
2022-12-19 07:05:24 +00:00
|
|
|
|
2022-12-13 03:27:21 +00:00
|
|
|
def imports(self):
|
|
|
|
self.copy("*.dylib", "../lib", "lib")
|
|
|
|
self.copy("*.dll", "../lib", "lib")
|
|
|
|
self.copy("*.so*", "../lib", "lib")
|
|
|
|
self.copy("*", "../bin", "bin")
|
2023-03-21 08:31:57 +00:00
|
|
|
self.copy("*.proto", "../include", "include")
|