| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- using System;
- using System.Collections.Generic;
- using System.IO;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
-
- namespace System.IO.Packaging
- {
- internal class ZipPartStream : Stream
- {
- public MemoryStream BaseStream { get; private set; }
- public ZipPackage Package { get; private set; }
-
- public override bool CanRead
- {
- get
- {
- return BaseStream.CanRead;
- }
- }
-
- public override bool CanSeek
- {
- get
- {
- return BaseStream.CanSeek;
- }
- }
-
- public override bool CanTimeout
- {
- get { return BaseStream.CanTimeout; }
- }
-
- public override bool CanWrite
- {
- get { return Writeable; }
- }
-
- public override long Length
- {
- get { return BaseStream.Length; }
- }
-
- public override long Position
- {
- get;
- set;
- }
-
- public bool Writeable
- {
- get;
- set;
- }
-
- public override int WriteTimeout
- {
- get
- {
- return BaseStream.WriteTimeout;
- }
- set
- {
- BaseStream.WriteTimeout = value;
- }
- }
-
- public override int ReadTimeout
- {
- get
- {
- return BaseStream.ReadTimeout;
- }
- set
- {
- BaseStream.ReadTimeout = value;
- }
- }
-
- public ZipPartStream(ZipPackage package, MemoryStream stream, FileAccess access)
- {
- BaseStream = stream;
- Package = package;
- Writeable = access != FileAccess.Read;
- }
-
- public override void Flush()
- {
- // If the user flushes any of the part streams,
- // we need to flush the entire package
-
- // FIXME: Ensure that this actually happens with a testcase
- // ...if possible
- // Package.Flush();
- }
-
- public override int Read(byte[] buffer, int offset, int count)
- {
- Seek(Position, SeekOrigin.Begin);
- int read = BaseStream.Read(buffer, offset, count);
- Position += read;
- return read;
- }
-
- public override long Seek(long offset, SeekOrigin origin)
- {
- Position = BaseStream.Seek(offset, origin);
- return Position;
- }
-
- public override void SetLength(long value)
- {
- if (!CanWrite)
- throw new InvalidOperationException("Stream is not writeable");
-
- BaseStream.SetLength(value);
- }
-
- public override void Write(byte[] buffer, int offset, int count)
- {
- if (!CanWrite)
- throw new InvalidOperationException("Stream is not writeable");
-
- Seek(Position, SeekOrigin.Begin);
- BaseStream.Write(buffer, offset, count);
- Position += count;
- }
- }
- }
|