Path: blob/main/crates/polars-compute/src/gather/structure.rs
6939 views
// Licensed to the Apache Software Foundation (ASF) under one1// or more contributor license agreements. See the NOTICE file2// distributed with this work for additional information3// regarding copyright ownership. The ASF licenses this file4// to you under the Apache License, Version 2.0 (the5// "License"); you may not use this file except in compliance6// with the License. You may obtain a copy of the License at7//8// http://www.apache.org/licenses/LICENSE-2.09//10// Unless required by applicable law or agreed to in writing,11// software distributed under the License is distributed on an12// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY13// KIND, either express or implied. See the License for the14// specific language governing permissions and limitations15// under the License.1617use arrow::array::{Array, StructArray};18use arrow::compute::utils::combine_validities_and;19use arrow::datatypes::IdxArr;2021pub(super) unsafe fn take_unchecked(array: &StructArray, indices: &IdxArr) -> StructArray {22let values: Vec<Box<dyn Array>> = array23.values()24.iter()25.map(|a| super::take_unchecked(a.as_ref(), indices))26.collect();2728let validity = array29.validity()30.map(|b| super::bitmap::take_bitmap_nulls_unchecked(b, indices));31let validity = combine_validities_and(validity.as_ref(), indices.validity());32StructArray::new(array.dtype().clone(), indices.len(), values, validity)33}343536