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

hydra.lib.optionals.Bind Maven / Gradle / Ivy

package hydra.lib.optionals;

import hydra.Flows;
import hydra.compute.Flow;
import hydra.core.Name;
import hydra.core.Term;
import hydra.core.Type;
import hydra.dsl.Expect;
import hydra.dsl.Terms;
import hydra.graph.Graph;
import hydra.tools.PrimitiveFunction;

import java.util.List;
import java.util.function.Function;
import java.util.Optional;

import static hydra.dsl.Types.function;
import static hydra.dsl.Types.lambda;
import static hydra.dsl.Types.optional;


public class Bind extends PrimitiveFunction {
    public Name name() {
        return new Name("hydra/lib/optionals.bind");
    }

    @Override
    public Type type() {
        return lambda("a", lambda("b",
                function(optional("a"), function("a", optional("b")), optional("b"))));
    }

    @Override
    protected Function>, Flow, Term>> implementation() {
        return args -> Flows.map(Expect.optional(Flows::pure, args.get(0)),
            arg -> arg.map(term -> Terms.optional(Optional.of(Terms.apply(args.get(1), term))))
                .orElseGet(() -> Terms.optional(Optional.empty())));
    }

    public static  Function>, Optional> apply(Optional optionalArg) {
        return (f) -> apply(optionalArg, f);
    }

    /**
     * Apply the function to both arguments.
     */
    public static  Optional apply(Optional optionalArg, Function> f) {
        return optionalArg.isPresent()
            ? f.apply(optionalArg.get())
            : Optional.empty();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy