Mercurial > 510Connectbot
diff src/com/jcraft/jzlib/Adler32.java @ 0:0ce5cc452d02
initial version
author | Carl Byington <carl@five-ten-sg.com> |
---|---|
date | Thu, 22 May 2014 10:41:19 -0700 |
parents | |
children | 46c2115ae1c8 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/com/jcraft/jzlib/Adler32.java Thu May 22 10:41:19 2014 -0700 @@ -0,0 +1,98 @@ +/* -*-mode:java; c-basic-offset:2; -*- */ +/* +Copyright (c) 2000,2001,2002,2003 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: + + 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 + 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 + derived from this software without specific prior written permission. + +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 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 +LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +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; + +final class Adler32 { + + // largest prime smaller than 65536 + static final private int BASE = 65521; + // NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 + static final private int NMAX = 5552; + + long adler32(long adler, byte[] buf, int index, int len) { + if (buf == null) { return 1L; } + + long s1 = adler & 0xffff; + long s2 = (adler >> 16) & 0xffff; + int k; + + while (len > 0) { + k = len < NMAX ? len : NMAX; + len -= k; + + while (k >= 16) { + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + s1 += buf[index++] & 0xff; s2 += s1; + k -= 16; + } + + if (k != 0) { + do { + s1 += buf[index++] & 0xff; s2 += s1; + } + while (--k != 0); + } + + s1 %= BASE; + s2 %= BASE; + } + + return (s2 << 16) | s1; + } + + /* + private java.util.zip.Adler32 adler=new java.util.zip.Adler32(); + long adler32(long value, byte[] buf, int index, int len){ + if(value==1) {adler.reset();} + if(buf==null) {adler.reset();} + else{adler.update(buf, index, len);} + return adler.getValue(); + } + */ +}