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

com.abubusoft.kripton.common.DynamicByteBufferHelper Maven / Gradle / Ivy

There is a newer version: 8.2.0-rc.4
Show newest version
/*
 * Copyright 2013-2014 Richard M. Hightower
 * 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.
 *
 * __________                              _____          __   .__
 * \______   \ ____   ____   ____   /\    /     \ _____  |  | _|__| ____    ____
 *  |    |  _//  _ \ /  _ \ /    \  \/   /  \ /  \\__  \ |  |/ /  |/    \  / ___\
 *  |    |   (  <_> |  <_> )   |  \ /\  /    Y    \/ __ \|    <|  |   |  \/ /_/  >
 *  |______  /\____/ \____/|___|  / \/  \____|__  (____  /__|_ \__|___|  /\___  /
 *         \/                   \/              \/     \/     \/       \//_____/
 *      ____.                     ___________   _____    ______________.___.
 *     |    |____ ___  _______    \_   _____/  /  _  \  /   _____/\__  |   |
 *     |    \__  \\  \/ /\__  \    |    __)_  /  /_\  \ \_____  \  /   |   |
 * /\__|    |/ __ \\   /  / __ \_  |        \/    |    \/        \ \____   |
 * \________(____  /\_/  (____  / /_______  /\____|__  /_______  / / ______|
 *               \/           \/          \/         \/        \/  \/
 */

package com.abubusoft.kripton.common;

import java.nio.charset.StandardCharsets;

import com.abubusoft.kripton.exception.KriptonRuntimeException;

public class DynamicByteBufferHelper {

	public static byte[] grow(byte[] array, final int size) {
		byte[] newArray = new byte[array.length + size];
		System.arraycopy(array, 0, newArray, 0, array.length);
		return newArray;
	}

	public static byte[] grow(byte[] array) {

		byte[] newArray = new byte[array.length * 2];
		System.arraycopy(array, 0, newArray, 0, array.length);
		return newArray;
	}

	public static byte[] shrink(byte[] array, int size) {

		byte[] newArray = new byte[array.length - size];

		System.arraycopy(array, 0, newArray, 0, array.length - size);
		return newArray;
	}

	public static byte[] compact(byte[] array) {

		int nullCount = 0;
		for (byte ch : array) {

			if (ch == '\0') {
				nullCount++;
			}
		}
		byte[] newArray = new byte[array.length - nullCount];

		int j = 0;
		for (byte ch : array) {

			if (ch == '\0') {
				continue;
			}

			newArray[j] = ch;
			j++;
		}
		return newArray;
	}

	/**
	 * Creates an array of bytes
	 *
	 * @param size
	 *            size of the array you want to make
	 * @return array of bytes
	 */
	public static byte[] arrayOfByte(final int size) {
		return new byte[size];
	}

	/**
	 * @param array
	 *            array
	 * @return array
	 */

	public static byte[] array(final byte... array) {
		return array;
	}

	/**
	 * @param array
	 *            array
	 * @return array
	 */

	public static byte[] bytes(final byte... array) {
		return array;
	}

	/**
	 * @param str
	 *            string
	 * @return array
	 */

	public static byte[] bytes(String str) {
		return str.getBytes(StandardCharsets.UTF_8);
	}

	public static int len(byte[] array) {
		return array.length;
	}

	public static int lengthOf(byte[] array) {
		return array.length;
	}

	public static byte atIndex(final byte[] array, final int index) {
		return idx(array, index);
	}

	public static byte idx(final byte[] array, final int index) {
		final int i = calculateIndex(array, index);

		return array[i];
	}

	public static void atIndex(final byte[] array, int index, byte value) {
		idx(array, index, value);
	}

	public static void idx(final byte[] array, int index, byte value) {
		final int i = calculateIndex(array, index);

		array[i] = value;
	}

	public static byte[] sliceOf(byte[] array, int startIndex, int endIndex) {
		return slc(array, startIndex, endIndex);
	}

	public static byte[] slc(byte[] array, int startIndex, int endIndex) {

		final int start = calculateIndex(array, startIndex);
		final int end = calculateEndIndex(array, endIndex);
		final int newLength = end - start;

		if (newLength < 0) {
			throw new ArrayIndexOutOfBoundsException(String.format("start index %d, end index %d, length %d", startIndex, endIndex, array.length));
		}

		byte[] newArray = new byte[newLength];
		System.arraycopy(array, start, newArray, 0, newLength);
		return newArray;
	}

