| author | paulson | 
| Fri, 18 Feb 2000 15:33:09 +0100 | |
| changeset 8253 | 975eb12aa040 | 
| parent 5445 | 3905974ad555 | 
| child 9001 | 93af64f54bf2 | 
| permissions | -rw-r--r-- | 
(* Title: Option.thy ID: $Id$ Author: Tobias Nipkow Copyright 1994 TU Muenchen Datatype 'a option *) Option = Datatype + datatype 'a option = None | Some 'a constdefs the :: "'a option => 'a" "the == %y. case y of None => arbitrary | Some x => x" option_map :: "('a => 'b) => ('a option => 'b option)" "option_map == %f y. case y of None => None | Some x => Some (f x)" consts o2s :: "'a option => 'a set" primrec "o2s None = {}" "o2s (Some x) = {x}" end