/*
* Copyright 2015 Google Inc.
*
* 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 com.google.template.soy.pysrc.restricted;
import com.google.template.soy.internal.targetexpr.TargetExpr;
/**
* Value class to represent a Python expression. Includes the text of the expression as well as the
* precedence of the top-most operator.
*
* <p>Important: This class may only be used in implementing plugins (e.g. functions, directives).
*
* <p>Since the type information is rather generic it could potentially be shared with the JsExpr,
* but as JS doesn't currently have any uses, and Python types do differ in some aspects (such as
* with numbers), it's kept separate.
*
* <p>NOTE: Some expressions could potentially return multiple types (such as a ternary if with a
* String or number as potential results). If possible to avoid, the results will be improved, but
* if not, this class can be used with no type assumed.
*
*/
public class PyExpr extends TargetExpr {
/**
* Create a new Python expression with the given text and precedence.
*
* <p>The precedence should be carefully considered for complex expressions. The precedence should
* represent the top most operator, or if there are multiple at the same level, the operator with
* the lowest value.
*
* <p>For example in the expression {@code x + y * z}, {@code x + y} has the lower precedence
* (will evaluate last), and is most likely to be trumped if combined into a more complex
* expression. So the precedence of the entire expression should be the {@code +} operators
* precedence.
*
* <p>An expression with a precedence which can't be trumped (such variable access or a function
* call) should use Integer.MAX_VALUE to avoid unnecessary parenthesis.
*
* @param text The Python expression text.
* @param precedence The precedence of the top-most operator or Integer.MAX_VALUE.
*/
public PyExpr(String text, int precedence) {
super(text, precedence);
}
/**
* Convert the given type to a Python String expression.
*
* @return A PyStringExpr representing this expression as a String.
*/
public PyStringExpr toPyString() {
return new PyStringExpr("str(" + getText() + ")", Integer.MAX_VALUE);
}
}