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

MAINTAINER=	yuri@FreeBSD.org
COMMENT=	Blazingly fast DataFrame library
WWW=		https://github.com/pola-rs/polars

LICENSE=	MIT
LICENSE_FILE=	${WRKSRC}/LICENSE

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

USES=		cargo python
USE_PYTHON=	pep517 autoplist

USE_GITHUB=	yes
GH_ACCOUNT=	pola-rs

# 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=\"mimalloc\" # 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

CARGO_BUILDDEP=	no
CARGO_CRATES=	addr2line-0.22.0 \
		adler-1.0.2 \
		adler32-1.2.0 \
		ahash-0.8.11 \
		aho-corasick-1.1.3 \
		alloc-no-stdlib-2.0.4 \
		alloc-stdlib-0.2.2 \
		allocator-api2-0.2.18 \
		android-tzdata-0.1.1 \
		android_system_properties-0.1.5 \
		anes-0.1.6 \
		anstyle-1.0.7 \
		anyhow-1.0.86 \
		apache-avro-0.16.0 \
		arboard-3.4.0 \
		argminmax-0.6.2 \
		array-init-cursor-0.2.0 \
		arrow-array-52.0.0 \
		arrow-buffer-52.0.0 \
		arrow-data-52.0.0 \
		arrow-schema-52.0.0 \
		arrow2-0.17.4 \
		async-stream-0.3.5 \
		async-stream-impl-0.3.5 \
		async-trait-0.1.80 \
		atoi-2.0.0 \
		atoi_simd-0.15.6 \
		autocfg-1.3.0 \
		avro-schema-0.3.0 \
		aws-config-1.5.1 \
		aws-credential-types-1.2.0 \
		aws-runtime-1.2.3 \
		aws-sdk-s3-1.36.0 \
		aws-sdk-sso-1.31.0 \
		aws-sdk-ssooidc-1.32.0 \
		aws-sdk-sts-1.31.0 \
		aws-sigv4-1.2.2 \
		aws-smithy-async-1.2.1 \
		aws-smithy-checksums-0.60.10 \
		aws-smithy-eventstream-0.60.4 \
		aws-smithy-http-0.60.8 \
		aws-smithy-json-0.60.7 \
		aws-smithy-query-0.60.7 \
		aws-smithy-runtime-1.6.0 \
		aws-smithy-runtime-api-1.7.0 \
		aws-smithy-types-1.2.0 \
		aws-smithy-xml-0.60.8 \
		aws-types-1.3.1 \
		backtrace-0.3.73 \
		base16ct-0.1.1 \
		base64-0.21.7 \
		base64-0.22.1 \
		base64-simd-0.8.0 \
		base64ct-1.6.0 \
		bincode-1.3.3 \
		bitflags-1.3.2 \
		bitflags-2.5.0 \
		block-buffer-0.10.4 \
		block2-0.5.1 \
		brotli-5.0.0 \
		brotli-decompressor-4.0.1 \
		built-0.7.3 \
		bumpalo-3.16.0 \
		bytemuck-1.16.0 \
		bytemuck_derive-1.7.0 \
		bytes-1.6.0 \
		bytes-utils-0.1.4 \
		cargo-lock-9.0.0 \
		casey-0.4.0 \
		cast-0.3.0 \
		cc-1.0.99 \
		cfg-if-1.0.0 \
		chrono-0.4.38 \
		chrono-tz-0.8.6 \
		chrono-tz-build-0.2.1 \
		ciborium-0.2.2 \
		ciborium-io-0.2.2 \
		ciborium-ll-0.2.2 \
		clap-4.5.7 \
		clap_builder-4.5.7 \
		clap_lex-0.7.1 \
		clipboard-win-5.3.1 \
		cmake-0.1.50 \
		comfy-table-7.1.1 \
		const-oid-0.9.6 \
		const-random-0.1.18 \
		const-random-macro-0.1.16 \
		core-foundation-0.9.4 \
		core-foundation-sys-0.8.6 \
		core2-0.4.0 \
		cpufeatures-0.2.12 \
		crc-2.1.0 \
		crc-catalog-1.1.1 \
		crc32c-0.6.8 \
		crc32fast-1.4.2 \
		criterion-0.5.1 \
		criterion-plot-0.5.0 \
		crossbeam-channel-0.5.13 \
		crossbeam-deque-0.8.5 \
		crossbeam-epoch-0.9.18 \
		crossbeam-queue-0.3.11 \
		crossbeam-utils-0.8.20 \
		crossterm-0.27.0 \
		crossterm_winapi-0.9.1 \
		crunchy-0.2.2 \
		crypto-bigint-0.4.9 \
		crypto-bigint-0.5.5 \
		crypto-common-0.1.6 \
		dary_heap-0.3.6 \
		der-0.6.1 \
		deranged-0.3.11 \
		digest-0.10.7 \
		displaydoc-0.2.4 \
		doc-comment-0.3.3 \
		dyn-clone-1.0.17 \
		ecdsa-0.14.8 \
		either-1.12.0 \
		elliptic-curve-0.12.3 \
		encoding_rs-0.8.34 \
		enum_dispatch-0.3.13 \
		env_logger-0.8.4 \
		equivalent-1.0.1 \
		errno-0.3.9 \
		error-code-3.2.0 \
		ethnum-1.5.0 \
		fallible-streaming-iterator-0.1.9 \
		fast-float-0.2.0 \
		fastrand-2.1.0 \
		ff-0.12.1 \
		flate2-1.0.30 \
		float-cmp-0.9.0 \
		fnv-1.0.7 \
		foreign_vec-0.1.0 \
		form_urlencoded-1.2.1 \
		futures-0.3.30 \
		futures-channel-0.3.30 \
		futures-core-0.3.30 \
		futures-executor-0.3.30 \
		futures-io-0.3.30 \
		futures-macro-0.3.30 \
		futures-sink-0.3.30 \
		futures-task-0.3.30 \
		futures-util-0.3.30 \
		generic-array-0.14.7 \
		gethostname-0.4.3 \
		getrandom-0.2.15 \
		gimli-0.29.0 \
		git2-0.18.3 \
		glob-0.3.1 \
		group-0.12.1 \
		h2-0.3.26 \
		half-2.4.1 \
		halfbrown-0.2.5 \
		hash_hasher-2.0.3 \
		hashbrown-0.14.5 \
		heck-0.4.1 \
		heck-0.5.0 \
		hermit-abi-0.3.9 \
		hex-0.4.3 \
		hmac-0.12.1 \
		home-0.5.9 \
		http-0.2.12 \
		http-1.1.0 \
		http-body-0.4.6 \
		http-body-1.0.0 \
		http-body-util-0.1.2 \
		httparse-1.8.0 \
		httpdate-1.0.3 \
		humantime-2.1.0 \
		hyper-0.14.29 \
		hyper-rustls-0.24.2 \
		iana-time-zone-0.1.60 \
		iana-time-zone-haiku-0.1.2 \
		icu_collections-1.5.0 \
		icu_locid-1.5.0 \
		icu_locid_transform-1.5.0 \
		icu_locid_transform_data-1.5.0 \
		icu_normalizer-1.5.0 \
		icu_normalizer_data-1.5.0 \
		icu_properties-1.5.0 \
		icu_properties_data-1.5.0 \
		icu_provider-1.5.0 \
		icu_provider_macros-1.5.0 \
		idna-1.0.0 \
		indexmap-2.2.6 \
		indoc-2.0.5 \
		inventory-0.3.15 \
		ipnet-2.9.0 \
		is-terminal-0.4.12 \
		itertools-0.10.5 \
		itertools-0.12.1 \
		itoa-1.0.11 \
		itoap-1.0.1 \
		jobserver-0.1.31 \
		js-sys-0.3.69 \
		jsonpath_lib_polars_vendor-0.0.1 \
		lazy_static-1.4.0 \
		lexical-core-0.8.5 \
		lexical-parse-float-0.8.5 \
		lexical-parse-integer-0.8.6 \
		lexical-util-0.8.5 \
		lexical-write-float-0.8.5 \
		lexical-write-integer-0.8.5 \
		libc-0.2.155 \
		libflate-1.4.0 \
		libflate-2.1.0 \
		libflate_lz77-1.2.0 \
		libflate_lz77-2.1.0 \
		libgit2-sys-0.16.2+1.7.2 \
		libloading-0.8.3 \
		libm-0.2.8 \
		libmimalloc-sys-0.1.38 \
		libz-ng-sys-1.1.15 \
		libz-sys-1.1.18 \
		linux-raw-sys-0.4.14 \
		litemap-0.7.3 \
		lock_api-0.4.12 \
		log-0.4.21 \
		lru-0.12.3 \
		lz4-1.25.0 \
		lz4-sys-1.9.5 \
		lz4_flex-0.11.3 \
		matrixmultiply-0.3.8 \
		md-5-0.10.6 \
		memchr-2.7.4 \
		memmap2-0.7.1 \
		memoffset-0.9.1 \
		mimalloc-0.1.42 \
		mime-0.3.17 \
		miniz_oxide-0.7.3 \
		mio-0.8.11 \
		multiversion-0.7.4 \
		multiversion-macros-0.7.4 \
		ndarray-0.15.6 \
		now-0.1.3 \
		ntapi-0.4.1 \
		num-0.4.3 \
		num-bigint-0.4.5 \
		num-complex-0.4.6 \
		num-conv-0.1.0 \
		num-integer-0.1.46 \
		num-iter-0.1.45 \
		num-rational-0.4.2 \
		num-traits-0.2.19 \
		num_cpus-1.16.0 \
		numpy-0.21.0 \
		objc-sys-0.3.5 \
		objc2-0.5.2 \
		objc2-app-kit-0.2.2 \
		objc2-core-data-0.2.2 \
		objc2-core-image-0.2.2 \
		objc2-encode-4.0.3 \
		objc2-foundation-0.2.2 \
		objc2-metal-0.2.2 \
		objc2-quartz-core-0.2.2 \
		object-0.36.0 \
		object_store-0.9.1 \
		once_cell-1.19.0 \
		oorandom-11.1.3 \
		openssl-probe-0.1.5 \
		outref-0.5.1 \
		p256-0.11.1 \
		parking_lot-0.12.3 \
		parking_lot_core-0.9.10 \
		parquet-format-safe-0.2.4 \
		parse-zoneinfo-0.3.1 \
		percent-encoding-2.3.1 \
		phf-0.11.2 \
		phf_codegen-0.11.2 \
		phf_generator-0.11.2 \
		phf_shared-0.11.2 \
		pin-project-lite-0.2.14 \
		pin-utils-0.1.0 \
		pkcs8-0.9.0 \
		pkg-config-0.3.30 \
		planus-0.3.1 \
		plotters-0.3.6 \
		plotters-backend-0.3.6 \
		plotters-svg-0.3.6 \
		polars-arrow-format-0.1.0 \
		portable-atomic-1.6.0 \
		powerfmt-0.2.0 \
		ppv-lite86-0.2.17 \
		proc-macro2-1.0.85 \
		proptest-1.4.0 \
		prost-0.11.9 \
		prost-derive-0.11.9 \
		psm-0.1.21 \
		pyo3-0.21.2 \
		pyo3-build-config-0.21.2 \
		pyo3-ffi-0.21.2 \
		pyo3-macros-0.21.2 \
		pyo3-macros-backend-0.21.2 \
		quad-rand-0.2.1 \
		quick-xml-0.31.0 \
		quickcheck-1.0.3 \
		quote-1.0.36 \
		rand-0.8.5 \
		rand_chacha-0.3.1 \
		rand_core-0.6.4 \
		rand_distr-0.4.3 \
		rand_regex-0.15.1 \
		rand_xorshift-0.3.0 \
		raw-cpuid-11.0.2 \
		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.2 \
		ref-cast-1.0.23 \
		ref-cast-impl-1.0.23 \
		regex-1.10.5 \
		regex-automata-0.4.7 \
		regex-lite-0.1.6 \
		regex-syntax-0.6.29 \
		regex-syntax-0.8.4 \
		reqwest-0.11.27 \
		rfc6979-0.3.1 \
		ring-0.17.8 \
		rle-decode-fast-1.0.3 \
		rustc-demangle-0.1.24 \
		rustc-hash-1.1.0 \
		rustc_version-0.4.0 \
		rustix-0.38.34 \
		rustls-0.21.12 \
		rustls-native-certs-0.6.3 \
		rustls-pemfile-1.0.4 \
		rustls-pemfile-2.1.2 \
		rustls-pki-types-1.7.0 \
		rustls-webpki-0.101.7 \
		rustversion-1.0.17 \
		ryu-1.0.18 \
		same-file-1.0.6 \
		sample-arrow2-0.17.2 \
		sample-std-0.2.1 \
		sample-test-0.2.1 \
		sample-test-macros-0.2.1 \
		schannel-0.1.23 \
		scopeguard-1.2.0 \
		sct-0.7.1 \
		sec1-0.3.0 \
		security-framework-2.11.0 \
		security-framework-sys-2.11.0 \
		semver-1.0.23 \
		seq-macro-0.3.5 \
		serde-1.0.203 \
		serde_derive-1.0.203 \
		serde_json-1.0.117 \
		serde_spanned-0.6.6 \
		serde_urlencoded-0.7.1 \
		sha1-0.10.6 \
		sha2-0.10.8 \
		signal-hook-registry-1.4.2 \
		signature-1.6.4 \
		simd-json-0.13.10 \
		simdutf8-0.1.4 \
		siphasher-0.3.11 \
		slab-0.4.9 \
		smallvec-1.13.2 \
		smartstring-1.0.1 \
		snafu-0.7.5 \
		snafu-derive-0.7.5 \
		snap-1.1.1 \
		socket2-0.5.7 \
		spin-0.9.8 \
		spki-0.6.0 \
		sqlparser-0.39.0 \
		stable_deref_trait-1.2.0 \
		stacker-0.1.15 \
		static_assertions-1.1.0 \
		streaming-decompression-0.1.2 \
		streaming-iterator-0.1.9 \
		strength_reduce-0.2.4 \
		strum-0.25.0 \
		strum-0.26.2 \
		strum_macros-0.25.3 \
		strum_macros-0.26.4 \
		subtle-2.5.0 \
		syn-1.0.109 \
		syn-2.0.66 \
		sync_wrapper-0.1.2 \
		synstructure-0.13.1 \
		sysinfo-0.30.12 \
		system-configuration-0.5.1 \
		system-configuration-sys-0.5.0 \
		target-features-0.1.6 \
		target-lexicon-0.12.14 \
		tempfile-3.10.1 \
		thiserror-1.0.61 \
		thiserror-impl-1.0.61 \
		time-0.3.36 \
		time-core-0.1.2 \
		time-macros-0.2.18 \
		tiny-keccak-2.0.2 \
		tinystr-0.7.6 \
		tinytemplate-1.2.1 \
		tokio-1.38.0 \
		tokio-macros-2.3.0 \
		tokio-rustls-0.24.1 \
		tokio-util-0.7.11 \
		toml-0.7.8 \
		toml_datetime-0.6.6 \
		toml_edit-0.19.15 \
		tower-service-0.3.2 \
		tracing-0.1.40 \
		tracing-attributes-0.1.27 \
		tracing-core-0.1.32 \
		try-lock-0.2.5 \
		twox-hash-1.6.3 \
		typed-builder-0.16.2 \
		typed-builder-macro-0.16.2 \
		typenum-1.17.0 \
		unarray-0.1.4 \
		unicode-ident-1.0.12 \
		unicode-reverse-1.0.9 \
		unicode-segmentation-1.11.0 \
		unicode-width-0.1.13 \
		unindent-0.2.3 \
		untrusted-0.9.0 \
		url-2.5.1 \
		urlencoding-2.1.3 \
		utf16_iter-1.0.5 \
		utf8_iter-1.0.4 \
		uuid-1.8.0 \
		value-trait-0.8.1 \
		vcpkg-0.2.15 \
		version_check-0.9.4 \
		vsimd-0.8.0 \
		walkdir-2.5.0 \
		want-0.3.1 \
		wasi-0.11.0+wasi-snapshot-preview1 \
		wasm-bindgen-0.2.92 \
		wasm-bindgen-backend-0.2.92 \
		wasm-bindgen-futures-0.4.42 \
		wasm-bindgen-macro-0.2.92 \
		wasm-bindgen-macro-support-0.2.92 \
		wasm-bindgen-shared-0.2.92 \
		wasm-streams-0.4.0 \
		web-sys-0.3.69 \
		winapi-0.3.9 \
		winapi-i686-pc-windows-gnu-0.4.0 \
		winapi-util-0.1.8 \
		winapi-x86_64-pc-windows-gnu-0.4.0 \
		windows-0.52.0 \
		windows-core-0.52.0 \
		windows-sys-0.48.0 \
		windows-sys-0.52.0 \
		windows-targets-0.48.5 \
		windows-targets-0.52.5 \
		windows_aarch64_gnullvm-0.48.5 \
		windows_aarch64_gnullvm-0.52.5 \
		windows_aarch64_msvc-0.48.5 \
		windows_aarch64_msvc-0.52.5 \
		windows_i686_gnu-0.48.5 \
		windows_i686_gnu-0.52.5 \
		windows_i686_gnullvm-0.52.5 \
		windows_i686_msvc-0.48.5 \
		windows_i686_msvc-0.52.5 \
		windows_x86_64_gnu-0.48.5 \
		windows_x86_64_gnu-0.52.5 \
		windows_x86_64_gnullvm-0.48.5 \
		windows_x86_64_gnullvm-0.52.5 \
		windows_x86_64_msvc-0.48.5 \
		windows_x86_64_msvc-0.52.5 \
		winnow-0.5.40 \
		winreg-0.50.0 \
		write16-1.0.0 \
		writeable-0.5.5 \
		x11rb-0.13.1 \
		x11rb-protocol-0.13.1 \
		xmlparser-0.13.6 \
		xxhash-rust-0.8.10 \
		yoke-0.7.4 \
		yoke-derive-0.7.4 \
		zerocopy-0.7.34 \
		zerocopy-derive-0.7.34 \
		zerofrom-0.1.4 \
		zerofrom-derive-0.1.4 \
		zeroize-1.8.1 \
		zerovec-0.10.2 \
		zerovec-derive-0.10.2 \
		zstd-0.13.1 \
		zstd-safe-7.1.0 \
		zstd-sys-2.0.10+zstd.1.5.6

CARGO_BUILD=	no
CARGO_INSTALL=	no
CARGO_TEST=	no
CARGO_TARGET_DIR=	${WRKSRC}/target

WRKSRC_SUBDIR=	py-polars

PORTSCOUT=	limit:^py-

post-install:
	@${STRIP_CMD} ${STAGEDIR}${PYTHONPREFIX_SITELIBDIR}/polars/polars.abi3.so

.include <bsd.port.mk>
