org.apache.velocity.runtime.parser.node.ASTFloatingPointLiteral Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.liferay.portal.template.velocity
Show all versions of com.liferay.portal.template.velocity
Liferay Portal Template Velocity
The newest version!
package org.apache.velocity.runtime.parser.node;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
import java.math.BigDecimal;
import org.apache.velocity.context.InternalContextAdapter;
import org.apache.velocity.exception.TemplateInitException;
import org.apache.velocity.runtime.parser.Parser;
/**
* Handles floating point numbers. The value will be either a Double
* or a BigDecimal.
*
* @author Will Glass-Husain
* @since 1.5
*/
public class ASTFloatingPointLiteral extends SimpleNode
{
// This may be of type Double or BigDecimal
private Number value = null;
/**
* @param id
*/
public ASTFloatingPointLiteral(int id)
{
super(id);
}
/**
* @param p
* @param id
*/
public ASTFloatingPointLiteral(Parser p, int id)
{
super(p, id);
}
/**
* @see org.apache.velocity.runtime.parser.node.SimpleNode#jjtAccept(org.apache.velocity.runtime.parser.node.ParserVisitor, java.lang.Object)
*/
public Object jjtAccept(ParserVisitor visitor, Object data)
{
return visitor.visit(this, data);
}
/**
* Initialization method - doesn't do much but do the object
* creation. We only need to do it once.
* @param context
* @param data
* @return The data object.
* @throws TemplateInitException
*/
public Object init( InternalContextAdapter context, Object data)
throws TemplateInitException
{
/*
* init the tree correctly
*/
super.init( context, data );
/**
* Determine the size of the item and make it a Double or BigDecimal as appropriate.
*/
String str = getFirstToken().image;
try
{
value = new Double( str );
} catch ( NumberFormatException E1 )
{
// if there's still an Exception it will propogate out
value = new BigDecimal( str );
}
return data;
}
/**
* @see org.apache.velocity.runtime.parser.node.SimpleNode#value(org.apache.velocity.context.InternalContextAdapter)
*/
public Object value( InternalContextAdapter context)
{
return value;
}
}