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

dev.cel.common.ExprFeatures Maven / Gradle / Ivy

// Copyright 2022 Google LLC
//
// 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
//
//      https://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 dev.cel.common;

import com.google.common.collect.ImmutableSet;

/**
 * ExprFeatures are flags that alter how the CEL Java parser, checker, and interpreter behave.
 *
 * @deprecated Use {@code CelOptions} instead.
 */
@Deprecated
public enum ExprFeatures {

  /**
   * Require overloads to resolve (narrow to a single candidate) during type checking.
   *
   * 

This eliminates run-time overload dispatch and avoids implicit coercions of the result type * to type dyn. */ COMPILE_TIME_OVERLOAD_RESOLUTION, /** * When enabled use Java equality for (in)equality tests. * *

This feature is how the legacy CEL-Java APIs were originally configured, and in most cases * will yield identical results to CEL equality, with the exception that equality between * well-known protobuf types (wrapper types, {@code protobuf.Value}, {@code protobuf.Any}) may not * compare correctly to simple and aggregate CEL types. * *

Additionally, Java equality across numeric types such as {@code double} and {@code long}, * will be trivially false, whereas CEL equality will compare the values as though they exist on a * continuous number line. */ LEGACY_JAVA_EQUALITY, /** * During type checking require list-, and map literals to be type-homogeneous in their element-, * key-, and value types, respectively. * *

Without this flag one can use type-mismatched elements, keys, and values, and the type * checker will implicitly coerce them to type dyn. */ HOMOGENEOUS_LITERALS, /** * Treat regex {@code matches} calls as substring (unanchored) match patterns. * *

The default treatment for pattern matching within RE2 is full match within Java; however, * the CEL standarda specifies that the matches() function is a substring match. */ REGEX_PARTIAL_MATCH, /** * Check for use of reserved identifiers during parsing. * *

See the language * spec for a list of reserved identifiers. */ RESERVED_IDS, /** * Retain all invocations of unary '-' and '!' that occur in source in the abstract syntax. * *

By default the parser collapses towers of repeated unary '-' and '!' into zero or one * instance by assuming these operators to be inverses of themselves. This behavior may not always * be desirable. */ RETAIN_REPEATED_UNARY_OPERATORS, /** * Retain the original grouping of logical connectives '&&' and '||' without attempting to * rebalance them in the abstract syntax. * *

The default rebalancing can reduce the overall nesting depth of the generated protos * representing abstract syntax, but it relies on associativity of the operations themselves. This * behavior may not always be desirable. */ RETAIN_UNBALANCED_LOGICAL_EXPRESSIONS, /** * Treat unsigned integers as unsigned when doing arithmetic and comparisons. * *

Prior to turning on this feature, attempts to perform arithmetic or comparisons on unsigned * integers larger than 2^63-1 may result in a runtime exception in the form of an {@link * java.lang.IllegalArgumentException}. */ UNSIGNED_COMPARISON_AND_ARITHMETIC_IS_UNSIGNED, /** * Throw errors when ints or uints wrap. * *

Prior to this feature, int and uint arithmetic wrapped, i.e. was coerced into range via mod * 2^64. The spec settled on throwing an error instead. Note that this makes arithmetic non- * associative. */ ERROR_ON_WRAP, /** Error on duplicate keys in map literals. */ ERROR_ON_DUPLICATE_KEYS, /** Populate macro_calls map in source_info with macro calls parsed from the expression. */ POPULATE_MACRO_CALLS, /** * Enable the timestamp from epoch overload. This will automatically move to CURRENT after a two * month notice to consumers. * *

TODO: Remove this feature once it has been auto-enabled. */ ENABLE_TIMESTAMP_EPOCH, /** * Enable numeric comparisons across types. This will automatically move to CURRENT after a two * month notice to consumers. * *

TODO: Remove this feature once it has been auto-enabled. */ ENABLE_HETEROGENEOUS_NUMERIC_COMPARISONS, /** * Enable the using of {@code UnsignedLong} values in place of {@code Long} values for unsigned * integers. * *

Note, users must be careful not to supply {@code Long} values when {@code UnsignedLong} * values are intended. */ ENABLE_UNSIGNED_LONGS, /** * Enable proto differencer based equality for messages. This is in place of Message.equals() * which has a slightly different behavior. */ PROTO_DIFFERENCER_EQUALITY, /** * Enables the usage of namespaced functions and identifiers. This causes the type-checker to * rewrite the AST to support namespacing. */ ENABLE_NAMESPACED_DECLARATIONS; /** Feature flags that enable the current best practices for CEL. */ public static final ImmutableSet CURRENT = ImmutableSet.of( REGEX_PARTIAL_MATCH, RESERVED_IDS, UNSIGNED_COMPARISON_AND_ARITHMETIC_IS_UNSIGNED, ENABLE_NAMESPACED_DECLARATIONS, ERROR_ON_WRAP, ERROR_ON_DUPLICATE_KEYS); public static final ImmutableSet LEGACY = ImmutableSet.of(LEGACY_JAVA_EQUALITY); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy