Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
pola-rs
GitHub Repository: pola-rs/polars
Path: blob/main/crates/polars-arrow/src/array/binview/ffi.rs
8412 views
1
use polars_buffer::Buffer;
2
use polars_error::PolarsResult;
3
4
use super::BinaryViewArrayGeneric;
5
use crate::array::binview::{View, ViewType};
6
use crate::array::{FromFfi, ToFfi};
7
use crate::bitmap::align;
8
use crate::ffi;
9
10
unsafe impl<T: ViewType + ?Sized> ToFfi for BinaryViewArrayGeneric<T> {
11
fn buffers(&self) -> Vec<Option<*const u8>> {
12
let mut buffers = Vec::with_capacity(self.buffers.len() + 2);
13
buffers.push(self.validity.as_ref().map(|x| x.as_ptr()));
14
buffers.push(Some(self.views.storage_ptr().cast::<u8>()));
15
buffers.extend(self.buffers.iter().map(|b| Some(b.storage_ptr())));
16
buffers
17
}
18
19
fn offset(&self) -> Option<usize> {
20
let offset = self.views.offset();
21
if let Some(bitmap) = self.validity.as_ref() {
22
if bitmap.offset() == offset {
23
Some(offset)
24
} else {
25
None
26
}
27
} else {
28
Some(offset)
29
}
30
}
31
32
fn to_ffi_aligned(&self) -> Self {
33
let offset = self.views.offset();
34
35
let validity = self.validity.as_ref().map(|bitmap| {
36
if bitmap.offset() == offset {
37
bitmap.clone()
38
} else {
39
align(bitmap, offset)
40
}
41
});
42
43
Self {
44
dtype: self.dtype.clone(),
45
validity,
46
views: self.views.clone(),
47
buffers: self.buffers.clone(),
48
phantom: Default::default(),
49
total_bytes_len: self.total_bytes_len.clone(),
50
total_buffer_len: self.total_buffer_len,
51
}
52
}
53
}
54
55
impl<T: ViewType + ?Sized, A: ffi::ArrowArrayRef> FromFfi<A> for BinaryViewArrayGeneric<T> {
56
unsafe fn try_from_ffi(array: A) -> PolarsResult<Self> {
57
let dtype = array.dtype().clone();
58
59
let validity = unsafe { array.validity() }?;
60
let views = unsafe { array.buffer::<View>(1) }?;
61
62
// 2 - validity + views
63
let n_buffers = array.n_buffers();
64
let mut remaining_buffers = n_buffers - 2;
65
if remaining_buffers <= 1 {
66
return Ok(Self::new_unchecked_unknown_md(
67
dtype,
68
views,
69
Buffer::new(),
70
validity,
71
None,
72
));
73
}
74
75
let n_variadic_buffers = remaining_buffers - 1;
76
let variadic_buffer_offset = n_buffers - 1;
77
78
let variadic_buffer_sizes =
79
array.buffer_known_len::<i64>(variadic_buffer_offset, n_variadic_buffers)?;
80
remaining_buffers -= 1;
81
82
let mut variadic_buffers = Vec::with_capacity(remaining_buffers);
83
84
let offset = 2;
85
for (i, &size) in (offset..remaining_buffers + offset).zip(variadic_buffer_sizes.iter()) {
86
let values = unsafe { array.buffer_known_len::<u8>(i, size as usize) }?;
87
variadic_buffers.push(values);
88
}
89
90
Ok(Self::new_unchecked_unknown_md(
91
dtype,
92
views,
93
Buffer::from(variadic_buffers),
94
validity,
95
None,
96
))
97
}
98
}
99
100