Skip to content

Commit 134d40d

Browse files
committed
---
yaml --- r: 46091 b: refs/heads/try2 c: 5aa0463 h: refs/heads/master i: 46089: bee9814 46087: 04cac8a v: v3
1 parent d46756a commit 134d40d

File tree

2 files changed

+6
-9
lines changed

2 files changed

+6
-9
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ refs/heads/snap-stage3: a6d9689399d091c3265f00434a69c551a61c28dc
55
refs/heads/try: ef355f6332f83371e4acf04fc4eb940ab41d78d3
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
8-
refs/heads/try2: a2573290710f4b3f14be475f4ef2af773de7b4c7
8+
refs/heads/try2: 5aa04635647287481ceca44cf557b698666fa939
99
refs/heads/incoming: 210fa2d0172c10112196e8fcf640e32ee54944fe
1010
refs/heads/dist-snap: 8b98e5a296d95c5e832db0756828e5bec31c6f50
1111
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596

branches/try2/src/libstd/deque.rs

Lines changed: 5 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -98,17 +98,14 @@ impl<T: Copy> Deque<T> {
9898

9999
/// Grow is only called on full elts, so nelts is also len(elts), unlike
100100
/// elsewhere.
101-
fn grow<T: Copy>(nelts: uint, lo: uint, elts: &[Option<T>]) -> ~[Option<T>] {
101+
fn grow<T>(nelts: uint, lo: uint, elts: &mut [Option<T>]) -> ~[Option<T>] {
102102
assert nelts == elts.len();
103103
let mut rv = ~[];
104104

105-
let mut i = 0u;
106-
let nalloc = uint::next_power_of_two(nelts + 1u);
107-
while i < nalloc {
108-
if i < nelts {
109-
rv.push(elts[(lo + i) % nelts]);
110-
} else { rv.push(None); }
111-
i += 1u;
105+
do vec::grow_fn(&mut rv, nelts + 1) |i| {
106+
let mut element = None;
107+
element <-> elts[(lo + i) % nelts];
108+
element
112109
}
113110

114111
rv

0 commit comments

Comments
 (0)