Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
 /*
  * Copyright 2014 Daniel Bechler
  *
  * 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 de.danielbechler.diff.node;
Prints the hierarchy of the object graph in a human-readable form.

Author(s):
Daniel Bechler
@SuppressWarnings({"UnusedDeclaration"})
public class NodeHierarchyVisitor implements DiffNode.Visitor
	public static final int UNLIMITED = -1;
	private final int maxDepth;
	{
		this();
	}
	public NodeHierarchyVisitor(final int maxDepth)
	{
		this. = maxDepth;
	}
	public void node(final DiffNode nodefinal Visit visit)
	{
		if ( == 0)
		{
			visit.stop();
		}
		final int currentLevel = calculateDepth(node);
		if ( > 0)
		{
			if (currentLevel <= )
			{
				print(nodecurrentLevel);
			}
			else
			{
				visit.dontGoDeeper();
			}
		}
		else if ( < 0)
		{
			print(nodecurrentLevel);
		}
	}
	private static int calculateDepth(final DiffNode node)
	{
		int count = 0;
		DiffNode parentNode = node.getParentNode();
		while (parentNode != null)
		{
			count++;
			parentNode = parentNode.getParentNode();
		}
		return count;
	}
	protected void print(final DiffNode nodefinal int level)
	{
		final String nodeAsString = node.getPath() + " ===> " + node.toString();
		final String indentedNodeString = Strings.indent(levelnodeAsString);
		print(indentedNodeString);
	}
	@SuppressWarnings({"MethodMayBeStatic"})
	protected void print(final String text)
	{
	}
New to GrepCode? Check out our FAQ X