Skip to content

Instantly share code, notes, and snippets.

@OleTraveler
Created December 20, 2012 17:35
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save OleTraveler/4347051 to your computer and use it in GitHub Desktop.
Save OleTraveler/4347051 to your computer and use it in GitHub Desktop.
val validInt: String => ValidationNEL[String, Int] = s =>
for {
validStr <- (allDigits(s) |@| maxSizeOfTen(s))((_,x) => x)
i <- toInt(validStr)
} yield(i)
@drstevens
Copy link

I believe you could also write this as

val validInt: String => ValidationNEL[String, Int] = s =>
  for {
    _ <- (allDigits(s) <|*|> maxSizeOfTen(s))
    i <- toInt(s)
} yield(i)

or

val validInt: String => ValidationNEL[String, Int] = s =>
  for {
    validStr <- (allDigits(s) *> maxSizeOfTen(s))
    i <- toInt(validStr)
} yield(i)

or

val validInt: String => ValidationNEL[String, Int] = s =>
  for {
    validStr <- (allDigits(s) <* maxSizeOfTen(s))
    i <- toInt(validStr)
} yield(i)

or

val validInt: String => ValidationNEL[String, Int] = s =>
  (allDigits(s) *> maxSizeOfTen(s)) flatMap toInt

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment