PORTNAME=	polars-runtime
DISTVERSIONPREFIX=	py-
DISTVERSION=	1.36.1
CATEGORIES=	misc
#MASTER_SITES=	PYPI
PKGNAMEPREFIX=	${PYTHON_PKGNAMEPREFIX}

MAINTAINER=	yuri@FreeBSD.org
COMMENT=	Runtime binaries for Polars, the DataFrame library
WWW=		https://github.com/pola-rs/polars

LICENSE=	MIT
LICENSE_FILE=	${WRKSRC}/LICENSE

FLAVORS=	compat 32 64 # runtime values; it might look hackish to define different types of flavors in this Python port, but Polars needs all of them to be installed and there should be no problems as long as files are installed into proper locations
FLAVOR?=	${FLAVORS:[1]}
${FLAVOR}_PKGNAMESUFFIX=	-${FLAVOR} # there's no default runtime for Polars, all of them are needed

BUILD_DEPENDS=	${PYTHON_PKGNAMEPREFIX}maturin>=1.3.2:devel/py-maturin@${PY_FLAVOR} \
		rust-nightly>0:lang/rust-nightly
LIB_DEPENDS=	libzstd.so:archivers/zstd
RUN_DEPENDS=	${PYTHON_PKGNAMEPREFIX}altair>=5.4.0:graphics/py-altair@${PY_FLAVOR} \
		${PYTHON_PKGNAMEPREFIX}matplotlib>0:math/py-matplotlib@${PY_FLAVOR}

USES=		cargo pkgconfig python
USE_PYTHON=	pep517 noflavors # autoplist is broken

USE_GITHUB=	yes
GH_ACCOUNT=	pola-rs
GH_PROJECT=	polars

# the below RUSTFLAGS builds the polars package that fails in the run-time with the TLS error about insufficient TLS memory
# this RUSTFLAGS is replaced with ugly patches in files/ that allow to build a working package
# the reason is unclear, needs to be investigated
RUSTFLAGS=	--cfg allocator=\"default\" # other choices are "default" and "jemalloc" (jemalloc is broken due to the conflict with system allocator)
MAKE_ENV+=	RUSTFLAGS="${RUSTFLAGS}" # pass RUSTFLAGS to rustc via python's "build" module and maturin

PEP517_INSTALL_CMD=	${PYTHON_CMD} -m installer --destdir ${STAGEDIR} --prefix ${PREFIX} ${BUILD_WRKSRC}/dist/${PORTNAME:C|[-_]+|_|g}_${FLAVOR}-${DISTVERSION}*.whl

CARGO_BUILDDEP=	no
CARGO_CRATES=	addr2line-0.24.2 \
		adler2-2.0.1 \
		adler32-1.2.0 \
		ahash-0.8.12 \
		aho-corasick-1.1.3 \
		alloc-no-stdlib-2.0.4 \
		alloc-stdlib-0.2.2 \
		allocator-api2-0.2.21 \
		android-tzdata-0.1.1 \
		android_system_properties-0.1.5 \
		anyhow-1.0.98 \
		apache-avro-0.17.0 \
		arboard-3.6.0 \
		argminmax-0.6.3 \
		array-init-cursor-0.2.1 \
		arrayref-0.3.9 \
		arrayvec-0.7.6 \
		async-channel-2.4.0 \
		async-stream-0.3.6 \
		async-stream-impl-0.3.6 \
		async-trait-0.1.88 \
		atoi_simd-0.16.1 \
		atomic-waker-1.1.2 \
		autocfg-1.5.0 \
		avro-schema-0.3.0 \
		aws-config-1.8.1 \
		aws-credential-types-1.2.3 \
		aws-lc-rs-1.13.1 \
		aws-lc-sys-0.29.0 \
		aws-runtime-1.5.8 \
		aws-sdk-s3-1.96.0 \
		aws-sdk-sso-1.74.0 \
		aws-sdk-ssooidc-1.75.0 \
		aws-sdk-sts-1.76.0 \
		aws-sigv4-1.3.3 \
		aws-smithy-async-1.2.5 \
		aws-smithy-checksums-0.60.13 \
		aws-smithy-checksums-0.63.4 \
		aws-smithy-eventstream-0.60.9 \
		aws-smithy-http-0.60.12 \
		aws-smithy-http-0.62.1 \
		aws-smithy-http-client-1.0.6 \
		aws-smithy-json-0.61.4 \
		aws-smithy-observability-0.1.3 \
		aws-smithy-query-0.60.7 \
		aws-smithy-runtime-1.8.3 \
		aws-smithy-runtime-api-1.8.1 \
		aws-smithy-types-1.3.2 \
		aws-smithy-xml-0.60.10 \
		aws-types-1.3.7 \
		backtrace-0.3.75 \
		base16ct-0.1.1 \
		base64-0.21.7 \
		base64-0.22.1 \
		base64-simd-0.8.0 \
		base64ct-1.8.0 \
		bigdecimal-0.4.8 \
		bincode-2.0.1 \
		bincode_derive-2.0.1 \
		bindgen-0.69.5 \
		bitflags-2.9.1 \
		blake3-1.8.2 \
		block-buffer-0.10.4 \
		boxcar-0.2.13 \
		brotli-8.0.1 \
		brotli-decompressor-5.0.0 \
		bumpalo-3.19.0 \
		bytemuck-1.23.1 \
		bytemuck_derive-1.9.3 \
		byteorder-1.5.0 \
		bytes-1.10.1 \
		bytes-utils-0.1.4 \
		castaway-0.2.3 \
		cc-1.2.28 \
		cexpr-0.6.0 \
		cfg-if-1.0.1 \
		cfg_aliases-0.2.1 \
		chrono-0.4.41 \
		chrono-tz-0.10.3 \
		chrono-tz-build-0.4.1 \
		clang-sys-1.8.1 \
		clipboard-win-5.4.0 \
		cmake-0.1.54 \
		comfy-table-7.1.4 \
		compact_str-0.9.0 \
		concurrent-queue-2.5.0 \
		const-oid-0.9.6 \
		constant_time_eq-0.3.1 \
		core-foundation-0.9.4 \
		core-foundation-0.10.1 \
		core-foundation-sys-0.8.7 \
		core2-0.4.0 \
		cpufeatures-0.2.17 \
		crc-2.1.0 \
		crc-3.3.0 \
		crc-catalog-1.1.1 \
		crc-catalog-2.4.0 \
		crc-fast-1.3.0 \
		crc32c-0.6.8 \
		crc32fast-1.4.2 \
		crossbeam-channel-0.5.15 \
		crossbeam-deque-0.8.6 \
		crossbeam-epoch-0.9.18 \
		crossbeam-queue-0.3.12 \
		crossbeam-utils-0.8.21 \
		crossterm-0.28.1 \
		crossterm_winapi-0.9.1 \
		crunchy-0.2.4 \
		crypto-bigint-0.4.9 \
		crypto-bigint-0.5.5 \
		crypto-common-0.1.6 \
		dary_heap-0.3.7 \
		debug_unsafe-0.1.3 \
		der-0.6.1 \
		deranged-0.4.0 \
		digest-0.10.7 \
		dispatch2-0.3.0 \
		displaydoc-0.2.5 \
		dissimilar-1.0.10 \
		dunce-1.0.5 \
		dyn-clone-1.0.19 \
		ecdsa-0.14.8 \
		either-1.15.0 \
		elliptic-curve-0.12.3 \
		equivalent-1.0.2 \
		errno-0.3.13 \
		error-code-3.3.2 \
		ethnum-1.5.2 \
		event-listener-5.4.0 \
		event-listener-strategy-0.5.4 \
		fallible-streaming-iterator-0.1.9 \
		fast-float2-0.2.3 \
		fastrand-2.3.0 \
		ff-0.12.1 \
		flate2-1.1.2 \
		float-cmp-0.10.0 \
		fnv-1.0.7 \
		foldhash-0.1.5 \
		foldhash-0.2.0 \
		foreign-types-0.3.2 \
		foreign-types-shared-0.1.1 \
		form_urlencoded-1.2.1 \
		fs4-0.13.1 \
		fs_extra-1.3.0 \
		futures-0.3.31 \
		futures-channel-0.3.31 \
		futures-core-0.3.31 \
		futures-executor-0.3.31 \
		futures-io-0.3.31 \
		futures-macro-0.3.31 \
		futures-sink-0.3.31 \
		futures-task-0.3.31 \
		futures-util-0.3.31 \
		generic-array-0.14.7 \
		gethostname-0.4.3 \
		getrandom-0.2.16 \
		getrandom-0.3.3 \
		gimli-0.31.1 \
		glob-0.3.2 \
		group-0.12.1 \
		h2-0.3.26 \
		h2-0.4.11 \
		half-2.7.1 \
		halfbrown-0.4.0 \
		hashbrown-0.14.5 \
		hashbrown-0.15.4 \
		hashbrown-0.16.0 \
		heck-0.5.0 \
		hex-0.4.3 \
		hmac-0.12.1 \
		home-0.5.11 \
		http-0.2.12 \
		http-1.3.1 \
		http-body-0.4.6 \
		http-body-1.0.1 \
		http-body-util-0.1.3 \
		httparse-1.10.1 \
		httpdate-1.0.3 \
		humantime-2.2.0 \
		hyper-0.14.32 \
		hyper-1.6.0 \
		hyper-rustls-0.24.2 \
		hyper-rustls-0.27.7 \
		hyper-tls-0.6.0 \
		hyper-util-0.1.14 \
		iana-time-zone-0.1.63 \
		iana-time-zone-haiku-0.1.2 \
		icu_collections-2.0.0 \
		icu_locale_core-2.0.0 \
		icu_normalizer-2.0.0 \
		icu_normalizer_data-2.0.0 \
		icu_properties-2.0.1 \
		icu_properties_data-2.0.1 \
		icu_provider-2.0.0 \
		idna-1.0.3 \
		idna_adapter-1.2.1 \
		indexmap-2.12.0 \
		indoc-2.0.6 \
		inventory-0.3.20 \
		io-uring-0.7.8 \
		ipnet-2.11.0 \
		iri-string-0.7.8 \
		iter-read-1.1.0 \
		itertools-0.10.5 \
		itertools-0.12.1 \
		itertools-0.14.0 \
		itoa-1.0.15 \
		jobserver-0.1.33 \
		js-sys-0.3.77 \
		jsonpath_lib_polars_vendor-0.0.1 \
		lazy_static-1.5.0 \
		lazycell-1.3.0 \
		libc-0.2.174 \
		libflate-1.4.0 \
		libflate-2.1.0 \
		libflate_lz77-1.2.0 \
		libflate_lz77-2.1.0 \
		libloading-0.8.8 \
		libm-0.2.15 \
		libmimalloc-sys-0.1.43 \
		libz-rs-sys-0.5.1 \
		linux-raw-sys-0.4.15 \
		linux-raw-sys-0.9.4 \
		litemap-0.8.0 \
		lock_api-0.4.13 \
		log-0.4.27 \
		lru-0.12.5 \
		lru-slab-0.1.2 \
		lz4-1.28.1 \
		lz4-sys-1.11.1+lz4-1.10.0 \
		lz4_flex-0.11.5 \
		matrixmultiply-0.3.10 \
		md-5-0.10.6 \
		memchr-2.7.5 \
		memmap2-0.9.5 \
		memoffset-0.9.1 \
		mimalloc-0.1.47 \
		minimal-lexical-0.2.1 \
		miniz_oxide-0.8.9 \
		mio-1.0.4 \
		native-tls-0.2.14 \
		ndarray-0.16.1 \
		nom-7.1.3 \
		now-0.1.3 \
		ntapi-0.4.1 \
		num-0.4.3 \
		num-bigint-0.4.6 \
		num-complex-0.4.6 \
		num-conv-0.1.0 \
		num-derive-0.4.2 \
		num-integer-0.1.46 \
		num-iter-0.1.45 \
		num-rational-0.4.2 \
		num-traits-0.2.19 \
		numpy-0.26.0 \
		objc2-0.6.1 \
		objc2-app-kit-0.3.1 \
		objc2-core-foundation-0.3.1 \
		objc2-core-graphics-0.3.1 \
		objc2-encode-4.1.0 \
		objc2-foundation-0.3.1 \
		objc2-io-surface-0.3.1 \
		object-0.36.7 \
		object_store-0.12.2 \
		once_cell-1.21.3 \
		openssl-0.10.73 \
		openssl-macros-0.1.1 \
		openssl-probe-0.1.6 \
		openssl-sys-0.9.109 \
		outref-0.5.2 \
		p256-0.11.1 \
		parking-2.2.1 \
		parking_lot-0.12.4 \
		parking_lot_core-0.9.11 \
		parse-zoneinfo-0.3.1 \
		paste-1.0.15 \
		percent-encoding-2.3.1 \
		phf-0.11.3 \
		phf_codegen-0.11.3 \
		phf_generator-0.11.3 \
		phf_shared-0.11.3 \
		pin-project-lite-0.2.16 \
		pin-utils-0.1.0 \
		pkcs8-0.9.0 \
		pkg-config-0.3.32 \
		planus-1.1.1 \
		polars-arrow-format-0.2.0 \
		polars-parquet-format-0.1.0 \
		portable-atomic-1.11.1 \
		portable-atomic-util-0.2.4 \
		potential_utf-0.1.2 \
		powerfmt-0.2.0 \
		ppv-lite86-0.2.21 \
		prettyplease-0.2.35 \
		proc-macro2-1.0.95 \
		proptest-1.7.0 \
		prost-0.11.9 \
		prost-derive-0.11.9 \
		psm-0.1.26 \
		pyo3-0.26.0 \
		pyo3-build-config-0.26.0 \
		pyo3-ffi-0.26.0 \
		pyo3-macros-0.26.0 \
		pyo3-macros-backend-0.26.0 \
		quad-rand-0.2.3 \
		quick-xml-0.37.5 \
		quinn-0.11.8 \
		quinn-proto-0.11.12 \
		quinn-udp-0.5.13 \
		quote-1.0.40 \
		r-efi-5.3.0 \
		rand-0.8.5 \
		rand-0.9.1 \
		rand_chacha-0.3.1 \
		rand_chacha-0.9.0 \
		rand_core-0.6.4 \
		rand_core-0.9.3 \
		rand_distr-0.5.1 \
		rand_xorshift-0.4.0 \
		raw-cpuid-11.5.0 \
		rawpointer-0.2.1 \
		rayon-1.10.0 \
		rayon-core-1.12.1 \
		recursive-0.1.1 \
		recursive-proc-macro-impl-0.1.1 \
		redox_syscall-0.5.13 \
		ref-cast-1.0.24 \
		ref-cast-impl-1.0.24 \
		regex-1.11.1 \
		regex-automata-0.4.9 \
		regex-lite-0.1.6 \
		regex-syntax-0.8.5 \
		reqwest-0.12.22 \
		rfc6979-0.3.1 \
		ring-0.17.14 \
		rle-decode-fast-1.0.3 \
		rmp-0.8.14 \
		rmp-serde-1.3.0 \
		rustc-demangle-0.1.25 \
		rustc-hash-1.1.0 \
		rustc-hash-2.1.1 \
		rustc_version-0.4.1 \
		rustflags-0.1.7 \
		rustix-0.38.44 \
		rustix-1.0.7 \
		rustls-0.21.12 \
		rustls-0.23.28 \
		rustls-native-certs-0.6.3 \
		rustls-native-certs-0.8.1 \
		rustls-pemfile-1.0.4 \
		rustls-pemfile-2.2.0 \
		rustls-pki-types-1.12.0 \
		rustls-webpki-0.101.7 \
		rustls-webpki-0.103.3 \
		rustversion-1.0.21 \
		ryu-1.0.20 \
		same-file-1.0.6 \
		schannel-0.1.27 \
		schemars-0.9.0 \
		schemars_derive-0.9.0 \
		scopeguard-1.2.0 \
		sct-0.7.1 \
		sec1-0.3.0 \
		security-framework-2.11.1 \
		security-framework-3.2.0 \
		security-framework-sys-2.14.0 \
		semver-1.0.26 \
		serde-1.0.228 \
		serde-pickle-1.2.0 \
		serde_bytes-0.11.17 \
		serde_core-1.0.228 \
		serde_derive-1.0.228 \
		serde_derive_internals-0.29.1 \
		serde_json-1.0.140 \
		serde_spanned-1.0.0 \
		serde_stacker-0.1.12 \
		serde_urlencoded-0.7.1 \
		sha1-0.10.6 \
		sha2-0.10.9 \
		shlex-1.3.0 \
		signal-hook-0.3.18 \
		signal-hook-registry-1.4.5 \
		signature-1.6.4 \
		simd-json-0.17.0 \
		simdutf8-0.1.5 \
		siphasher-1.0.1 \
		slab-0.4.11 \
		slotmap-1.0.7 \
		smallvec-1.15.1 \
		snap-1.1.1 \
		socket2-0.5.10 \
		spki-0.6.0 \
		sqlparser-0.60.0 \
		sqlparser_derive-0.4.0 \
		stable_deref_trait-1.2.0 \
		stacker-0.1.21 \
		static_assertions-1.1.0 \
		streaming-decompression-0.1.2 \
		streaming-iterator-0.1.9 \
		strength_reduce-0.2.4 \
		strum-0.26.3 \
		strum-0.27.1 \
		strum_macros-0.26.4 \
		strum_macros-0.27.1 \
		subtle-2.6.1 \
		syn-1.0.109 \
		syn-2.0.104 \
		sync_wrapper-1.0.2 \
		synstructure-0.13.2 \
		sysinfo-0.33.1 \
		target-lexicon-0.13.2 \
		target-triple-0.1.4 \
		tempfile-3.20.0 \
		termcolor-1.4.1 \
		thiserror-1.0.69 \
		thiserror-2.0.12 \
		thiserror-impl-1.0.69 \
		thiserror-impl-2.0.12 \
		time-0.3.41 \
		time-core-0.1.4 \
		time-macros-0.2.22 \
		tinystr-0.8.1 \
		tinyvec-1.9.0 \
		tinyvec_macros-0.1.1 \
		tokio-1.46.1 \
		tokio-macros-2.5.0 \
		tokio-native-tls-0.3.1 \
		tokio-rustls-0.24.1 \
		tokio-rustls-0.26.2 \
		tokio-util-0.7.15 \
		toml-0.9.2 \
		toml_datetime-0.7.0 \
		toml_parser-1.0.1 \
		toml_writer-1.0.2 \
		tower-0.5.2 \
		tower-http-0.6.6 \
		tower-layer-0.3.3 \
		tower-service-0.3.3 \
		tracing-0.1.41 \
		tracing-attributes-0.1.30 \
		tracing-core-0.1.34 \
		try-lock-0.2.5 \
		trybuild-1.0.106 \
		twox-hash-2.1.1 \
		typed-builder-0.19.1 \
		typed-builder-macro-0.19.1 \
		typenum-1.18.0 \
		unarray-0.1.4 \
		unicode-ident-1.0.18 \
		unicode-normalization-0.1.24 \
		unicode-reverse-1.0.9 \
		unicode-segmentation-1.12.0 \
		unicode-width-0.2.1 \
		unindent-0.2.4 \
		untrusted-0.9.0 \
		unty-0.0.4 \
		url-2.5.4 \
		urlencoding-2.1.3 \
		utf8_iter-1.0.4 \
		uuid-1.17.0 \
		value-trait-0.12.1 \
		vcpkg-0.2.15 \
		version_check-0.9.5 \
		virtue-0.0.18 \
		vsimd-0.8.0 \
		walkdir-2.5.0 \
		want-0.3.1 \
		wasi-0.11.1+wasi-snapshot-preview1 \
		wasi-0.14.2+wasi-0.2.4 \
		wasm-bindgen-0.2.100 \
		wasm-bindgen-backend-0.2.100 \
		wasm-bindgen-futures-0.4.50 \
		wasm-bindgen-macro-0.2.100 \
		wasm-bindgen-macro-support-0.2.100 \
		wasm-bindgen-shared-0.2.100 \
		wasm-streams-0.4.2 \
		web-sys-0.3.77 \
		web-time-1.1.0 \
		which-4.4.2 \
		winapi-0.3.9 \
		winapi-i686-pc-windows-gnu-0.4.0 \
		winapi-util-0.1.9 \
		winapi-x86_64-pc-windows-gnu-0.4.0 \
		windows-0.57.0 \
		windows-core-0.57.0 \
		windows-core-0.61.2 \
		windows-implement-0.57.0 \
		windows-implement-0.60.0 \
		windows-interface-0.57.0 \
		windows-interface-0.59.1 \
		windows-link-0.1.3 \
		windows-result-0.1.2 \
		windows-result-0.3.4 \
		windows-strings-0.4.2 \
		windows-sys-0.52.0 \
		windows-sys-0.59.0 \
		windows-sys-0.60.2 \
		windows-targets-0.48.5 \
		windows-targets-0.52.6 \
		windows-targets-0.53.2 \
		windows_aarch64_gnullvm-0.48.5 \
		windows_aarch64_gnullvm-0.52.6 \
		windows_aarch64_gnullvm-0.53.0 \
		windows_aarch64_msvc-0.48.5 \
		windows_aarch64_msvc-0.52.6 \
		windows_aarch64_msvc-0.53.0 \
		windows_i686_gnu-0.48.5 \
		windows_i686_gnu-0.52.6 \
		windows_i686_gnu-0.53.0 \
		windows_i686_gnullvm-0.52.6 \
		windows_i686_gnullvm-0.53.0 \
		windows_i686_msvc-0.48.5 \
		windows_i686_msvc-0.52.6 \
		windows_i686_msvc-0.53.0 \
		windows_x86_64_gnu-0.48.5 \
		windows_x86_64_gnu-0.52.6 \
		windows_x86_64_gnu-0.53.0 \
		windows_x86_64_gnullvm-0.48.5 \
		windows_x86_64_gnullvm-0.52.6 \
		windows_x86_64_gnullvm-0.53.0 \
		windows_x86_64_msvc-0.48.5 \
		windows_x86_64_msvc-0.52.6 \
		windows_x86_64_msvc-0.53.0 \
		winnow-0.7.12 \
		wit-bindgen-rt-0.39.0 \
		writeable-0.6.1 \
		x11rb-0.13.1 \
		x11rb-protocol-0.13.1 \
		xmlparser-0.13.6 \
		xxhash-rust-0.8.15 \
		yoke-0.8.0 \
		yoke-derive-0.8.0 \
		zerocopy-0.8.26 \
		zerocopy-derive-0.8.26 \
		zerofrom-0.1.6 \
		zerofrom-derive-0.1.6 \
		zeroize-1.8.1 \
		zerotrie-0.2.2 \
		zerovec-0.11.2 \
		zerovec-derive-0.11.1 \
		zlib-rs-0.5.1 \
		zstd-0.13.3 \
		zstd-safe-7.2.4 \
		zstd-sys-2.0.15+zstd.1.5.7 \
		tikv-jemalloc-sys,tikv-jemallocator@git+https://github.com/pola-rs/jemallocator?rev=c7991e5bb6b3e9f79db6b0f48dcda67c5c3d2936\#c7991e5bb6b3e9f79db6b0f48dcda67c5c3d2936
