net.sf.jasperreports.engine.base.JRBaseExpression Maven / Gradle / Ivy
/*
* JasperReports - Free Java Reporting Library.
* Copyright (C) 2001 - 2023 Cloud Software Group, Inc. All rights reserved.
* http://www.jaspersoft.com
*
* Unless you have purchased a commercial license agreement from Jaspersoft,
* the following license terms apply:
*
* This program is part of JasperReports.
*
* JasperReports is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* JasperReports 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with JasperReports. If not, see .
*/
package net.sf.jasperreports.engine.base;
import java.io.Serializable;
import java.util.StringTokenizer;
import net.sf.jasperreports.engine.JRConstants;
import net.sf.jasperreports.engine.JRExpression;
import net.sf.jasperreports.engine.JRExpressionChunk;
import net.sf.jasperreports.engine.JRRuntimeException;
import net.sf.jasperreports.engine.type.ExpressionTypeEnum;
import net.sf.jasperreports.engine.util.JRClassLoader;
import net.sf.jasperreports.engine.util.JRCloneUtils;
/**
* @author Teodor Danciu ([email protected])
*/
public class JRBaseExpression implements JRExpression, Serializable
{
/**
*
*/
private static final long serialVersionUID = JRConstants.SERIAL_VERSION_UID;
/**
* @deprecated To be removed.
*/
protected String valueClassName;
/**
* @deprecated To be removed.
*/
protected String valueClassRealName;
protected int id;
/**
* @deprecated To be removed.
*/
protected transient Class> valueClass;
/**
*
*/
private JRExpressionChunk[] chunks;
/**
*
*/
private static int lastId;
/**
*
*/
protected ExpressionTypeEnum type;
/**
*
*/
protected JRBaseExpression()
{
}
/**
* Creates a copy of an expression.
*
* @param expression the original expression
* @param factory the base object factory
* @param expressionId if not null, the created expression will use it as ID
* instead of the original expressions's ID
*/
protected JRBaseExpression(JRExpression expression, JRBaseObjectFactory factory, Integer expressionId)
{
factory.put(expression, this);
if (expressionId == null)
{
id = expression.getId();
}
else
{
id = expressionId;
}
type = expression.getType();
/* */
JRExpressionChunk[] jrChunks = expression.getChunks();
if (jrChunks != null && jrChunks.length > 0)
{
chunks = new JRExpressionChunk[jrChunks.length];
for(int i = 0; i < chunks.length; i++)
{
chunks[i] = factory.getExpressionChunk(jrChunks[i]);
}
}
}
/**
* Creates a copy of an expression.
*
* @param expression the original expression
* @param factory the base object factory
*/
protected JRBaseExpression(JRExpression expression, JRBaseObjectFactory factory)
{
this(expression, factory, null);
}
/**
*
*/
private static synchronized int getNextId()
{
return lastId++;
}
/**
*
*/
public void regenerateId()
{
id = getNextId();
}
/**
* @deprecated To be removed.
*/
@Override
public Class> getValueClass()
{
if (valueClass == null)
{
String className = getValueClassRealName();
if (className != null)
{
try
{
valueClass = JRClassLoader.loadClassForName(className);
}
catch(ClassNotFoundException e)
{
throw new JRRuntimeException(e);
}
}
}
return valueClass;
}
/**
* @deprecated To be removed.
*/
@Override
public String getValueClassName()
{
return valueClassName;
}
/**
* @deprecated To be removed.
*/
private String getValueClassRealName()
{
if (valueClassRealName == null)
{
valueClassRealName = JRClassLoader.getClassRealName(valueClassName);
}
return valueClassRealName;
}
@Override
public int getId()
{
return id;
}
@Override
public ExpressionTypeEnum getType()
{
return type;
}
@Override
public JRExpressionChunk[] getChunks()
{
return chunks;
}
@Override
public String getText()
{
String text = "";
chunks = getChunks();
if (chunks != null && chunks.length > 0)
{
StringBuilder sb = new StringBuilder();
for(int i = 0; i < chunks.length; i++)
{
switch(chunks[i].getType())
{
case JRExpressionChunk.TYPE_PARAMETER :
{
sb.append("$P{");
sb.append( chunks[i].getText() );
sb.append("}");
break;
}
case JRExpressionChunk.TYPE_FIELD :
{
sb.append("$F{");
sb.append( chunks[i].getText() );
sb.append("}");
break;
}
case JRExpressionChunk.TYPE_VARIABLE :
{
sb.append("$V{");
sb.append( chunks[i].getText() );
sb.append("}");
break;
}
case JRExpressionChunk.TYPE_RESOURCE :
{
sb.append("$R{");
sb.append( chunks[i].getText() );
sb.append("}");
break;
}
case JRExpressionChunk.TYPE_TEXT :
default :
{
String textChunk = chunks[i].getText();
String escapedText = escapeTextChunk(textChunk);
sb.append(escapedText);
break;
}
}
}
text = sb.toString();
}
return text;
}
protected String escapeTextChunk(String text)
{
if (text == null || text.indexOf('$') < 0)
{
return text;
}
StringBuilder sb = new StringBuilder(text.length() + 4);
StringTokenizer tkzer = new StringTokenizer(text, "$", true);
boolean wasDelim = false;
while (tkzer.hasMoreElements())
{
String token = tkzer.nextToken();
if (wasDelim &&
(token.startsWith("P{") || token.startsWith("F{") || token.startsWith("V{") || token.startsWith("R{")) &&
token.indexOf('}') > 0)
{
sb.append('$');
}
sb.append(token);
wasDelim = token.equals("$");
}
return sb.toString();
}
@Override
public Object clone()
{
JRBaseExpression clone = null;
try
{
clone = (JRBaseExpression)super.clone();
}
catch (CloneNotSupportedException e)
{
throw new JRRuntimeException(e);
}
clone.chunks = JRCloneUtils.cloneArray(chunks);
return clone;
}
}