All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.commons.jexl2.Script Maven / Gradle / Ivy

/*
 * 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.
 */
package org.apache.commons.jexl2;

import java.util.List;
import java.util.Set;
import java.util.concurrent.Callable;

/**
 * 

A JEXL Script.

*

A script is some valid JEXL syntax to be executed with * a given set of {@link JexlContext} variables.

*

A script is a group of statements, separated by semicolons.

*

The statements can be blocks (curly braces containing code), * Control statements such as if and while * as well as expressions and assignment statements.

* * @since 1.1 */ public interface Script { /** * Executes the script with the variables contained in the * supplied {@link JexlContext}. * * @param context A JexlContext containing variables. * @return The result of this script, usually the result of * the last statement. */ Object execute(JexlContext context); /** * Executes the script with the variables contained in the * supplied {@link JexlContext} and a set of arguments corresponding to the * parameters used during parsing. * * @param context A JexlContext containing variables. * @param args the arguments * @return The result of this script, usually the result of * the last statement. * @since 2.1 */ Object execute(JexlContext context, Object... args); /** * Returns the text of this Script. * @return The script to be executed. */ String getText(); /** * Gets this script parameters. * @return the parameters or null * @since 2.1 */ String[] getParameters(); /** * Gets this script local variables. * @return the local variables or null * @since 2.1 */ String[] getLocalVariables(); /** * Gets this script variables. *

Note that since variables can be in an ant-ish form (ie foo.bar.quux), each variable is returned as * a list of strings where each entry is a fragment of the variable ({"foo", "bar", "quux"} in the example.

* @return the variables or null * @since 2.1 */ Set> getVariables(); /** * Creates a Callable from this script. *

This allows to submit it to an executor pool and provides support for asynchronous calls.

*

The interpreter will handle interruption/cancellation gracefully if needed.

* @param context the context * @return the callable * @since 2.1 */ Callable callable(JexlContext context); /** * Creates a Callable from this script. *

This allows to submit it to an executor pool and provides support for asynchronous calls.

*

The interpreter will handle interruption/cancellation gracefully if needed.

* @param context the context * @param args the script arguments * @return the callable * @since 2.1 */ Callable callable(JexlContext context, Object... args); }