	public static byte[] sliceOf(byte[] array, int startIndex) {
		return slc(array, startIndex);
	}

	public static byte[] slc(byte[] array, int startIndex) {

		final int start = calculateIndex(array, startIndex);
		final int newLength = array.length - start;

		if (newLength < 0) {
			throw new ArrayIndexOutOfBoundsException(String.format("start index %d, length %d", startIndex, array.length));
		}

		byte[] newArray = new byte[newLength];
		System.arraycopy(array, start, newArray, 0, newLength);
		return newArray;
	}

	public static byte[] endSliceOf(byte[] array, int endIndex) {
		return slcEnd(array, endIndex);
	}

	public static byte[] slcEnd(byte[] array, int endIndex) {

		final int end = calculateEndIndex(array, endIndex);
		final int newLength = end; // + (endIndex < 0 ? 1 : 0);

		if (newLength < 0) {
			throw new ArrayIndexOutOfBoundsException(String.format("start index %d, length %d", endIndex, array.length));
		}

		byte[] newArray = new byte[newLength];
		System.arraycopy(array, 0, newArray, 0, newLength);
		return newArray;
	}

	public static boolean in(int value, byte... array) {
		for (int currentValue : array) {
			if (currentValue == value) {
				return true;
			}
		}
		return false;
	}

	public static boolean inIntArray(byte value, int[] array) {
		for (int currentValue : array) {
			if (currentValue == value) {
				return true;
			}
		}
		return false;
	}

	public static boolean in(int value, int offset, byte[] array) {
		for (int index = offset; index < array.length; index++) {
			int currentValue = array[index];
			if (currentValue == value) {
				return true;
			}
		}
		return false;
	}

	public static boolean in(int value, int offset, int end, byte[] array) {
		for (int index = offset; index < end; index++) {
			int currentValue = array[index];
			if (currentValue == value) {
				return true;
			}
		}
		return false;
	}

	public static byte[] copy(byte[] array) {
		byte[] newArray = new byte[array.length];
		System.arraycopy(array, 0, newArray, 0, array.length);
		return newArray;
	}

	public static byte[] copy(byte[] array, int offset, int length) {
		byte[] newArray = new byte[length];
		System.arraycopy(array, offset, newArray, 0, length);
		return newArray;
	}

	public static byte[] add(byte[] array, byte v) {
		byte[] newArray = new byte[array.length + 1];
		System.arraycopy(array, 0, newArray, 0, array.length);
		newArray[array.length] = v;
		return newArray;
	}

	public static byte[] add(byte[] array, byte[] array2) {
		byte[] newArray = new byte[array.length + array2.length];
		System.arraycopy(array, 0, newArray, 0, array.length);
		System.arraycopy(array2, 0, newArray, array.length, array2.length);
		return newArray;
	}

	public static byte[] insert(final byte[] array, final int idx, final byte v) {

		if (idx >= array.length) {
			return add(array, v);
		}

		final int index = calculateIndex(array, idx);

		// Object newArray =
		// Array.newInstance(array.getClass().getComponentType(),
		// array.length+1);
		byte[] newArray = new byte[array.length + 1];

		if (index != 0) {
			/* Copy up to the length in the array before the index. */
			/* src sbegin dst dbegin length of copy */
			System.arraycopy(array, 0, newArray, 0, index);
		}

		boolean lastIndex = index == array.length - 1;
		int remainingIndex = array.length - index;

		if (lastIndex) {
			/*
			 * Copy the area after the insert. Make sure we don't write over the
			 * end.
			 */
			/* src sbegin dst dbegin length of copy */
			System.arraycopy(array, index, newArray, index + 1, remainingIndex);

		} else {
			/* Copy the area after the insert. */
			/* src sbegin dst dbegin length of copy */
			System.arraycopy(array, index, newArray, index + 1, remainingIndex);

		}

		newArray[index] = v;
		return newArray;
	}

