src/ZF/Let.thy
author wenzelm
Tue, 16 Jul 2002 18:37:03 +0200
changeset 13368 8f8ba32d148b
parent 13220 62c899c77151
permissions -rw-r--r--
added equal_elim_rule1;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1478
2b8c2a7547ab expanded tabs
clasohm
parents: 1401
diff changeset
     1
(*  Title:      ZF/Let
1061
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
     2
    ID:         $Id$
1478
2b8c2a7547ab expanded tabs
clasohm
parents: 1401
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
1061
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
     4
    Copyright   1995  University of Cambridge
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
     5
1094
840554ac0451 Patterns can now be let-bound
lcp
parents: 1061
diff changeset
     6
Let expressions, and tuple pattern-matching (borrowed from HOL)
1061
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
     7
*)
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
     8
1094
840554ac0451 Patterns can now be let-bound
lcp
parents: 1061
diff changeset
     9
Let = FOL +
1061
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    10
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    11
types
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    12
  letbinds  letbind
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    13
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    14
consts
13220
62c899c77151 tidying
paulson
parents: 4879
diff changeset
    15
  Let           :: "['a::logic, 'a => 'b] => ('b::logic)"
1061
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    16
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    17
syntax
13220
62c899c77151 tidying
paulson
parents: 4879
diff changeset
    18
  "_bind"       :: "[pttrn, 'a] => letbind"           ("(2_ =/ _)" 10)
62c899c77151 tidying
paulson
parents: 4879
diff changeset
    19
  ""            :: "letbind => letbinds"              ("_")
62c899c77151 tidying
paulson
parents: 4879
diff changeset
    20
  "_binds"      :: "[letbind, letbinds] => letbinds"  ("_;/ _")
62c899c77151 tidying
paulson
parents: 4879
diff changeset
    21
  "_Let"        :: "[letbinds, 'a] => 'a"             ("(let (_)/ in (_))" 10)
1061
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    22
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    23
translations
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    24
  "_Let(_binds(b, bs), e)"  == "_Let(b, _Let(bs, e))"
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    25
  "let x = a in e"          == "Let(a, %x. e)"
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    26
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    27
defs
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    28
  Let_def       "Let(s, f) == f(s)"
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    29
8897213195c0 Definition of 'let' declarations, from HOL
lcp
parents:
diff changeset
    30
end