From 15281ace35052288f043bc4f75af4222458a1d8a Mon Sep 17 00:00:00 2001 From: Gabe Johnson Date: Thu, 11 Jan 2018 10:08:18 -0600 Subject: [PATCH] Add Tuple specification --- README.md | 25 +++++++++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 853e8b6..86cedde 100644 --- a/README.md +++ b/README.md @@ -850,7 +850,7 @@ nothing :: Maybe a just :: a -> Maybe a ``` -A value which conforms to the Maybe specification must provide an `cata` method. +A value which conforms to the Maybe specification must provide a `cata` method. The `cata` method takes two arguments: @@ -875,7 +875,7 @@ left :: a -> Either a b right :: b -> Either a b ``` -A value which conforms to the Either specification must provide an `cata` method. +A value which conforms to the Either specification must provide a `cata` method. The `cata` method takes two arguments: @@ -891,6 +891,27 @@ The `cata` method takes two arguments: 1. If `g` is not a function, the behaviour of `cata` is unspecified. 2. No parts of `g`'s return value should be checked. +### Tuple + +`Tuple` is the canonical product type and represents a structure containing two +values (Tuple a b). + +```hs +Tuple a b = { cata :: ((a, b) -> c) -> c } +tuple :: (a, b) -> Tuple a b +``` + +A value which conforms to the Tuple specification must provide a `cata` method. + +The `cata` method takes a single argument: + + t.cata(f) + +1. `f` must be a function of two arguments which returns a value + + 1. If `f` is not a function, the behaviour of `cata` is unspecified. + 2. No parts of `f`'s return value should be checked. + ## Derivations When creating data types which satisfy multiple algebras, authors may choose