	public static byte[] insert(final byte[] array, final int fromIndex, final byte[] values) {

		if (fromIndex >= array.length) {
			return add(array, values);
		}

		final int index = calculateIndex(array, fromIndex);

		// Object newArray =
		// Array.newInstance(array.getClass().getComponentType(),
		// array.length+1);
		byte[] newArray = new byte[array.length + values.length];

		if (index != 0) {
			/* Copy up to the length in the array before the index. */
			/* src sbegin dst dbegin length of copy */
			System.arraycopy(array, 0, newArray, 0, index);
		}

		boolean lastIndex = index == array.length - 1;

		int toIndex = index + values.length;
		int remainingIndex = newArray.length - toIndex;

		if (lastIndex) {
			/*
			 * Copy the area after the insert. Make sure we don't write over the
			 * end.
			 */
			/* src sbegin dst dbegin length of copy */
			System.arraycopy(array, index, newArray, index + values.length, remainingIndex);

		} else {
			/* Copy the area after the insert. */
			/* src sbegin dst dbegin length of copy */
			System.arraycopy(array, index, newArray, index + values.length, remainingIndex);

		}

		for (int i = index, j = 0; i < toIndex; i++, j++) {
			newArray[i] = values[j];
		}
		return newArray;
	}

	/* End universal methods. */
	private static int calculateIndex(byte[] array, int originalIndex) {
		final int length = array.length;

		int index = originalIndex;

		/*
		 * Adjust for reading from the right as in -1 reads the 4th element if
		 * the length is 5
		 */
		if (index < 0) {
			index = length + index;
		}

		/*
		 * Bounds check if it is still less than 0, then they have an negative
		 * index that is greater than length
		 */
		/*
		 * Bounds check if it is still less than 0, then they have an negative
		 * index that is greater than length
		 */
		if (index < 0) {
			index = 0;
		}
		if (index >= length) {
			index = length - 1;
		}
		return index;
	}

	/* End universal methods. */
	private static int calculateEndIndex(byte[] array, int originalIndex) {
		final int length = array.length;

		int index = originalIndex;

		/*
		 * Adjust for reading from the right as in -1 reads the 4th element if
		 * the length is 5
		 */
		if (index < 0) {
			index = length + index;
		}

		/*
		 * Bounds check if it is still less than 0, then they have an negative
		 * index that is greater than length
		 */
		/*
		 * Bounds check if it is still less than 0, then they have an negative
		 * index that is greater than length
		 */
		if (index < 0) {
			index = 0;
		}
		if (index > length) {
			index = length;
		}
		return index;
	}

	public static int idxInt(byte[] bytes, int off) {
		return ((bytes[off + 3] & 0xFF)) + ((bytes[off + 2] & 0xFF) << 8) + ((bytes[off + 1] & 0xFF) << 16) + ((bytes[off]) << 24);
	}

	public static byte[] addInt(byte[] array, int v) {

		byte[] arrayToHoldInt = new byte[4];
		intTo(arrayToHoldInt, 0, v);
		return add(array, arrayToHoldInt);

	}

	public static byte[] insertIntInto(byte[] array, int index, int v) {

		byte[] arrayToHoldInt = new byte[4];
		intTo(arrayToHoldInt, 0, v);
		return insert(array, index, arrayToHoldInt);

	}

	public static void intTo(byte[] b, int off, int val) {
		b[off + 3] = (byte) (val);
		b[off + 2] = (byte) (val >>> 8);
		b[off + 1] = (byte) (val >>> 16);
		b[off] = (byte) (val >>> 24);
	}

	public static void longTo(byte[] b, int off, long val) {
		b[off + 7] = (byte) (val);
		b[off + 6] = (byte) (val >>> 8);
		b[off + 5] = (byte) (val >>> 16);
		b[off + 4] = (byte) (val >>> 24);
		b[off + 3] = (byte) (val >>> 32);
		b[off + 2] = (byte) (val >>> 40);
		b[off + 1] = (byte) (val >>> 48);
		b[off] = (byte) (val >>> 56);
	}

	public static byte[] addLong(byte[] array, long value) {

		byte[] holder = new byte[8];
		longTo(holder, 0, value);
		return add(array, holder);

	}

	public static long idxUnsignedInt(byte[] bytes, int off) {
		return ((bytes[off + 3] & 0xFFL)) + ((bytes[off + 2] & 0xFFL) << 8L) + ((bytes[off + 1] & 0xFFL) << 16L) + ((bytes[off] & 0xFFL) << 24L);
	}

	public static long idxLong(byte[] b, int off) {
		return ((b[off + 7] & 0xFFL)) + ((b[off + 6] & 0xFFL) << 8) + ((b[off + 5] & 0xFFL) << 16) + ((b[off + 4] & 0xFFL) << 24) + ((b[off + 3] & 0xFFL) << 32) + ((b[off + 2] & 0xFFL) << 40)
				+ ((b[off + 1] & 0xFFL) << 48) + (((long) b[off]) << 56);
	}

	public static short idxShort(byte[] b, int off) {
		return (short) ((b[off + 1] & 0xFF) + (b[off] << 8));
	}

	public static byte[] addShort(byte[] array, short value) {

		byte[] holder = new byte[2];
		shortTo(holder, 0, value);
		return add(array, holder);

	}

	public static byte[] insertShortInto(byte[] array, int index, short value) {

		byte[] holder = new byte[2];
		shortTo(holder, 0, value);
		return insert(array, index, holder);

	}

	public static void shortTo(byte[] b, int off, short val) {
		b[off + 1] = (byte) (val);
		b[off] = (byte) (val >>> 8);
	}

	public static char idxChar(byte[] b, int off) {
		return (char) ((b[off + 1] & 0xFF) + (b[off] << 8));
	}

	public static byte[] addChar(byte[] array, char value) {
		byte[] holder = new byte[2];
		charTo(holder, 0, value);
		return add(array, holder);

	}

	public static byte[] insertCharInto(byte[] array, int index, char value) {
		byte[] holder = new byte[2];
		charTo(holder, 0, value);
		return insert(array, index, holder);

	}

	public static void charTo(byte[] b, int off, char val) {
		b[off + 1] = (byte) (val);
		b[off] = (byte) (val >>> 8);
	}

	public static void charTo(byte[] b, char val) {
		b[1] = (byte) (val);
		b[0] = (byte) (val >>> 8);
	}

	public static float idxFloat(byte[] array, int off) {
		return Float.intBitsToFloat(idxInt(array, off));
	}

	public static byte[] addFloat(byte[] array, float value) {

		byte[] holder = new byte[4];
		floatTo(holder, 0, value);
		return add(array, holder);

	}

	public static byte[] insertFloatInto(byte[] array, int index, float value) {

		byte[] holder = new byte[4];
		floatTo(holder, 0, value);
		return insert(array, index, holder);

	}

	public static void floatTo(byte[] array, int off, float val) {
		intTo(array, off, Float.floatToIntBits(val));
	}

	public static byte[] addDouble(byte[] array, double value) {
		byte[] holder = new byte[4];
		doubleTo(holder, 0, value);
		return add(array, holder);

	}

	public static byte[] insertDoubleInto(byte[] array, int index, double value) {
		byte[] holder = new byte[4];
		doubleTo(holder, 0, value);
		return insert(array, index, holder);

	}

	public static void doubleTo(byte[] b, int off, double val) {
		longTo(b, off, Double.doubleToLongBits(val));
	}

	public static double idxDouble(byte[] b, int off) {
		return Double.longBitsToDouble(idxLong(b, off));
	}

