Package groovy.util

Class Eval

java.lang.Object
groovy.util.Eval

public class Eval
extends java.lang.Object
Allow easy integration from Groovy into Java through convenience methods.

This class is a simple helper on top of GroovyShell. You can use it to evaluate small Groovy scripts that don't need large Binding objects. For example, this script executes with no errors:

 assert Eval.me(' 2 * 4 + 2') == 10
 assert Eval.x(2, ' x * 4 + 2') == 10
 
See Also:
GroovyShell
  • Constructor Summary

    Constructors
    Constructor Description
    Eval()  
  • Method Summary

    Modifier and Type Method Description
    static java.lang.Object me​(java.lang.String expression)
    Evaluates the specified String expression and returns the result.
    static java.lang.Object me​(java.lang.String symbol, java.lang.Object object, java.lang.String expression)
    Evaluates the specified String expression and makes the parameter available inside the script, returning the result.
    static java.lang.Object x​(java.lang.Object x, java.lang.String expression)
    Evaluates the specified String expression and makes the parameter available inside the script bound to a variable named 'x', returning the result.
    static java.lang.Object xy​(java.lang.Object x, java.lang.Object y, java.lang.String expression)
    Evaluates the specified String expression and makes the first two parameters available inside the script bound to variables named 'x' and 'y' respectively, returning the result.
    static java.lang.Object xyz​(java.lang.Object x, java.lang.Object y, java.lang.Object z, java.lang.String expression)
    Evaluates the specified String expression and makes the first three parameters available inside the script bound to variables named 'x', 'y', and 'z' respectively, returning the result.

    Methods inherited from class java.lang.Object

    clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
  • Constructor Details

    • Eval

      public Eval()
  • Method Details

    • me

      public static java.lang.Object me​(java.lang.String expression) throws CompilationFailedException
      Evaluates the specified String expression and returns the result. For example:
       assert Eval.me(' 2 * 4 + 2') == 10
       
      Parameters:
      expression - the Groovy expression to evaluate
      Returns:
      the result of the expression
      Throws:
      CompilationFailedException - if expression is not valid Groovy
    • me

      public static java.lang.Object me​(java.lang.String symbol, java.lang.Object object, java.lang.String expression) throws CompilationFailedException
      Evaluates the specified String expression and makes the parameter available inside the script, returning the result. For example, this code binds the 'x' variable:
       assert Eval.me('x', 2, ' x * 4 + 2') == 10
       
      Parameters:
      expression - the Groovy expression to evaluate
      Returns:
      the result of the expression
      Throws:
      CompilationFailedException - if expression is not valid Groovy
    • x

      public static java.lang.Object x​(java.lang.Object x, java.lang.String expression) throws CompilationFailedException
      Evaluates the specified String expression and makes the parameter available inside the script bound to a variable named 'x', returning the result. For example, this code executes without failure:
       assert Eval.x(2, ' x * 4 + 2') == 10
       
      Parameters:
      expression - the Groovy expression to evaluate
      Returns:
      the result of the expression
      Throws:
      CompilationFailedException - if expression is not valid Groovy
    • xy

      public static java.lang.Object xy​(java.lang.Object x, java.lang.Object y, java.lang.String expression) throws CompilationFailedException
      Evaluates the specified String expression and makes the first two parameters available inside the script bound to variables named 'x' and 'y' respectively, returning the result. For example, this code executes without failure:
       assert Eval.xy(2, 4, ' x * y + 2') == 10
       
      Parameters:
      expression - the Groovy expression to evaluate
      Returns:
      the result of the expression
      Throws:
      CompilationFailedException - if expression is not valid Groovy
    • xyz

      public static java.lang.Object xyz​(java.lang.Object x, java.lang.Object y, java.lang.Object z, java.lang.String expression) throws CompilationFailedException
      Evaluates the specified String expression and makes the first three parameters available inside the script bound to variables named 'x', 'y', and 'z' respectively, returning the result. For example, this code executes without failure:
       assert Eval.xyz(2, 4, 2, ' x * y + z') == 10
       
      Parameters:
      expression - the Groovy expression to evaluate
      Returns:
      the result of the expression
      Throws:
      CompilationFailedException - if expression is not valid Groovy