/**
* Copyright (c) 2010-2016 by the respective copyright holders.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*/
package org.openhab.binding.maxcube.internal;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.Date;
/**
* Utility class for common tasks within the MAX!Cube binding package.
*
* @author Andreas Heil (info@aheil.de)
* @since 1.4.0
*/
public final class Utils {
/**
* Returns the integer value of an hexadecimal number (base 16).
*
* @param hex
* the hex value to be parsed into an integer
* @return the given hex value as integer
*/
public static final int fromHex(String hex) {
return Integer.parseInt(hex, 16);
}
/**
* Returns the hexadecimal number of a number of integer values.
*
* @param values
* the integer values to be converted into hexadecimal numbers
* @return the given numbers as hexadecimal number
*/
public static final String toHex(int... values) {
String returnValue = "";
for (int v : values) {
returnValue += v < 16 ? "0" + Integer.toHexString(v).toUpperCase() : Integer.toHexString(v).toUpperCase();
}
return returnValue;
}
/**
* Returns the hexadecimal number of a bit array .
*
* @param bits
* the boolean array representing the bits to be converted into hexadecimal numbers
* @return the hexadecimal number
*/
public static final String toHex(boolean[] bits) {
int retVal = 0;
for (int i = 0; i < bits.length; ++i) {
retVal |= (bits[i] ? 1 : 0) << i;
}
return toHex(retVal);
}
/**
* Converts an Java signed byte into its general (unsigned) value as being used in other programming languages and
* platforms.
*
* @param b
* the byte to be converted into its integer value
* @return the integer value represented by the given byte
*/
public static final int fromByte(byte b) {
return b & 0xFF;
}
/**
* Resolves the date and time based based on a three byte encoded within a MAX!Cube L message.
*
* Date decoding (two byte)
*
* <pre>
* Hex Binary
* 9D0B 1001110100001011
* MMMDDDDDM YYYYYY
* 100 0 = 1000b = 8d = month
* 11101 = 11101b = 29d = day
* 001011 = 1011b = 11d = year-2000
* </pre>
*
* Time decoding (one byte)
*
* <pre>
* Hex Decimal
* 1F 31 * 0.5 hours = 15:30
* </pre>
*
* @param date
* the date to be converted based on two bytes
* @param time
* the time to be converted based on a single byte
* @return the date time based on the values provided
*/
@SuppressWarnings("deprecation")
public static Date resolveDateTime(int date, int time) {
int month = ((date & 0xE000) >> 12) + ((date & 0x80) >> 7);
int day = (date & 0x1F00) >> 8;
int year = (date & 0x0F) + 2000;
int hours = (int) (time * 0.5);
int minutes = (int) (60 * ((time * 0.5) - hours));
return new Date(year, month, day, hours, minutes);
}
/**
* Returns a bit representation as boolean values in a reversed manner.
* A bit string <code>0001 0010</code> would be returnd as <code>0100 1000</code>.
* That way, the least significant bit can be addressed by bits[0], the second by bits[1] and so on.
*
* @param value
* the integer value to be converted in a bit array
* @return
* the bit array of the input value in a reversed manner.
*/
public static boolean[] getBits(int value) {
boolean[] bits = new boolean[8];
for (int i = 0; i < 8; i++) {
bits[i] = (((value >> i) & 0x1) == 1);
}
return bits;
}
/**
* Convert a string representation of hexadecimal to a byte array.
*
* For example:
* String s = "00010203"
* returned byte array is {0x00, 0x01, 0x03}
*
* @param s
* @return byte array equivalent to hex string
**/
public static byte[] hexStringToByteArray(String s) {
int len = s.length();
byte[] data = new byte[len / 2];
for (int i = 0; i < len; i += 2) {
data[i / 2] = (byte) ((Character.digit(s.charAt(i), 16) << 4) + Character.digit(s.charAt(i + 1), 16));
}
return data;
}
/**
* Convert a byte array to a string representation of hexadecimals.
*
* For example:
* byte array is {0x00, 0x01, 0x03}
* returned String s = "00 01 02 03"
*
* @param byte array
* @return String equivalent to hex string
**/
static final String HEXES = "0123456789ABCDEF";
public static String getHex(byte[] raw) {
if (raw == null) {
return null;
}
final StringBuilder hex = new StringBuilder(3 * raw.length);
for (final byte b : raw) {
hex.append(HEXES.charAt((b & 0xF0) >> 4)).append(HEXES.charAt((b & 0x0F))).append(" ");
}
hex.delete(hex.length() - 1, hex.length());
return hex.toString();
}
/**
* Retrieves the stacktrace of an exception as string.
*
* @param e
* the exception to resolve the stacktrace from
* @return
* the stacktrace from the exception provided
*/
public static String getStackTrace(Exception e) {
StringWriter stringWriter = new StringWriter();
PrintWriter printWriter = new PrintWriter(stringWriter);
e.printStackTrace(printWriter);
return stringWriter.toString();
}
}