	//
	//
	// public static boolean booleanAt(byte[] b, int off) {
	// return b[off] != 0;
	// }
	//
	//
	// public static boolean booleanInBytePos1(int val) {
	// val = val & 0x01;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos2(int val) {
	// val = val & 0x02;
	// return val != 0;
	// }
	//
	//
	// public static boolean booleanInBytePos3(int val) {
	// val = val & 0x04;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos4(int val) {
	// val = val & 0x08;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos1(byte[] b, int off) {
	// int val = b[off] & 0x01;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos2(byte[] b, int off) {
	// int val = b[off] & 0x02;
	// return val != 0;
	// }
	//
	//
	// public static boolean booleanInBytePos3(byte[] b, int off) {
	// int val = b[off] & 0x04;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos4(byte[] b, int off) {
	// int val = b[off] & 0x08;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos5(byte[] b, int off) {
	// int val = b[off] & 0x10;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos6(byte[] b, int off) {
	// int val = b[off] & 0x20;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos7(byte[] b, int off) {
	// int val = b[off] & 0x40;
	// return val != 0;
	// }
	//
	// public static boolean booleanInBytePos8(byte[] b, int off) {
	// int val = b[off] & 0x80;
	// return val != 0;
	// }
	//
	//
	// public static int byteAt(byte[] b, int off) {
	// return b[off];
	// }
	//
	//
	// public static int topNibbleAt(byte[] b, int off) {
	// return topNibbleAt (b[off] );
	// }
	//
	// public static int bottomNibbleAt(byte[] b, int off) {
	// return bottomNibbleAt (b[off] );
	// }
	//
	// public static int topNibbleAt(int val) {
	// return (val & 0xF0);
	// }
	//
	// public static int bottomNibbleAt(int val) {
	// return (val & 0x0F);
	// }
	//
	//
	// public static char charAt1(byte[] b, int off) {
	// return (char) ((b[off + 1] & 0xFF) +
	// (b[off] << 8));
	// }
	//

	public static void _idx(final byte[] array, int startIndex, byte[] input) {
		try {

			System.arraycopy(input, 0, array, startIndex, input.length);
		} catch (Exception ex) {
			throw new KriptonRuntimeException(String.format("array size %d, startIndex %d, input length %d", array.length, startIndex, input.length), ex);
		}
	}

	public static void _idx(final byte[] array, int startIndex, byte[] input, int length) {
		try {

			System.arraycopy(input, 0, array, startIndex, length);
		} catch (Exception ex) {
			throw new KriptonRuntimeException(String.format("array size %d, startIndex %d, input length %d", array.length, startIndex, input.length), ex);
		}
	}

	public static void _idx(final byte[] output, int ouputStartIndex, byte[] input, int inputOffset, int length) {
		try {

			System.arraycopy(input, inputOffset, output, ouputStartIndex, length);
		} catch (Exception ex) {
			throw new KriptonRuntimeException(String.format("array size %d, startIndex %d, input length %d", output.length, ouputStartIndex, input.length), ex);
		}
	}

	public static int idxUnsignedShort(byte[] buffer, int off) {

		int ch1 = buffer[off] & 0xFF;
		int ch2 = buffer[off + 1] & 0xFF;

		return (ch1 << 8) + (ch2);

	}

	public static short idxUnsignedByte(byte[] array, int location) {
		return (short) (array[location] & 0xFF);
	}

	public static void unsignedIntTo(byte[] b, int off, long val) {
		b[off + 3] = (byte) (val);
		b[off + 2] = (byte) (val >>> 8);
		b[off + 1] = (byte) (val >>> 16);
		b[off] = (byte) (val >>> 24);
	}

	public static void unsignedShortTo(byte[] buffer, int off, int value) {

		buffer[off + 1] = (byte) (value);
		buffer[off] = (byte) (value >>> 8);

	}

	public static void unsignedByteTo(byte[] buffer, int off, short value) {
		buffer[off] = (byte) (value);

	}

	public static String utfString(byte[] jsonBytes) {
		return new String(jsonBytes, StandardCharsets.UTF_8);
	}

	/**
	 * Checks to see if two arrays are equals
	 * 
	 * @param expected
	 *            expected array
	 * @param got
	 *            got array
	 * @return true if equal or throws exception if not.
	 */
	public static boolean equalsOrDie(byte[] expected, byte[] got) {

		if (expected.length != got.length) {
			throw new KriptonRuntimeException("Lengths did not match, expected length" + expected.length + "but got" + got.length);
		}

		for (int index = 0; index < expected.length; index++) {
			if (expected[index] != got[index]) {
				throw new KriptonRuntimeException("value at index did not match index" + index + "expected value" + expected[index] + "but got"+ got[index]);

			}
		}
		return true;
	}

	/**
	 * Checks to see if two arrays are equals
	 * 
	 * @param expected
	 *            expected array
	 * @param got
	 *            got array
	 * @return true if equal or false if not.
	 */
	public static boolean equals(byte[] expected, byte[] got) {

		if (expected.length != got.length) {
			return false;
		}

		for (int index = 0; index < expected.length; index++) {
			if (expected[index] != got[index]) {
				return false;
			}
		}
		return true;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy