/******************************************************************************* * Copyright 2011 See AUTHORS file. * * 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.badlogic.gdx.utils; /** Indicates an error during serialization due to misconfiguration or during deserialization due to invalid input data. * @author Nathan Sweet */ public class SerializationException extends RuntimeException { private StringBuffer trace; public SerializationException () { super(); } public SerializationException (String message, Throwable cause) { super(message, cause); } public SerializationException (String message) { super(message); } public SerializationException (Throwable cause) { super("", cause); } /** Returns true if any of the exceptions that caused this exception are of the specified type. */ public boolean causedBy (Class type) { return causedBy(this, type); } private boolean causedBy (Throwable ex, Class type) { Throwable cause = ex.getCause(); if (cause == null || cause == ex) return false; if (type.isAssignableFrom(cause.getClass())) return true; return causedBy(cause, type); } public String getMessage () { if (trace == null) return super.getMessage(); StringBuffer buffer = new StringBuffer(512); buffer.append(super.getMessage()); if (buffer.length() > 0) buffer.append('\n'); buffer.append("Serialization trace:"); buffer.append(trace); return buffer.toString(); } /** Adds information to the exception message about where in the the object graph serialization failure occurred. Serializers * can catch {@link SerializationException}, add trace information, and rethrow the exception. */ public void addTrace (String info) { if (info == null) throw new IllegalArgumentException("info cannot be null."); if (trace == null) trace = new StringBuffer(512); trace.append('\n'); trace.append(info); } }