using System; using System.Collections.Generic; using System.Text; using System.IO; namespace HH.WMS.Utils.NPOI.Util { public class ByteArrayInputStream : Stream { public ByteArrayInputStream() { } protected byte[] buf; protected int pos; protected int mark = 0; protected int count; public ByteArrayInputStream(byte[] buf) { this.buf = buf; this.pos = 0; this.count = buf.Length; } public ByteArrayInputStream(byte[] buf, int offset, int length) { this.buf = buf; this.pos = offset; this.count = Math.Min(offset + length, buf.Length); this.mark = offset; } public virtual int Read() { lock (this) { return (pos < count) ? (buf[pos++] & 0xff) : -1; } } public override int Read(byte[] b, int off, int len) { lock (this) { if (b == null) { throw new NullReferenceException(); } else if (off < 0 || len < 0 || len > b.Length - off) { throw new IndexOutOfRangeException(); } if (pos >= count) { return -1; } int avail = count - pos; if (len > avail) { len = avail; } if (len <= 0) { return 0; } Array.Copy(buf, pos, b, off, len); pos += len; return len; } } public virtual int Available() { return count - pos; } public virtual bool MarkSupported() { return true; } public virtual void Mark(int readAheadLimit) { mark = pos; } public virtual void Reset() { pos = mark; } public override void Close() { } public override bool CanRead { get { return true; } } public override bool CanWrite { get { return false; } } public override bool CanSeek { get { return true; } } public override void Flush() { throw new NotImplementedException(); } public override long Length { get { return this.count; } } public override long Position { get { return this.pos; } set { this.pos = (int)value; } } public override long Seek(long offset, SeekOrigin origin) { if (!this.CanSeek) throw new NotSupportedException(); switch (origin) { case SeekOrigin.Begin: if (0L > offset) { throw new ArgumentOutOfRangeException("offset", "offset must be positive"); } this.Position = offset < this.Length ? offset : this.Length; break; case SeekOrigin.Current: this.Position = (this.Position + offset) < this.Length ? (this.Position + offset) : this.Length; break; case SeekOrigin.End: this.Position = this.Length; break; default: throw new ArgumentException("incorrect SeekOrigin", "origin"); } return Position; } public override void SetLength(long value) { } public override void Write(byte[] buffer, int offset, int count) { throw new NotImplementedException(); } } }