(*  Title:      ZF/Coind/Values.thy
    ID:         $Id$
    Author:     Jacob Frost, Cambridge University Computer Laboratory
    Copyright   1995  University of Cambridge
*)
Values = Language + Map +
(* Values, values environments and associated operators *)
consts
  Val, ValEnv, Val_ValEnv  :: i
codatatype
    "Val" = v_const ("c:Const")
          | v_clos ("x:ExVar","e:Exp","ve:ValEnv")
  and
    "ValEnv" = ve_mk ("m:PMap(ExVar,Val)")
  monos       map_mono
  type_intrs  A_into_univ, mapQU
consts
  ve_owr :: [i,i,i] => i
  ve_dom :: i=>i
  ve_app :: [i,i] => i
primrec "ve_owr(ve_mk(m), x, v) = ve_mk(map_owr(m,x,v))"
primrec "ve_dom(ve_mk(m)) = domain(m)"
primrec "ve_app(ve_mk(m), a) = map_app(m,a)"
constdefs
  ve_emp :: i
   "ve_emp == ve_mk(map_emp)"
end