/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
// www.projectforge.org
//
// Copyright (C) 2001-2014 Kai Reinhard (k.reinhard@micromata.de)
//
// ProjectForge is dual-licensed.
//
// This community edition is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as published
// by the Free Software Foundation; version 3 of the License.
//
// This community edition is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
// Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, see http://www.gnu.org/licenses/.
//
/////////////////////////////////////////////////////////////////////////////
package org.projectforge.common;
import java.io.Serializable;
import java.lang.reflect.Field;
import java.util.Collection;
import java.util.TimeZone;
import org.apache.commons.lang.builder.ReflectionToStringBuilder;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.hibernate.Hibernate;
import org.projectforge.core.BaseDO;
import org.projectforge.core.ShortDisplayNameCapable;
import org.projectforge.database.HibernateUtils;
/**
*
* @author wolle (wolle@micromata.de)
*
*/
public class ReflectionToString extends ReflectionToStringBuilder
{
public ReflectionToString(final Object arg0)
{
super(Hibernate.isInitialized(arg0) ? arg0 : "Lazy" + arg0.getClass() + "@" + System.identityHashCode(arg0));
}
@Override
public ToStringBuilder append(final String fieldName, final Object object)
{
if (object != null) {
if (Hibernate.isInitialized(object) == false) {
if (BaseDO.class.isAssignableFrom(object.getClass()) == true) {
// Work around for Jassist bug:
final Serializable id = HibernateUtils.getIdentifier((BaseDO< ? >) object);
return super.append(fieldName, id != null ? id : "<id>");
}
return super.append(fieldName, "LazyCollection");
} else if (ShortDisplayNameCapable.class.isAssignableFrom(object.getClass()) == true) {
return super.append(fieldName, myToString(object));
} else if (BaseDO.class.isAssignableFrom(object.getClass()) == true) {
return super.append(fieldName, myToString(object));
} else if (object instanceof Collection) {
final StringBuilder sb = new StringBuilder().append("[");
boolean first = true;
for (final Object el : (Collection< ? >) object) {
if (first == true)
first = false;
else sb.append(", ");
sb.append(myToString(el));
}
return super.append(fieldName, sb.append("]").toString());
} else if (object instanceof TimeZone) {
return super.append(fieldName, ((TimeZone) object).getID());
}
}
return super.append(fieldName, object);
}
private String myToString(final Object obj)
{
if (obj == null) {
return "<null>";
} else if (ShortDisplayNameCapable.class.isAssignableFrom(obj.getClass()) == true) {
if (BaseDO.class.isAssignableFrom(obj.getClass()) == true) {
final Serializable id = HibernateUtils.getIdentifier((BaseDO< ? >) obj);
return id + ":" + ((ShortDisplayNameCapable) obj).getShortDisplayName();
}
return ((ShortDisplayNameCapable) obj).getShortDisplayName();
} else if (BaseDO.class.isAssignableFrom(obj.getClass()) == true) {
final Serializable id = HibernateUtils.getIdentifier((BaseDO< ? >) obj);
return id != null ? id.toString() : "<id>";
}
return obj.toString();
}
@Override
protected boolean accept(final Field field)
{
try {
final Object value = getValue(field);
if (Hibernate.isInitialized(value) == false) {
append(field.getName(), value);
return false;
}
} catch (final IllegalArgumentException ex) {
return false;
} catch (final IllegalAccessException ex) {
return false;
}
return super.accept(field);
}
public static String asString(final Object o)
{
return new ReflectionToString(o).toString();
}
}