CARGO_TARGET_DIR=	${WRKSRC}/target
CARGO_BUILD=	no
CARGO_INSTALL=	no

BUILD_WRKSRC=	${WRKSRC}/py-polars # for Python build
INSTALL_WRKSRC=	${WRKSRC}/py-polars # for Python install

TEST_ENV=	${MAKE_ENV} PYTHONPATH=${STAGEDIR}${PYTHONPREFIX_SITELIBDIR}
TEST_WRKSRC=	${CARGO_WRKSRC}/tests

BINARY_ALIAS=	python3=${PYTHON_CMD}

PLIST_SUB+=	FLAVOR=${FLAVOR} \
		PORTVERSION=${PORTVERSION}

do-build:
	# build
	@cd ${WRKSRC}/py-polars && \
		${SETENV} ${MAKE_ENV} maturin build -o dist --release --locked --strip --manifest-path runtime/polars-runtime-${FLAVOR}/Cargo.toml
	# adjust wheel name
	@cd ${WRKSRC}/py-polars/dist && \
		${LN} -s `ls *.whl` `ls *.whl | ${SED} -e "s/_${FLAVOR}//"`

do-install:
	@${MKDIR} ${STAGEDIR}${PYTHONPREFIX_SITELIBDIR}
	@cd ${INSTALL_WRKSRC} && ${SETENVI} ${WRK_ENV} ${MAKE_ENV} ${PEP517_INSTALL_CMD}

.include <bsd.port.mk>
