Coverage Report

Created: 2026-01-10 07:01

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/rust/registry/src/index.crates.io-1949cf8c6b5b557f/rayon-1.11.0/src/vec.rs
Line
Count
Source
1
//! Parallel iterator types for [vectors] (`Vec<T>`)
2
//!
3
//! You will rarely need to interact with this module directly unless you need
4
//! to name one of the iterator types.
5
//!
6
//! [vectors]: mod@std::vec
7
8
use crate::iter::plumbing::*;
9
use crate::iter::*;
10
use crate::math::simplify_range;
11
use crate::slice::{Iter, IterMut};
12
use std::iter;
13
use std::mem;
14
use std::ops::{Range, RangeBounds};
15
use std::ptr;
16
use std::slice;
17
18
impl<'data, T: Sync + 'data> IntoParallelIterator for &'data Vec<T> {
19
    type Item = &'data T;
20
    type Iter = Iter<'data, T>;
21
22
0
    fn into_par_iter(self) -> Self::Iter {
23
0
        <&[T]>::into_par_iter(self)
24
0
    }
25
}
26
27
impl<'data, T: Send + 'data> IntoParallelIterator for &'data mut Vec<T> {
28
    type Item = &'data mut T;
29
    type Iter = IterMut<'data, T>;
30
31
0
    fn into_par_iter(self) -> Self::Iter {
32
0
        <&mut [T]>::into_par_iter(self)
33
0
    }
34
}
35
36
/// Parallel iterator that moves out of a vector.
37
#[derive(Debug, Clone)]
38
pub struct IntoIter<T> {
39
    vec: Vec<T>,
40
}
41
42
impl<T: Send> IntoParallelIterator for Vec<T> {
43
    type Item = T;
44
    type Iter = IntoIter<T>;
45
46
0
    fn into_par_iter(self) -> Self::Iter {
47
0
        IntoIter { vec: self }
48
0
    }
Unexecuted instantiation: <alloc::vec::Vec<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::IntoParallelIterator>::into_par_iter
Unexecuted instantiation: <alloc::vec::Vec<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::IntoParallelIterator>::into_par_iter
Unexecuted instantiation: <alloc::vec::Vec<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IntoParallelIterator>::into_par_iter
Unexecuted instantiation: <alloc::vec::Vec<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::IntoParallelIterator>::into_par_iter
Unexecuted instantiation: <alloc::vec::Vec<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::IntoParallelIterator>::into_par_iter
Unexecuted instantiation: <alloc::vec::Vec<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IntoParallelIterator>::into_par_iter
Unexecuted instantiation: <alloc::vec::Vec<_> as rayon::iter::IntoParallelIterator>::into_par_iter
49
}
50
51
impl<T: Send> IntoParallelIterator for Box<[T]> {
52
    type Item = T;
53
    type Iter = IntoIter<T>;
54
55
0
    fn into_par_iter(self) -> Self::Iter {
56
0
        IntoIter { vec: self.into() }
57
0
    }
58
}
59
60
impl<T: Send> ParallelIterator for IntoIter<T> {
61
    type Item = T;
62
63
0
    fn drive_unindexed<C>(self, consumer: C) -> C::Result
64
0
    where
65
0
        C: UnindexedConsumer<Self::Item>,
66
    {
67
0
        bridge(self, consumer)
68
0
    }
Unexecuted instantiation: <rayon::vec::IntoIter<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::for_each::ForEachConsumer<rav1e::api::lookahead::compute_motion_vectors<u16>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::for_each::ForEachConsumer<av_scenechange::analyze::inter::compute_motion_vectors<u16>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::for_each::ForEachConsumer<rav1e::api::lookahead::compute_motion_vectors<u8>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::for_each::ForEachConsumer<av_scenechange::analyze::inter::compute_motion_vectors<u8>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::drive_unindexed::<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>
Unexecuted instantiation: <rayon::vec::IntoIter<_> as rayon::iter::ParallelIterator>::drive_unindexed::<_>
69
70
0
    fn opt_len(&self) -> Option<usize> {
71
0
        Some(self.len())
72
0
    }
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::opt_len
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelIterator>::opt_len
Unexecuted instantiation: <rayon::vec::IntoIter<_> as rayon::iter::ParallelIterator>::opt_len
73
}
74
75
impl<T: Send> IndexedParallelIterator for IntoIter<T> {
76
0
    fn drive<C>(self, consumer: C) -> C::Result
77
0
    where
78
0
        C: Consumer<Self::Item>,
79
    {
80
0
        bridge(self, consumer)
81
0
    }
82
83
0
    fn len(&self) -> usize {
84
0
        self.vec.len()
85
0
    }
Unexecuted instantiation: <rayon::vec::IntoIter<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::IndexedParallelIterator>::len
Unexecuted instantiation: <rayon::vec::IntoIter<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::IndexedParallelIterator>::len
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::len
Unexecuted instantiation: <rayon::vec::IntoIter<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::IndexedParallelIterator>::len
Unexecuted instantiation: <rayon::vec::IntoIter<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::IndexedParallelIterator>::len
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::len
Unexecuted instantiation: <rayon::vec::IntoIter<_> as rayon::iter::IndexedParallelIterator>::len
86
87
0
    fn with_producer<CB>(mut self, callback: CB) -> CB::Output
88
0
    where
89
0
        CB: ProducerCallback<Self::Item>,
90
    {
91
        // Drain every item, and then the vector only needs to free its buffer.
92
0
        self.vec.par_drain(..).with_producer(callback)
93
0
    }
Unexecuted instantiation: <rayon::vec::IntoIter<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<rav1e::api::lookahead::compute_motion_vectors<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<av_scenechange::analyze::inter::compute_motion_vectors<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<rav1e::api::lookahead::compute_motion_vectors<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<av_scenechange::analyze::inter::compute_motion_vectors<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::IntoIter<_> as rayon::iter::IndexedParallelIterator>::with_producer::<_>
94
}
95
96
impl<'data, T: Send> ParallelDrainRange<usize> for &'data mut Vec<T> {
97
    type Iter = Drain<'data, T>;
98
    type Item = T;
99
100
0
    fn par_drain<R: RangeBounds<usize>>(self, range: R) -> Self::Iter {
101
0
        Drain {
102
0
            orig_len: self.len(),
103
0
            range: simplify_range(range, self.len()),
104
0
            vec: self,
105
0
        }
106
0
    }
Unexecuted instantiation: <&mut alloc::vec::Vec<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::ParallelDrainRange>::par_drain::<core::ops::range::RangeFull>
Unexecuted instantiation: <&mut alloc::vec::Vec<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::ParallelDrainRange>::par_drain::<core::ops::range::RangeFull>
Unexecuted instantiation: <&mut alloc::vec::Vec<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelDrainRange>::par_drain::<core::ops::range::RangeFull>
Unexecuted instantiation: <&mut alloc::vec::Vec<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::ParallelDrainRange>::par_drain::<core::ops::range::RangeFull>
Unexecuted instantiation: <&mut alloc::vec::Vec<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::ParallelDrainRange>::par_drain::<core::ops::range::RangeFull>
Unexecuted instantiation: <&mut alloc::vec::Vec<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::ParallelDrainRange>::par_drain::<core::ops::range::RangeFull>
Unexecuted instantiation: <&mut alloc::vec::Vec<_> as rayon::iter::ParallelDrainRange>::par_drain::<_>
107
}
108
109
/// Draining parallel iterator that moves a range out of a vector, but keeps the total capacity.
110
#[derive(Debug)]
111
pub struct Drain<'data, T: Send> {
112
    vec: &'data mut Vec<T>,
113
    range: Range<usize>,
114
    orig_len: usize,
