diff options
| author | bors <bors@rust-lang.org> | 2013-09-14 01:16:00 -0700 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2013-09-14 01:16:00 -0700 |
| commit | fbafb41fff33cf9a7709ef50f7525fa5f9930d2b (patch) | |
| tree | 99da47d4759aae00022ca91faf9d457658923027 /src/libstd/rt | |
| parent | 2aa578efd9834e37ad52879ff10ee2c2aa938389 (diff) | |
| parent | ef964a162fb9100042714cc8fa70b37b200770bc (diff) | |
| download | rust-fbafb41fff33cf9a7709ef50f7525fa5f9930d2b.tar.gz rust-fbafb41fff33cf9a7709ef50f7525fa5f9930d2b.zip | |
auto merge of #9156 : sfackler/rust/buffered-fix, r=huonw
This is a workaround for #9155. Currently, any uses of BufferedStream outside of libstd ICE.
Diffstat (limited to 'src/libstd/rt')
| -rw-r--r-- | src/libstd/rt/io/buffered.rs | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/src/libstd/rt/io/buffered.rs b/src/libstd/rt/io/buffered.rs index 66446de4492..579e581d87e 100644 --- a/src/libstd/rt/io/buffered.rs +++ b/src/libstd/rt/io/buffered.rs @@ -187,31 +187,37 @@ impl<W: Writer> Decorator<W> for BufferedWriter<W> { } } -struct InternalBufferedWriter<W>(BufferedWriter<W>); +// FIXME #9155 this should be a newtype struct +struct InternalBufferedWriter<W> { + inner: BufferedWriter<W> +} impl<W: Reader> Reader for InternalBufferedWriter<W> { fn read(&mut self, buf: &mut [u8]) -> Option<uint> { - self.inner.read(buf) + self.inner.inner.read(buf) } fn eof(&mut self) -> bool { - self.inner.eof() + self.inner.inner.eof() } } /// Wraps a Stream and buffers input and output to and from it /// /// NOTE: `BufferedStream` will NOT flush its output buffer when dropped. -pub struct BufferedStream<S>(BufferedReader<InternalBufferedWriter<S>>); +// FIXME #9155 this should be a newtype struct +pub struct BufferedStream<S> { + priv inner: BufferedReader<InternalBufferedWriter<S>> +} impl<S: Stream> BufferedStream<S> { pub fn with_capacities(reader_cap: uint, writer_cap: uint, inner: S) -> BufferedStream<S> { let writer = BufferedWriter::with_capacity(writer_cap, inner); - let internal_writer = InternalBufferedWriter(writer); + let internal_writer = InternalBufferedWriter { inner: writer }; let reader = BufferedReader::with_capacity(reader_cap, internal_writer); - BufferedStream(reader) + BufferedStream { inner: reader } } pub fn new(inner: S) -> BufferedStream<S> { @@ -222,35 +228,35 @@ impl<S: Stream> BufferedStream<S> { impl<S: Stream> Reader for BufferedStream<S> { fn read(&mut self, buf: &mut [u8]) -> Option<uint> { - (**self).read(buf) + self.inner.read(buf) } fn eof(&mut self) -> bool { - (**self).eof() + self.inner.eof() } } impl<S: Stream> Writer for BufferedStream<S> { fn write(&mut self, buf: &[u8]) { - self.inner.write(buf) + self.inner.inner.inner.write(buf) } fn flush(&mut self) { - self.inner.flush() + self.inner.inner.inner.flush() } } impl<S: Stream> Decorator<S> for BufferedStream<S> { fn inner(self) -> S { - self.inner.inner() + self.inner.inner.inner.inner() } fn inner_ref<'a>(&'a self) -> &'a S { - self.inner.inner_ref() + self.inner.inner.inner.inner_ref() } fn inner_mut_ref<'a>(&'a mut self) -> &'a mut S { - self.inner.inner_mut_ref() + self.inner.inner.inner.inner_mut_ref() } } |
