]> git.lizzy.rs Git - rust.git/commitdiff
Use `len` instead of `size_hint` where appropiate
authorTobias Bucher <tobiasbucher5991@gmail.com>
Thu, 23 Jun 2016 10:26:15 +0000 (12:26 +0200)
committerTobias Bucher <tobiasbucher5991@gmail.com>
Thu, 23 Jun 2016 10:26:15 +0000 (12:26 +0200)
This makes it clearer that we're not just looking for a lower bound but
rather know that the iterator is an `ExactSizeIterator`.

src/libcollections/vec.rs
src/libcore/fmt/mod.rs
src/libcore/slice.rs
src/libcore/str/mod.rs
src/libcore/str/pattern.rs
src/libstd/sys/common/wtf8.rs

index bd1bf6e9cc37591b3269d2e1ad6308ab2fd54a48..9797113b8ad66450ac1934404e9acad9c112456a 100644 (file)
@@ -1658,7 +1658,7 @@ fn size_hint(&self) -> (usize, Option<usize>) {
 
     #[inline]
     fn count(self) -> usize {
-        self.size_hint().0
+        self.len()
     }
 }
 
index 6579e5dab543245ccd56934ec787974880d00adf..4ac134c2b59c8d9535d1b1d449809be809d449a4 100644 (file)
@@ -1384,7 +1384,7 @@ fn fmt(&self, f: &mut Formatter) -> Result {
         for (i, c) in self.char_indices() {
             let esc = c.escape_default();
             // If char needs escaping, flush backlog so far and write, else skip
-            if esc.size_hint() != (1, Some(1)) {
+            if esc.len() != 1 {
                 f.write_str(&self[from..i])?;
                 for c in esc {
                     f.write_char(c)?;
index 727c26ba9abd144c9910ff1f864b73dfbea3b6ae..4f11cac4eb2bec7b7e7ba6c4346e78fd5f3ed354 100644 (file)
@@ -835,7 +835,7 @@ fn size_hint(&self) -> (usize, Option<usize>) {
 
             #[inline]
             fn count(self) -> usize {
-                self.size_hint().0
+                self.len()
             }
 
             #[inline]
@@ -1444,7 +1444,7 @@ fn size_hint(&self) -> (usize, Option<usize>) {
 
     #[inline]
     fn count(self) -> usize {
-        self.size_hint().0
+        self.len()
     }
 
     #[inline]
@@ -1541,7 +1541,7 @@ fn size_hint(&self) -> (usize, Option<usize>) {
 
     #[inline]
     fn count(self) -> usize {
-        self.size_hint().0
+        self.len()
     }
 
     #[inline]
@@ -1632,7 +1632,7 @@ fn size_hint(&self) -> (usize, Option<usize>) {
 
     #[inline]
     fn count(self) -> usize {
-        self.size_hint().0
+        self.len()
     }
 
     #[inline]
index 5fc15fae5199bd344a1920248201adb721fd92ad..9016d1a4d552cdc9bbff37e021697f076143c912 100644 (file)
@@ -433,7 +433,7 @@ fn next(&mut self) -> Option<char> {
 
     #[inline]
     fn size_hint(&self) -> (usize, Option<usize>) {
-        let (len, _) = self.iter.size_hint();
+        let len = self.iter.len();
         // `(len + 3)` can't overflow, because we know that the `slice::Iter`
         // belongs to a slice in memory which has a maximum length of
         // `isize::MAX` (that's well below `usize::MAX`).
@@ -480,12 +480,12 @@ impl<'a> Iterator for CharIndices<'a> {
 
     #[inline]
     fn next(&mut self) -> Option<(usize, char)> {
-        let (pre_len, _) = self.iter.iter.size_hint();
+        let pre_len = self.iter.iter.len();
         match self.iter.next() {
             None => None,
             Some(ch) => {
                 let index = self.front_offset;
-                let (len, _) = self.iter.iter.size_hint();
+                let len = self.iter.iter.len();
                 self.front_offset += pre_len - len;
                 Some((index, ch))
             }
@@ -505,8 +505,7 @@ fn next_back(&mut self) -> Option<(usize, char)> {
         match self.iter.next_back() {
             None => None,
             Some(ch) => {
-                let (len, _) = self.iter.iter.size_hint();
-                let index = self.front_offset + len;
+                let index = self.front_offset + self.iter.iter.len();
                 Some((index, ch))
             }
         }
index b803539e12b1a2fd6d91a26d56fb854851168340..53804c611e66ed52dc196b01e68eee88cce6820b 100644 (file)
@@ -310,9 +310,9 @@ fn next(&mut self) -> SearchStep {
         let s = &mut self.char_indices;
         // Compare lengths of the internal byte slice iterator
         // to find length of current char
-        let (pre_len, _) = s.iter.iter.size_hint();
+        let pre_len = s.iter.iter.len();
         if let Some((i, c)) = s.next() {
-            let (len, _) = s.iter.iter.size_hint();
+            let len = s.iter.iter.len();
             let char_len = pre_len - len;
             if self.char_eq.matches(c) {
                 return SearchStep::Match(i, i + char_len);
@@ -330,9 +330,9 @@ fn next_back(&mut self) -> SearchStep {
         let s = &mut self.char_indices;
         // Compare lengths of the internal byte slice iterator
         // to find length of current char
-        let (pre_len, _) = s.iter.iter.size_hint();
+        let pre_len = s.iter.iter.len();
         if let Some((i, c)) = s.next_back() {
-            let (len, _) = s.iter.iter.size_hint();
+            let len = s.iter.iter.len();
             let char_len = pre_len - len;
             if self.char_eq.matches(c) {
                 return SearchStep::Match(i, i + char_len);
index d705b8986d0b1108d23985c1820004aa36ed9296..b6be85a4dfa2879b04548c74964195a5f3f8c1ce 100644 (file)
@@ -715,7 +715,7 @@ fn next(&mut self) -> Option<CodePoint> {
 
     #[inline]
     fn size_hint(&self) -> (usize, Option<usize>) {
-        let (len, _) = self.bytes.size_hint();
+        let len = self.bytes.len();
         (len.saturating_add(3) / 4, Some(len))
     }
 }