Skip to content

Commit f4a0a82

Browse files
committed
---
yaml --- r: 272233 b: refs/heads/auto c: 2084f2e h: refs/heads/master i: 272231: 6ca9c8f
1 parent 1032a7c commit f4a0a82

File tree

4 files changed

+77
-1
lines changed

4 files changed

+77
-1
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503
88
refs/tags/release-0.3.1: 495bae036dfe5ec6ceafd3312b4dca48741e845b
99
refs/tags/release-0.4: e828ea2080499553b97dfe33b3f4d472b4562ad7
1010
refs/tags/release-0.5: 7e3bcfbf21278251ee936ad53e92e9b719702d73
11-
refs/heads/auto: 5972b22b7cdf2c4de2729ee874c1742a4ae97589
11+
refs/heads/auto: 2084f2ed77e28d78c8dfbd378251b29068a8c579
1212
refs/tags/release-0.6: b4ebcfa1812664df5e142f0134a5faea3918544c
1313
refs/tags/0.1: b19db808c2793fe2976759b85a355c3ad8c8b336
1414
refs/tags/0.2: 1754d02027f2924bed83b0160ee340c7f41d5ea1

branches/auto/src/libcollections/btree/map.rs

Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -285,6 +285,12 @@ pub struct Values<'a, K: 'a, V: 'a> {
285285
inner: Iter<'a, K, V>,
286286
}
287287

288+
/// A mutable iterator over a BTreeMap's values.
289+
#[unstable(feature = "map_values_mut", reason = "recently added", issue = "32551")]
290+
pub struct ValuesMut<'a, K: 'a, V: 'a> {
291+
inner: IterMut<'a, K, V>,
292+
}
293+
288294
/// An iterator over a sub-range of BTreeMap's entries.
289295
pub struct Range<'a, K: 'a, V: 'a> {
290296
front: Handle<NodeRef<marker::Immut<'a>, K, V, marker::Leaf>, marker::Edge>,
@@ -1006,6 +1012,33 @@ impl<'a, K, V> Iterator for Range<'a, K, V> {
10061012
}
10071013
}
10081014

1015+
#[unstable(feature = "map_values_mut", reason = "recently added", issue = "32551")]
1016+
impl<'a, K, V> Iterator for ValuesMut<'a, K, V> {
1017+
type Item = &'a mut V;
1018+
1019+
fn next(&mut self) -> Option<&'a mut V> {
1020+
self.inner.next().map(|(_, v)| v)
1021+
}
1022+
1023+
fn size_hint(&self) -> (usize, Option<usize>) {
1024+
self.inner.size_hint()
1025+
}
1026+
}
1027+
1028+
#[unstable(feature = "map_values_mut", reason = "recently added", issue = "32551")]
1029+
impl<'a, K, V> DoubleEndedIterator for ValuesMut<'a, K, V> {
1030+
fn next_back(&mut self) -> Option<&'a mut V> {
1031+
self.inner.next_back().map(|(_, v)| v)
1032+
}
1033+
}
1034+
1035+
#[unstable(feature = "map_values_mut", reason = "recently added", issue = "32551")]
1036+
impl<'a, K, V> ExactSizeIterator for ValuesMut<'a, K, V> {
1037+
fn len(&self) -> usize {
1038+
self.inner.len()
1039+
}
1040+
}
1041+
10091042
impl<'a, K, V> Range<'a, K, V> {
10101043
unsafe fn next_unchecked(&mut self) -> (&'a K, &'a V) {
10111044
let handle = self.front;
@@ -1403,6 +1436,33 @@ impl<K, V> BTreeMap<K, V> {
14031436
Values { inner: self.iter() }
14041437
}
14051438

1439+
/// Gets a mutable iterator over the values of the map, in order by key.
1440+
///
1441+
/// # Examples
1442+
///
1443+
/// Basic usage:
1444+
///
1445+
/// ```
1446+
/// # #![feature(map_values_mut)]
1447+
/// use std::collections::BTreeMap;
1448+
///
1449+
/// let mut a = BTreeMap::new();
1450+
/// a.insert(1, String::from("hello"));
1451+
/// a.insert(2, String::from("goodbye"));
1452+
///
1453+
/// for value in a.values_mut() {
1454+
/// value.push_str("!");
1455+
/// }
1456+
///
1457+
/// let values: Vec<String> = a.values().cloned().collect();
1458+
/// assert_eq!(values, [String::from("hello!"),
1459+
/// String::from("goodbye!")]);
1460+
/// ```
1461+
#[unstable(feature = "map_values_mut", reason = "recently added", issue = "32551")]
1462+
pub fn values_mut<'a>(&'a mut self) -> ValuesMut<'a, K, V> {
1463+
ValuesMut { inner: self.iter_mut() }
1464+
}
1465+
14061466
/// Returns the number of elements in the map.
14071467
///
14081468
/// # Examples

branches/auto/src/libcollectionstest/btree/map.rs

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -114,6 +114,21 @@ fn test_iter_rev() {
114114
test(size, map.into_iter().rev());
115115
}
116116

117+
#[test]
118+
fn test_values_mut() {
119+
let mut a = BTreeMap::new();
120+
a.insert(1, String::from("hello"));
121+
a.insert(2, String::from("goodbye"));
122+
123+
for value in a.values_mut() {
124+
value.push_str("!");
125+
}
126+
127+
let values: Vec<String> = a.values().cloned().collect();
128+
assert_eq!(values, [String::from("hello!"),
129+
String::from("goodbye!")]);
130+
}
131+
117132
#[test]
118133
fn test_iter_mixed() {
119134
let size = 10000;

branches/auto/src/libcollectionstest/lib.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@
2222
#![feature(enumset)]
2323
#![feature(iter_arith)]
2424
#![feature(map_entry_keys)]
25+
#![feature(map_values_mut)]
2526
#![feature(pattern)]
2627
#![feature(rand)]
2728
#![feature(set_recovery)]

0 commit comments

Comments
 (0)