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

com.speedment.runtime.compute.ToEnum Maven / Gradle / Ivy

Go to download

A Speedment bundle that shades all dependencies into one jar. This is useful when deploying an application on a server.

There is a newer version: 3.1.18
Show newest version
/**
 *
 * Copyright (c) 2006-2019, Speedment, Inc. All Rights Reserved.
 *
 * 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.speedment.runtime.compute;

import com.speedment.runtime.compute.expression.Expression;
import com.speedment.runtime.compute.expression.ExpressionType;
import com.speedment.runtime.compute.internal.ToEnumImpl;
import com.speedment.runtime.compute.internal.expression.ComposedUtil;
import com.speedment.runtime.compute.internal.expression.MapperUtil;
import com.speedment.runtime.compute.trait.HasCompare;
import com.speedment.runtime.compute.trait.HasCompose;
import com.speedment.runtime.compute.trait.HasHash;
import com.speedment.runtime.compute.trait.HasMap;

import java.util.function.Function;
import java.util.function.UnaryOperator;

/**
 * Expression that given an entity returns a non-null {@code enum} value. The
 * expression also knows about the enum class and can therefore not be
 * implemented as a lambda like the other expressions in this module.
 *
 * @param  type to extract from
 * @param  enum type
 *
 * @see Function
 *
 * @author Emil Forslund
 * @since  3.1.0
 */
public interface ToEnum>
extends Expression,
        Function,
        HasMap, ToEnum>,
        HasHash,
        HasCompare,
        HasCompose {

    /**
     * Returns a typed {@code ToEnum} using the provided
     * {@code lambda}.
     *
     * @param  type to extract from
     * @param  enum type
     * @param lambda to convert
     * @param enumClass class of the enum
     * @return a typed {@code ToEnum} using the provided
     *         {@code lambda}
     *
     * @throws NullPointerException if the provided {@code lambda} is
     * {@code null}
     */
    static > ToEnum
    of(Class enumClass, Function lambda) {
        return new ToEnumImpl<>(enumClass, lambda);
    }

    /**
     * Returns the {@code class} of the enum that this expression returns.
     *
     * @return  the enum class
     */
    Class enumClass();

    @Override
    default ExpressionType expressionType() {
        return ExpressionType.ENUM;
    }

    @Override
    E apply(T t);

    /**
     * Returns an alternative expression that represents the
     * {@link Enum#ordinal()} of the enum that would otherwise have been
     * returned by this expression.
     *
     * @return  the ordinal expression
     */
    default ToInt asOrdinal() {
        return t -> apply(t).ordinal();
    }

    /**
     * Returns an alternative expression that represents the {@link Enum#name()}
     * of the enum that would otherwise have been returned by this expression.
     *
     * @return  the name expression
     */
    default ToString asName() {
        return t -> apply(t).name();
    }

    @Override
    default ToEnum map(UnaryOperator mapper) {
        return MapperUtil.mapEnum(this, mapper);
    }

    @Override
    default long hash(T object) {
        return apply(object).hashCode();
    }

    @Override
    default int compare(T first, T second) {
        return apply(first).compareTo(apply(second));
    }

    @Override
    default  ToEnumNullable compose(Function before) {
        @SuppressWarnings("unchecked")
        final Function casted = (Function) before;
        return ComposedUtil.composeToEnum(casted, this);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy