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();
+  }
 
 }