/*
 * 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 <http://www.gnu.org/licenses/lgpl-2.1.html>.
 */
package org.hibernate.hql.internal.ast.tree;

import org.hibernate.engine.spi.SessionFactoryImplementor;
import org.hibernate.internal.util.StringHelper;

import antlr.Token;
import antlr.collections.AST;

Base node class for use by Hibernate within its AST trees.
Author:Joshua Davis, Steve Ebersole
/** * Base node class for use by Hibernate within its AST trees. * * @author Joshua Davis * @author Steve Ebersole */
public class Node extends antlr.CommonAST { private String filename; private int line; private int column; private int textLength; public Node() { super(); } public Node(Token tok) { super(tok); // This will call initialize(tok)! }
Retrieve the text to be used for rendering this particular node.
Params:
  • sessionFactory – The session factory
Returns:The text to use for rendering
/** * Retrieve the text to be used for rendering this particular node. * * @param sessionFactory The session factory * @return The text to use for rendering */
public String getRenderText(SessionFactoryImplementor sessionFactory) { // The basic implementation is to simply use the node's text return getText(); } @Override public void initialize(Token tok) { super.initialize(tok); filename = tok.getFilename(); line = tok.getLine(); column = tok.getColumn(); String text = tok.getText(); textLength = StringHelper.isEmpty(text) ? 0 : text.length(); } @Override public void initialize(AST t) { super.initialize( t ); if ( t instanceof Node ) { Node n = (Node)t; filename = n.filename; line = n.line; column = n.column; textLength = n.textLength; } } public String getFilename() { return filename; } @Override public int getLine() { return line; } @Override public int getColumn() { return column; } public int getTextLength() { return textLength; } }