com.github.tonivade.purefun.instances.KleisliInstances Maven / Gradle / Ivy
/*
* Copyright (c) 2018-2019, Antonio Gabriel Muñoz Conejo
* Distributed under the terms of the MIT License
*/
package com.github.tonivade.purefun.instances;
import static java.util.Objects.requireNonNull;
import com.github.tonivade.purefun.Function1;
import com.github.tonivade.purefun.Higher1;
import com.github.tonivade.purefun.Instance;
import com.github.tonivade.purefun.Kind;
import com.github.tonivade.purefun.transformer.Kleisli;
import com.github.tonivade.purefun.typeclasses.Monad;
public interface KleisliInstances {
static Monad, Z>> monad(Monad monadF) {
requireNonNull(monadF);
return new KleisliMonad() {
@Override
public Monad monadF() { return monadF; }
};
}
}
@Instance
interface KleisliMonad extends Monad, Z>> {
Monad monadF();
@Override
default Kleisli pure(T value) {
return Kleisli.pure(monadF(), value);
}
@Override
default Kleisli flatMap(Higher1, Z>, T> value,
Function1, Z>, R>> map) {
return Kleisli.narrowK(value).flatMap(map.andThen(Kleisli::narrowK));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy