author | paulson |
Sat, 01 Nov 1997 12:59:06 +0100 | |
changeset 4059 | 59c1422c9da5 |
parent 3842 | b55686a7b22c |
permissions | -rw-r--r-- |
(* Title: HOL/W0/Maybe.thy ID: $Id$ Author: Dieter Nazareth and Tobias Nipkow Copyright 1995 TU Muenchen Universal error monad. *) Maybe = List + datatype 'a maybe = Ok 'a | Fail constdefs bind :: ['a maybe, 'a => 'b maybe] => 'b maybe (infixl 60) "m bind f == case m of Ok r => f r | Fail => Fail" syntax "@bind" :: [patterns,'a maybe,'b] => 'c ("(_ := _;//_)" 0) translations "P := E; F" == "E bind (%P. F)" end