Skip to content

Commit 862928b

Browse files
committed
---
yaml --- r: 149029 b: refs/heads/try2 c: 49ac48d h: refs/heads/master i: 149027: f636595 v: v3
1 parent ce727ac commit 862928b

File tree

2 files changed

+19
-3
lines changed

2 files changed

+19
-3
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: 78a7676898d9f80ab540c6df5d4c9ce35bb50463
55
refs/heads/try: 519addf6277dbafccbb4159db4b710c37eaa2ec5
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
8-
refs/heads/try2: 337e62e4d65e24682ba323b65283a59715a0c8af
8+
refs/heads/try2: 49ac48db3fe2666751908668ba8e5ab16e2fb07a
99
refs/heads/dist-snap: ba4081a5a8573875fed17545846f6f6902c8ba8d
1010
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596
1111
refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503

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

Lines changed: 18 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -177,7 +177,11 @@ impl Seek for MemReader {
177177

178178
impl Buffer for MemReader {
179179
fn fill<'a>(&'a mut self) -> IoResult<&'a [u8]> {
180-
Ok(self.buf.slice_from(self.pos))
180+
if self.pos < self.buf.len() {
181+
Ok(self.buf.slice_from(self.pos))
182+
} else {
183+
Err(io::standard_error(io::EndOfFile))
184+
}
181185
}
182186
fn consume(&mut self, amt: uint) { self.pos += amt; }
183187
}
@@ -308,7 +312,11 @@ impl<'a> Seek for BufReader<'a> {
308312

309313
impl<'a> Buffer for BufReader<'a> {
310314
fn fill<'a>(&'a mut self) -> IoResult<&'a [u8]> {
311-
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+
}
312320
}
313321
fn consume(&mut self, amt: uint) { self.pos += amt; }
314322
}
@@ -421,6 +429,10 @@ mod test {
421429
assert_eq!(reader.read(buf), Ok(3));
422430
assert_eq!(buf.slice(0, 3), [5, 6, 7]);
423431
assert!(reader.read(buf).is_err());
432+
let mut reader = MemReader::new(~[0, 1, 2, 3, 4, 5, 6, 7]);
433+
assert_eq!(reader.read_until(3).unwrap(), ~[0, 1, 2, 3]);
434+
assert_eq!(reader.read_until(3).unwrap(), ~[4, 5, 6, 7]);
435+
assert!(reader.read(buf).is_err());
424436
}
425437

426438
#[test]
@@ -441,6 +453,10 @@ mod test {
441453
assert_eq!(reader.read(buf), Ok(3));
442454
assert_eq!(buf.slice(0, 3), [5, 6, 7]);
443455
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());
444460
}
445461

446462
#[test]

0 commit comments

Comments
 (0)