115
}
116
117
impl<'data, T: Send> ParallelIterator for Drain<'data, T> {
118
    type Item = T;
119
120
0
    fn drive_unindexed<C>(self, consumer: C) -> C::Result
121
0
    where
122
0
        C: UnindexedConsumer<Self::Item>,
123
    {
124
0
        bridge(self, consumer)
125
0
    }
126
127
0
    fn opt_len(&self) -> Option<usize> {
128
0
        Some(self.len())
129
0
    }
130
}
131
132
impl<'data, T: Send> IndexedParallelIterator for Drain<'data, T> {
133
0
    fn drive<C>(self, consumer: C) -> C::Result
134
0
    where
135
0
        C: Consumer<Self::Item>,
136
    {
137
0
        bridge(self, consumer)
138
0
    }
139
140
0
    fn len(&self) -> usize {
141
0
        self.range.len()
142
0
    }
143
144
0
    fn with_producer<CB>(self, callback: CB) -> CB::Output
145
0
    where
146
0
        CB: ProducerCallback<Self::Item>,
147
    {
148
        unsafe {
149
            // Make the vector forget about the drained items, and temporarily the tail too.
150
0
            self.vec.set_len(self.range.start);
151
152
            // Create the producer as the exclusive "owner" of the slice.
153
0
            let producer = DrainProducer::from_vec(self.vec, self.range.len());
154
155
            // The producer will move or drop each item from the drained range.
156
0
            callback.callback(producer)
157
        }
158
0
    }
Unexecuted instantiation: <rayon::vec::Drain<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<rav1e::api::lookahead::compute_motion_vectors<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<av_scenechange::analyze::inter::compute_motion_vectors<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u16>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<rav1e::api::lookahead::compute_motion_vectors<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::for_each::ForEachConsumer<av_scenechange::analyze::inter::compute_motion_vectors<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::collect::consumer::CollectConsumer<alloc::vec::Vec<u8>>, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::extend::ListVecConsumer>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::IndexedParallelIterator>::with_producer::<rayon::iter::plumbing::bridge::Callback<rayon::iter::map::MapConsumer<rayon::iter::unzip::UnzipConsumer<rayon::iter::unzip::Unzip, rayon::iter::extend::ListVecConsumer, rayon::iter::collect::consumer::CollectConsumer<rav1e::stats::EncoderStats>>, rav1e::encoder::encode_tile_group<u8>::{closure#0}>>>
Unexecuted instantiation: <rayon::vec::Drain<_> as rayon::iter::IndexedParallelIterator>::with_producer::<_>
159
}
160
161
impl<'data, T: Send> Drop for Drain<'data, T> {
162
0
    fn drop(&mut self) {
163
0
        let Range { start, end } = self.range;
164
0
        if self.vec.len() == self.orig_len {
165
0
            // We must not have produced, so just call a normal drain to remove the items.
166
0
            self.vec.drain(start..end);
167
0
        } else if start == end {
168
            // Empty range, so just restore the length to its original state
169
0
            unsafe {
170
0
                self.vec.set_len(self.orig_len);
171
0
            }
172
0
        } else if end < self.orig_len {
173
            // The producer was responsible for consuming the drained items.
174
            // Move the tail items to their new place, then set the length to include them.
175
0
            unsafe {
176
0
                let ptr = self.vec.as_mut_ptr().add(start);
177
0
                let tail_ptr = self.vec.as_ptr().add(end);
178
0
                let tail_len = self.orig_len - end;
179
0
                ptr::copy(tail_ptr, ptr, tail_len);
180
0
                self.vec.set_len(start + tail_len);
181
0
            }
182
0
        }
183
0
    }
Unexecuted instantiation: <rayon::vec::Drain<rav1e::tiling::tiler::TileContextMut<u16>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::Drain<av_scenechange::data::tile::TileContextMut<u16>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::Drain<rav1e::tiling::tiler::TileContextMut<u8>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::Drain<av_scenechange::data::tile::TileContextMut<u8>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::Drain<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::Drain<_> as core::ops::drop::Drop>::drop
184
}
185
186
// ////////////////////////////////////////////////////////////////////////
187
188
pub(crate) struct DrainProducer<'data, T: Send> {
189
    slice: &'data mut [T],
190
}
191
192
impl<T: Send> DrainProducer<'_, T> {
193
    /// Creates a draining producer, which *moves* items from the slice.
194
    ///
195
    /// Unsafe because `!Copy` data must not be read after the borrow is released.
196
0
    pub(crate) unsafe fn new(slice: &mut [T]) -> DrainProducer<'_, T> {
197
0
        DrainProducer { slice }
198
0
    }
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u16>>>::new
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u16>>>::new
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)>>::new
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u8>>>::new
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u8>>>::new
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)>>::new
Unexecuted instantiation: <rayon::vec::DrainProducer<_>>::new
199
200
    /// Creates a draining producer, which *moves* items from the tail of the vector.
201
    ///
202
    /// Unsafe because we're moving from beyond `vec.len()`, so the caller must ensure
203
    /// that data is initialized and not read after the borrow is released.
204
0
    unsafe fn from_vec(vec: &mut Vec<T>, len: usize) -> DrainProducer<'_, T> {
205
0
        let start = vec.len();
206
0
        assert!(vec.capacity() - start >= len);
207
208
        // The pointer is derived from `Vec` directly, not through a `Deref`,
209
        // so it has provenance over the whole allocation.
210
0
        let ptr = vec.as_mut_ptr().add(start);
211
0
        DrainProducer::new(slice::from_raw_parts_mut(ptr, len))
212
0
    }
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u16>>>::from_vec
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u16>>>::from_vec
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)>>::from_vec
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u8>>>::from_vec
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u8>>>::from_vec
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)>>::from_vec
Unexecuted instantiation: <rayon::vec::DrainProducer<_>>::from_vec
213
}
214
215
impl<'data, T: 'data + Send> Producer for DrainProducer<'data, T> {
216
    type Item = T;
217
    type IntoIter = SliceDrain<'data, T>;
218
219
0
    fn into_iter(mut self) -> Self::IntoIter {
220
        // replace the slice so we don't drop it twice
221
0
        let slice = mem::take(&mut self.slice);
222
0
        SliceDrain {
223
0
            iter: slice.iter_mut(),
224
0
        }
225
0
    }
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::plumbing::Producer>::into_iter
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::plumbing::Producer>::into_iter
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::plumbing::Producer>::into_iter
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::plumbing::Producer>::into_iter
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::plumbing::Producer>::into_iter
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::plumbing::Producer>::into_iter
Unexecuted instantiation: <rayon::vec::DrainProducer<_> as rayon::iter::plumbing::Producer>::into_iter
226
227
0
    fn split_at(mut self, index: usize) -> (Self, Self) {
228
        // replace the slice so we don't drop it twice
229
0
        let slice = mem::take(&mut self.slice);
230
0
        let (left, right) = slice.split_at_mut(index);
231
0
        unsafe { (DrainProducer::new(left), DrainProducer::new(right)) }
232
0
    }
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u16>> as rayon::iter::plumbing::Producer>::split_at
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u16>> as rayon::iter::plumbing::Producer>::split_at
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::plumbing::Producer>::split_at
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u8>> as rayon::iter::plumbing::Producer>::split_at
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u8>> as rayon::iter::plumbing::Producer>::split_at
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as rayon::iter::plumbing::Producer>::split_at
Unexecuted instantiation: <rayon::vec::DrainProducer<_> as rayon::iter::plumbing::Producer>::split_at
233
}
234
235
impl<'data, T: 'data + Send> Drop for DrainProducer<'data, T> {
236
0
    fn drop(&mut self) {
237
        // extract the slice so we can use `Drop for [T]`
238
0
        let slice_ptr: *mut [T] = mem::take::<&'data mut [T]>(&mut self.slice);
239
0
        unsafe { ptr::drop_in_place::<[T]>(slice_ptr) };
240
0
    }
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u16>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u16>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::DrainProducer<rav1e::tiling::tiler::TileContextMut<u8>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::DrainProducer<av_scenechange::data::tile::TileContextMut<u8>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::DrainProducer<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::DrainProducer<_> as core::ops::drop::Drop>::drop
241
}
242
243
// ////////////////////////////////////////////////////////////////////////
244
245
// like std::vec::Drain, without updating a source Vec
246
pub(crate) struct SliceDrain<'data, T> {
247
    iter: slice::IterMut<'data, T>,
248
}
249
250
impl<'data, T: 'data> Iterator for SliceDrain<'data, T> {
251
    type Item = T;
252
253
0
    fn next(&mut self) -> Option<T> {
254
        // Coerce the pointer early, so we don't keep the
255
        // reference that's about to be invalidated.
256
0
        let ptr: *const T = self.iter.next()?;
257
0
        Some(unsafe { ptr::read(ptr) })
258
0
    }
Unexecuted instantiation: <rayon::vec::SliceDrain<rav1e::tiling::tiler::TileContextMut<u16>> as core::iter::traits::iterator::Iterator>::next
Unexecuted instantiation: <rayon::vec::SliceDrain<av_scenechange::data::tile::TileContextMut<u16>> as core::iter::traits::iterator::Iterator>::next
Unexecuted instantiation: <rayon::vec::SliceDrain<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as core::iter::traits::iterator::Iterator>::next
Unexecuted instantiation: <rayon::vec::SliceDrain<rav1e::tiling::tiler::TileContextMut<u8>> as core::iter::traits::iterator::Iterator>::next
Unexecuted instantiation: <rayon::vec::SliceDrain<av_scenechange::data::tile::TileContextMut<u8>> as core::iter::traits::iterator::Iterator>::next
Unexecuted instantiation: <rayon::vec::SliceDrain<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as core::iter::traits::iterator::Iterator>::next
Unexecuted instantiation: <rayon::vec::SliceDrain<_> as core::iter::traits::iterator::Iterator>::next
259
260
0
    fn size_hint(&self) -> (usize, Option<usize>) {
261
0
        self.iter.size_hint()
262
0
    }
263
264
0
    fn count(self) -> usize {
265
0
        self.iter.len()
266
0
    }
267
}
268
269
impl<'data, T: 'data> DoubleEndedIterator for SliceDrain<'data, T> {
270
0
    fn next_back(&mut self) -> Option<Self::Item> {
271
        // Coerce the pointer early, so we don't keep the
272
        // reference that's about to be invalidated.
273
0
        let ptr: *const T = self.iter.next_back()?;
274
0
        Some(unsafe { ptr::read(ptr) })
275
0
    }
276
}
277
278
impl<'data, T: 'data> ExactSizeIterator for SliceDrain<'data, T> {
279
0
    fn len(&self) -> usize {
280
0
        self.iter.len()
281
0
    }
282
}
283
284
impl<'data, T: 'data> iter::FusedIterator for SliceDrain<'data, T> {}
285
286
impl<'data, T: 'data> Drop for SliceDrain<'data, T> {
287
0
    fn drop(&mut self) {
288
        // extract the iterator so we can use `Drop for [T]`
289
0
        let slice_ptr: *mut [T] = mem::replace(&mut self.iter, [].iter_mut()).into_slice();
290
0
        unsafe { ptr::drop_in_place::<[T]>(slice_ptr) };
291
0
    }
Unexecuted instantiation: <rayon::vec::SliceDrain<rav1e::tiling::tiler::TileContextMut<u16>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::SliceDrain<av_scenechange::data::tile::TileContextMut<u16>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::SliceDrain<(rav1e::tiling::tiler::TileContextMut<u16>, &mut rav1e::context::cdf_context::CDFContext)> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::SliceDrain<rav1e::tiling::tiler::TileContextMut<u8>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::SliceDrain<av_scenechange::data::tile::TileContextMut<u8>> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::SliceDrain<(rav1e::tiling::tiler::TileContextMut<u8>, &mut rav1e::context::cdf_context::CDFContext)> as core::ops::drop::Drop>::drop
Unexecuted instantiation: <rayon::vec::SliceDrain<_> as core::ops::drop::Drop>::drop
292
}