ditto-0.1.3.0: ditto is a type-safe HTML form generation and validation library

Safe HaskellNone
LanguageHaskell98

Ditto.Proof

Contents

Description

This module defines the Proof type, some proofs, and some helper functions.

A Proof does three things:

  • verifies that the input value meets some criteria
  • optionally transforms the input value to another value while preserving that criteria
  • puts the proof name in type-signature where the type-checker can use it
Synopsis

Documentation

newtype Proof m error a b Source #

A Proof attempts to prove something about a value.

If successful, it can also transform the value to a new value. The proof should hold for the new value as well.

Generally, each Proof has a unique data-type associated with it which names the proof, such as:

Constructors

Proof 

Fields

prove :: Monad m => Form m input error view a -> Proof m error a b -> Form m input error view b Source #

apply a Proof to a Form

transformations (proofs minus the proof).

transform :: Monad m => Form m input error view a -> Proof m error a b -> Form m input error view b Source #

transform a Form using a Proof, and the replace the proof with ().

This is useful when you want just want classic digestive-functors behaviour.

transformEitherM :: Monad m => Form m input error view a -> (a -> m (Either error b)) -> Form m input error view b Source #

transform the Form result using a monadic Either function.

transformEither :: Monad m => Form m input error view a -> (a -> Either error b) -> Form m input error view b Source #

transform the Form result using an Either function.

Various Proofs

notNullProof :: Monad m => error -> Proof m error [a] [a] Source #

prove that a list is not empty

decimal Source #

Arguments

:: (Monad m, Eq i, Num i) 
=> (String -> error)

create an error message (String is the value that did not parse)

-> Proof m error String i 

read an unsigned number in decimal notation

signedDecimal :: (Monad m, Eq i, Real i) => (String -> error) -> Proof m error String i Source #

read signed decimal number

realFrac :: (Monad m, RealFrac a) => (String -> error) -> Proof m error String a Source #

read RealFrac number

realFracSigned :: (Monad m, RealFrac a) => (String -> error) -> Proof m error String a Source #

read a signed RealFrac number