org.apache.commons.imaging.internal.Debug Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.commons.imaging.internal;
import java.awt.color.ICC_Profile;
import java.io.File;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Objects;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* Internal-only debug class. Used for collecting extra information when parsing or modifying images or metadata. These methods are useful for troubleshooting
* and issue analysis, but this should not be used directly by end-users, nor extended in any way. This may change or be removed at any time.
*/
public final class Debug {
private static final Logger LOGGER = Logger.getLogger(Debug.class.getName());
// public static String newline = System.getProperty("line.separator");
private static final String NEWLINE = "\r\n";
private static long counter;
private static String byteQuadToString(final int byteQuad) {
final byte b1 = (byte) (byteQuad >> 24 & 0xff);
final byte b2 = (byte) (byteQuad >> 16 & 0xff);
final byte b3 = (byte) (byteQuad >> 8 & 0xff);
final byte b4 = (byte) (byteQuad >> 0 & 0xff);
final char c1 = (char) b1;
final char c2 = (char) b2;
final char c3 = (char) b3;
final char c4 = (char) b4;
// return new String(new char[] { c1, c2, c3, c4 });
final StringBuilder buffer = new StringBuilder(31);
buffer.append(new String(new char[] { c1, c2, c3, c4 }));
buffer.append(" byteQuad: ");
buffer.append(byteQuad);
buffer.append(" b1: ");
buffer.append(b1);
buffer.append(" b2: ");
buffer.append(b2);
buffer.append(" b3: ");
buffer.append(b3);
buffer.append(" b4: ");
buffer.append(b4);
return buffer.toString();
}
public static void debug() {
if (LOGGER.isLoggable(Level.FINEST)) {
LOGGER.finest(NEWLINE);
}
}
public static void debug(final String message) {
if (LOGGER.isLoggable(Level.FINEST)) {
LOGGER.finest(message);
}
}
private static void debug(final String message, final byte[] v) {
debug(getDebug(message, v));
}
private static void debug(final String message, final Calendar value) {
final DateFormat df = new SimpleDateFormat("MM/dd/yyyy HH:mm:ss", Locale.ENGLISH);
debug(message, value == null ? "null" : df.format(value.getTime()));
}
private static void debug(final String message, final char[] v) {
debug(getDebug(message, v));
}
private static void debug(final String message, final Date value) {
final DateFormat df = new SimpleDateFormat("MM/dd/yyyy HH:mm:ss", Locale.ENGLISH);
debug(message, value == null ? "null" : df.format(value));
}
private static void debug(final String message, final File file) {
debug(message + ": " + (file == null ? "null" : file.getPath()));
}
private static void debug(final String message, final ICC_Profile value) {
debug("ICC_Profile " + message + ": " + Objects.toString(value));
if (value != null) {
debug("\t getProfileClass: " + byteQuadToString(value.getProfileClass()));
debug("\t getPCSType: " + byteQuadToString(value.getPCSType()));
debug("\t getColorSpaceType() : " + byteQuadToString(value.getColorSpaceType()));
}
}
private static void debug(final String message, final int[] v) {
debug(getDebug(message, v));
}
private static void debug(final String message, final List> v) {
final String suffix = " [" + counter++ + "]";
debug(message + " (" + v.size() + ")" + suffix);
for (final Object aV : v) {
debug("\t" + aV.toString() + suffix);
}
debug();
}
private static void debug(final String message, final Map, ?> map) {
debug(getDebug(message, map));
}
public static void debug(final String message, final Object value) {
if (value == null) {
debug(message, "null");
} else if (value instanceof char[]) {
debug(message, (char[]) value);
} else if (value instanceof byte[]) {
debug(message, (byte[]) value);
} else if (value instanceof int[]) {
debug(message, (int[]) value);
} else if (value instanceof String) {
debug(message, (String) value);
} else if (value instanceof List) {
debug(message, (List>) value);
} else if (value instanceof Map) {
debug(message, (Map, ?>) value);
} else if (value instanceof ICC_Profile) {
debug(message, (ICC_Profile) value);
} else if (value instanceof File) {
debug(message, (File) value);
} else if (value instanceof Date) {
debug(message, (Date) value);
} else if (value instanceof Calendar) {
debug(message, (Calendar) value);
} else {
debug(message, value.toString());
}
}
private static void debug(final String message, final String value) {
debug(message + " " + value);
}
public static void debug(final Throwable e) {
debug(getDebug(e));
}
public static void debug(final Throwable e, final int value) {
debug(getDebug(e, value));
}
private static String getDebug(final String message, final byte[] v) {
final int max = 250;
return getDebug(message, v, max);
}
private static String getDebug(final String message, final byte[] v, final int max) {
final StringBuilder result = new StringBuilder();
if (v == null) {
result.append(message + " (" + null + ")" + NEWLINE);
} else {
result.append(message + " (" + v.length + ")" + NEWLINE);
for (int i = 0; i < max && i < v.length; i++) {
final int b = 0xff & v[i];
char c;
if (b == 0 || b == 10 || b == 11 || b == 13) {
c = ' ';
} else {
c = (char) b;
}
result.append("\t" + i + ": " + b + " (" + c + ", 0x" + Integer.toHexString(b) + ")" + NEWLINE);
}
if (v.length > max) {
result.append("\t..." + NEWLINE);
}
result.append(NEWLINE);
}
return result.toString();
}
private static String getDebug(final String message, final char[] v) {
final StringBuilder result = new StringBuilder();
if (v == null) {
result.append(message + " (" + null + ")" + NEWLINE);
} else {
result.append(message + " (" + v.length + ")" + NEWLINE);
for (final char element : v) {
result.append("\t" + element + " (" + (0xff & element) + ")" + NEWLINE);
}
result.append(NEWLINE);
}
return result.toString();
}
private static String getDebug(final String message, final int[] v) {
final StringBuilder result = new StringBuilder();
if (v == null) {
result.append(message + " (" + null + ")" + NEWLINE);
} else {
result.append(message + " (" + v.length + ")" + NEWLINE);
for (final int element : v) {
result.append("\t" + element + NEWLINE);
}
result.append(NEWLINE);
}
return result.toString();
}
private static String getDebug(final String message, final Map, ?> map) {
final StringBuilder result = new StringBuilder();
if (map == null) {
return message + " map: " + null;
}
final List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy