Skip to content

Instantly share code, notes, and snippets.

@yasuabe
Created April 7, 2019 15:19
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save yasuabe/bcb4aac044d1d4c3002eb65e4c18aeff to your computer and use it in GitHub Desktop.
Save yasuabe/bcb4aac044d1d4c3002eb65e4c18aeff to your computer and use it in GitHub Desktop.
sample code for Cats MTL FunctorRaise
import cats.mtl.FunctorRaise
import cats.syntax.applicative._
import cats.instances.string._
import cats.{Applicative, Semigroupal}
import cats.data.Validated
def parseNumber[F[_]: Applicative](in: String)(implicit F: FunctorRaise[F, String]): F[Double] =
if (in.matches("-?[0-9]+")) in.toDouble.pure[F]
else F.raise(in) // raise 構文
import cats.mtl.instances.handle._
val result: Validated[String, (Double, Double, Double)] = Semigroupal.tuple3(
parseNumber[Validated[String, ?]]("abc"),
parseNumber[Validated[String, ?]]("123"),
parseNumber[Validated[String, ?]]("xyz")
)
// result = Invalid(abcxyz)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment