Implement .zip() specialization for Map and Cloned. The crucial thing for transparent specialization is that we want to preserve the potential side effects. The simplest example is that in this code snippet: `(0..6).map(f).zip((0..4).map(g)).count()` `f` will be called five times, and `g` four times. The last time for `f` is when the other iterator is at its end, so this element is unused. This side effect can be preserved without disturbing code generation for simple uses of `.map()`. The `Zip::next_back()` case is even more complicated, unfortunately.
29 lines
1.1 KiB
Rust
29 lines
1.1 KiB
Rust
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
|
|
/// An iterator whose items are random accessible efficiently
|
|
///
|
|
/// # Safety
|
|
///
|
|
/// The iterator's .len() and size_hint() must be exact.
|
|
/// `.len()` must be cheap to call.
|
|
///
|
|
/// .get_unchecked() must return distinct mutable references for distinct
|
|
/// indices (if applicable), and must return a valid reference if index is in
|
|
/// 0..self.len().
|
|
#[doc(hidden)]
|
|
pub unsafe trait TrustedRandomAccess : ExactSizeIterator {
|
|
unsafe fn get_unchecked(&mut self, i: usize) -> Self::Item;
|
|
/// Return `true` if getting an iterator element may have
|
|
/// side effects. Remember to take inner iterators into account.
|
|
fn may_have_side_effect() -> bool;
|
|
}
|