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

org.elasticsearch.xpack.esql.optimizer.rules.PartiallyFoldCase Maven / Gradle / Ivy

There is a newer version: 8.16.1
Show newest version
/*
 * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
 * or more contributor license agreements. Licensed under the Elastic License
 * 2.0; you may not use this file except in compliance with the Elastic License
 * 2.0.
 */

package org.elasticsearch.xpack.esql.optimizer.rules;

import org.elasticsearch.xpack.esql.core.expression.Expression;
import org.elasticsearch.xpack.esql.core.optimizer.OptimizerRules;
import org.elasticsearch.xpack.esql.expression.function.scalar.conditional.Case;

import static org.elasticsearch.xpack.esql.core.optimizer.OptimizerRules.TransformDirection.DOWN;

/**
 * Fold the arms of {@code CASE} statements.
 * 
{@code
 * EVAL c=CASE(true, foo, bar)
 * }
* becomes *
{@code
 * EVAL c=foo
 * }
*/ public final class PartiallyFoldCase extends OptimizerRules.OptimizerExpressionRule { public PartiallyFoldCase() { super(DOWN); } @Override protected Expression rule(Case c) { return c.partiallyFold(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy