Functions: support materialize virtual array to initialized span
This commit is contained in:
@@ -135,6 +135,9 @@ class GVArray {
|
||||
this->get_internal_single(r_value);
|
||||
}
|
||||
|
||||
void materialize(void *dst) const;
|
||||
void materialize(const IndexMask mask, void *dst) const;
|
||||
|
||||
void materialize_to_uninitialized(void *dst) const;
|
||||
void materialize_to_uninitialized(const IndexMask mask, void *dst) const;
|
||||
|
||||
@@ -162,6 +165,7 @@ class GVArray {
|
||||
virtual bool is_single_impl() const;
|
||||
virtual void get_internal_single_impl(void *UNUSED(r_value)) const;
|
||||
|
||||
virtual void materialize_impl(const IndexMask mask, void *dst) const;
|
||||
virtual void materialize_to_uninitialized_impl(const IndexMask mask, void *dst) const;
|
||||
|
||||
virtual const void *try_get_internal_varray_impl() const;
|
||||
@@ -370,6 +374,11 @@ template<typename T> class GVArray_For_VArray : public GVArray {
|
||||
*(T *)r_value = varray_->get_internal_single();
|
||||
}
|
||||
|
||||
void materialize_impl(const IndexMask mask, void *dst) const override
|
||||
{
|
||||
varray_->materialize(mask, MutableSpan((T *)dst, mask.min_array_size()));
|
||||
}
|
||||
|
||||
void materialize_to_uninitialized_impl(const IndexMask mask, void *dst) const override
|
||||
{
|
||||
varray_->materialize_to_uninitialized(mask, MutableSpan((T *)dst, mask.min_array_size()));
|
||||
|
||||
Reference in New Issue
Block a user