Mercurial > 510Connectbot
diff src/com/jcraft/jzlib/ZOutputStream.java @ 357:46c2115ae1c8
update jzlib to a21be20213d66eff15904d925e9b721956a01ef7
author | Carl Byington <carl@five-ten-sg.com> |
---|---|
date | Fri, 01 Aug 2014 13:34:58 -0700 |
parents | 0ce5cc452d02 |
children |
line wrap: on
line diff
--- a/src/com/jcraft/jzlib/ZOutputStream.java Fri Aug 01 11:57:17 2014 -0700 +++ b/src/com/jcraft/jzlib/ZOutputStream.java Fri Aug 01 13:34:58 2014 -0700 @@ -1,6 +1,6 @@ /* -*-mode:java; c-basic-offset:2; indent-tabs-mode:nil -*- */ /* -Copyright (c) 2001 Lapo Luchini. +Copyright (c) 2011 ymnk, JCraft,Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: @@ -8,8 +8,8 @@ 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. - 2. Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 3. The names of the authors may not be used to endorse or promote products @@ -17,8 +17,8 @@ THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND -FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS -OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF @@ -26,143 +26,134 @@ NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -/* - * This program is based on zlib-1.1.3, so all credit should go authors - * Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu) - * and contributors of zlib. - */ package com.jcraft.jzlib; import java.io.*; -public class ZOutputStream extends OutputStream { - - protected ZStream z = new ZStream(); - protected int bufsize = 512; - protected int flush = JZlib.Z_NO_FLUSH; - protected byte[] buf = new byte[bufsize], - buf1 = new byte[1]; - protected boolean compress; - - protected OutputStream out; +/** + * ZOutputStream + * + * @deprecated use DeflaterOutputStream or InflaterInputStream + */ +@Deprecated +public class ZOutputStream extends FilterOutputStream { - public ZOutputStream(OutputStream out) { - super(); - this.out = out; - z.inflateInit(); - compress = false; - } + protected int bufsize=512; + protected int flush=JZlib.Z_NO_FLUSH; + protected byte[] buf=new byte[bufsize]; + protected boolean compress; - public ZOutputStream(OutputStream out, int level) { - this(out, level, false); - } - public ZOutputStream(OutputStream out, int level, boolean nowrap) { - super(); - this.out = out; - z.deflateInit(level, nowrap); - compress = true; - } + protected OutputStream out; + private boolean end=false; + + private DeflaterOutputStream dos; + private Inflater inflater; - public void write(int b) throws IOException { - buf1[0] = (byte)b; - write(buf1, 0, 1); - } + public ZOutputStream(OutputStream out) throws IOException { + super(out); + this.out=out; + inflater = new Inflater(); + inflater.init(); + compress=false; + } - public void write(byte b[], int off, int len) throws IOException { - if (len == 0) - return; - - int err; - z.next_in = b; - z.next_in_index = off; - z.avail_in = len; + public ZOutputStream(OutputStream out, int level) throws IOException { + this(out, level, false); + } - do { - z.next_out = buf; - z.next_out_index = 0; - z.avail_out = bufsize; - - if (compress) - err = z.deflate(flush); - else - err = z.inflate(flush); + public ZOutputStream(OutputStream out, int level, boolean nowrap) throws IOException { + super(out); + this.out=out; + Deflater deflater = new Deflater(level, nowrap); + dos = new DeflaterOutputStream(out, deflater); + compress=true; + } - if (err != JZlib.Z_OK) - throw new ZStreamException((compress ? "de" : "in") + "flating: " + z.msg); - - out.write(buf, 0, bufsize - z.avail_out); - } - while (z.avail_in > 0 || z.avail_out == 0); - } - - public int getFlushMode() { - return (flush); - } + private byte[] buf1 = new byte[1]; + public void write(int b) throws IOException { + buf1[0]=(byte)b; + write(buf1, 0, 1); + } - public void setFlushMode(int flush) { - this.flush = flush; + public void write(byte b[], int off, int len) throws IOException { + if(len==0) return; + if(compress){ + dos.write(b, off, len); } - - public void finish() throws IOException { - int err; - - do { - z.next_out = buf; - z.next_out_index = 0; - z.avail_out = bufsize; - - if (compress) { err = z.deflate(JZlib.Z_FINISH); } - else { err = z.inflate(JZlib.Z_FINISH); } + else { + inflater.setInput(b, off, len, true); + int err = JZlib.Z_OK; + while(inflater.avail_in>0){ + inflater.setOutput(buf, 0, buf.length); + err = inflater.inflate(flush); + if(inflater.next_out_index>0) + out.write(buf, 0, inflater.next_out_index); + if(err != JZlib.Z_OK) + break; + } + if(err != JZlib.Z_OK) + throw new ZStreamException("inflating: "+inflater.msg); + return; + } + } - if (err != JZlib.Z_STREAM_END && err != JZlib.Z_OK) - throw new ZStreamException((compress ? "de" : "in") + "flating: " + z.msg); - - if (bufsize - z.avail_out > 0) { - out.write(buf, 0, bufsize - z.avail_out); - } - } - while (z.avail_in > 0 || z.avail_out == 0); + public int getFlushMode() { + return flush; + } - flush(); - } - public void end() { - if (z == null) - return; - - if (compress) { z.deflateEnd(); } - else { z.inflateEnd(); } + public void setFlushMode(int flush) { + this.flush=flush; + } - z.free(); - z = null; + public void finish() throws IOException { + int err; + if(compress){ + int tmp = flush; + int flush = JZlib.Z_FINISH; + try{ + write("".getBytes(), 0, 0); + } + finally { flush = tmp; } + } + else{ + dos.finish(); } - public void close() throws IOException { - try { - try {finish();} - catch (IOException ignored) {} - } - finally { - end(); - out.close(); - out = null; - } + flush(); + } + public synchronized void end() { + if(end) return; + if(compress){ + try { dos.finish(); } catch(Exception e){} + } + else{ + inflater.end(); } + end=true; + } + public void close() throws IOException { + try{ + try{finish();} + catch (IOException ignored) {} + } + finally{ + end(); + out.close(); + out=null; + } + } - /** - * Returns the total number of bytes input so far. - */ - public long getTotalIn() { - return z.total_in; - } + public long getTotalIn() { + if(compress) return dos.getTotalIn(); + else return inflater.total_in; + } - /** - * Returns the total number of bytes output so far. - */ - public long getTotalOut() { - return z.total_out; - } + public long getTotalOut() { + if(compress) return dos.getTotalOut(); + else return inflater.total_out; + } - public void flush() throws IOException { - out.flush(); - } + public void flush() throws IOException { + out.flush(); + } }