All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.scurrilous.circe.crc.AbstractIntCrc Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright 2014 Trevor Robinson
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *   http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 ******************************************************************************/
package com.scurrilous.circe.crc;

import com.scurrilous.circe.impl.AbstractIncrementalIntHash;

/**
 * Base implementation of int-width CRC functions.
 */
abstract class AbstractIntCrc extends AbstractIncrementalIntHash {

    private final String algorithm;
    protected final int bitWidth;
    private final int initial;
    private final int xorOut;

    AbstractIntCrc(String algorithm, int bitWidth, int initial, int xorOut) {
        if (bitWidth < 1 || bitWidth > 32)
            throw new IllegalArgumentException("invalid CRC width");
        this.algorithm = algorithm;
        this.bitWidth = bitWidth;
        this.initial = initial;
        this.xorOut = xorOut;
    }

    @Override
    public String algorithm() {
        return algorithm;
    }

    @Override
    public int length() {
        return (bitWidth + 7) / 8;
    }

    @Override
    protected int initial() {
        return initial ^ xorOut;
    }

    @Override
    protected int resumeUnchecked(int current, byte[] input, int index, int length) {
        return resumeRaw(current ^ xorOut, input, index, length) ^ xorOut;
    }

    protected abstract int resumeRaw(int crc, byte[] input, int index, int length);

    protected final int reflect(int value) {
        return Integer.reverse(value) >>> (32 - bitWidth);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy