Skip to content

Commit 162aea4

Browse files
committed
---
yaml --- r: 104001 b: refs/heads/try c: 71c88e7 h: refs/heads/master i: 103999: af1d22c v: v3
1 parent 286bf23 commit 162aea4

File tree

2 files changed

+10
-2
lines changed

2 files changed

+10
-2
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
refs/heads/master: 62f1d68439dcfd509eaca29887afa97f22938373
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: 6e7f170fedd3c526a643c0b2d13863acd982be02
5-
refs/heads/try: e9c539a488a5b59293b24701b8f121fb7fae1636
5+
refs/heads/try: 71c88e7f47ff2c250f26f2e4a2742de0028526e5
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: 147ecfdd8221e4a4d4e090486829a06da1e0ca3c

branches/try/src/libstd/io/mem.rs

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -312,7 +312,11 @@ impl<'a> Seek for BufReader<'a> {
312312

313313
impl<'a> Buffer for BufReader<'a> {
314314
fn fill<'a>(&'a mut self) -> IoResult<&'a [u8]> {
315-
Ok(self.buf.slice_from(self.pos))
315+
if self.pos < self.buf.len() {
316+
Ok(self.buf.slice_from(self.pos))
317+
} else {
318+
Err(io::standard_error(io::EndOfFile))
319+
}
316320
}
317321
fn consume(&mut self, amt: uint) { self.pos += amt; }
318322
}
@@ -449,6 +453,10 @@ mod test {
449453
assert_eq!(reader.read(buf), Ok(3));
450454
assert_eq!(buf.slice(0, 3), [5, 6, 7]);
451455
assert!(reader.read(buf).is_err());
456+
let mut reader = BufReader::new(in_buf);
457+
assert_eq!(reader.read_until(3).unwrap(), ~[0, 1, 2, 3]);
458+
assert_eq!(reader.read_until(3).unwrap(), ~[4, 5, 6, 7]);
459+
assert!(reader.read(buf).is_err());
452460
}
453461

454462
#[test]

0 commit comments

Comments
 (0)