org.hibernate.loader.plan.build.spi.LoadPlanTreePrinter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hibernate-core Show documentation
Show all versions of hibernate-core Show documentation
Hibernate's core ORM functionality
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or .
*/
package org.hibernate.loader.plan.build.spi;
import java.io.ByteArrayOutputStream;
import java.io.PrintStream;
import java.io.PrintWriter;
import org.hibernate.internal.CoreLogging;
import org.hibernate.loader.plan.exec.spi.AliasResolutionContext;
import org.hibernate.loader.plan.spi.CollectionReturn;
import org.hibernate.loader.plan.spi.EntityReturn;
import org.hibernate.loader.plan.spi.LoadPlan;
import org.hibernate.loader.plan.spi.Return;
import org.jboss.logging.Logger;
/**
* Prints a {@link org.hibernate.loader.plan.spi.LoadPlan} graph and its
* {@link org.hibernate.loader.plan.spi.QuerySpaces} graph as tree structures.
*
* Intended for use in debugging, logging, etc.
*
* Aggregates calls to the {@link QuerySpaceTreePrinter} and {@link ReturnGraphTreePrinter}
*
* @author Steve Ebersole
*/
public class LoadPlanTreePrinter {
private static final Logger log = CoreLogging.logger( LoadPlanTreePrinter.class );
/**
* Singleton access
*/
public static final LoadPlanTreePrinter INSTANCE = new LoadPlanTreePrinter();
private LoadPlanTreePrinter() {
}
/**
* Logs the specified {@link org.hibernate.loader.plan.spi.LoadPlan} graph and its
* {@link org.hibernate.loader.plan.spi.QuerySpaces} graph as tree structures.
*
* @param loadPlan The load plan.
* @param aliasResolutionContext The context for resolving table and column aliases/
*/
public void logTree(LoadPlan loadPlan, AliasResolutionContext aliasResolutionContext) {
if ( ! log.isDebugEnabled() ) {
return;
}
log.debug( toString( loadPlan, aliasResolutionContext ) );
}
private String toString(LoadPlan loadPlan, AliasResolutionContext aliasResolutionContext) {
final ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
final PrintStream printStream = new PrintStream( byteArrayOutputStream );
final PrintWriter printWriter = new PrintWriter( printStream );
logTree( loadPlan, aliasResolutionContext, printWriter );
printWriter.flush();
printStream.flush();
return new String( byteArrayOutputStream.toByteArray() );
}
private void logTree(
LoadPlan loadPlan,
AliasResolutionContext aliasResolutionContext,
PrintWriter printWriter) {
printWriter.println( "LoadPlan(" + extractDetails( loadPlan ) + ")" );
printWriter.println( TreePrinterHelper.INSTANCE.generateNodePrefix( 1 ) + "Returns" );
for ( Return rtn : loadPlan.getReturns() ) {
ReturnGraphTreePrinter.INSTANCE.write( rtn, 2, printWriter );
printWriter.flush();
}
QuerySpaceTreePrinter.INSTANCE.write( loadPlan.getQuerySpaces(), 1, aliasResolutionContext, printWriter );
printWriter.flush();
}
private String extractDetails(LoadPlan loadPlan) {
switch ( loadPlan.getDisposition() ) {
case MIXED: {
return "mixed";
}
case ENTITY_LOADER: {
return "entity=" + ( (EntityReturn) loadPlan.getReturns().get( 0 ) ).getEntityPersister().getEntityName();
}
case COLLECTION_INITIALIZER: {
return "collection=" + ( (CollectionReturn) loadPlan.getReturns().get( 0 ) ).getCollectionPersister().getRole();
}
default: {
return "???";
}
}
}
}