src/HOL/Library/LaTeXsugar.thy
author nipkow
Mon, 30 May 2005 08:21:58 +0200
changeset 16110 c423bb89186d
parent 15690 1da2cfd1ca45
child 19674 22b635240905
permissions -rw-r--r--
added \nexists
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
15469
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/Library/LaTeXsugar.thy
nipkow
parents:
diff changeset
     2
    ID:         $Id$
nipkow
parents:
diff changeset
     3
    Author:     Gerwin Klain, Tobias Nipkow, Norbert Schirmer
nipkow
parents:
diff changeset
     4
    Copyright   2005 NICTA and TUM
nipkow
parents:
diff changeset
     5
*)
nipkow
parents:
diff changeset
     6
nipkow
parents:
diff changeset
     7
(*<*)
nipkow
parents:
diff changeset
     8
theory LaTeXsugar
nipkow
parents:
diff changeset
     9
imports Main
nipkow
parents:
diff changeset
    10
begin
nipkow
parents:
diff changeset
    11
nipkow
parents:
diff changeset
    12
(* LOGIC *)
nipkow
parents:
diff changeset
    13
syntax (latex output)
nipkow
parents:
diff changeset
    14
  If            :: "[bool, 'a, 'a] => 'a"
nipkow
parents:
diff changeset
    15
  ("(\<^raw:\textsf{>if\<^raw:}> (_)/ \<^raw:\textsf{>then\<^raw:}> (_)/ \<^raw:\textsf{>else\<^raw:}> (_))" 10)
nipkow
parents:
diff changeset
    16
nipkow
parents:
diff changeset
    17
  "_Let"        :: "[letbinds, 'a] => 'a"
nipkow
parents:
diff changeset
    18
  ("(\<^raw:\textsf{>let\<^raw:}> (_)/ \<^raw:\textsf{>in\<^raw:}> (_))" 10)
nipkow
parents:
diff changeset
    19
nipkow
parents:
diff changeset
    20
  "_case_syntax":: "['a, cases_syn] => 'b"
nipkow
parents:
diff changeset
    21
  ("(\<^raw:\textsf{>case\<^raw:}> _ \<^raw:\textsf{>of\<^raw:}>/ _)" 10)
nipkow
parents:
diff changeset
    22
16110
c423bb89186d added \nexists
nipkow
parents: 15690
diff changeset
    23
(* should become standard syntax once x-symbols supports it *)
c423bb89186d added \nexists
nipkow
parents: 15690
diff changeset
    24
syntax (latex)
c423bb89186d added \nexists
nipkow
parents: 15690
diff changeset
    25
  nexists :: "('a => bool) => bool"           (binder "\<nexists>" 10)
c423bb89186d added \nexists
nipkow
parents: 15690
diff changeset
    26
translations
c423bb89186d added \nexists
nipkow
parents: 15690
diff changeset
    27
  "\<nexists>x. P" <= "\<not>(\<exists>x. P)"
c423bb89186d added \nexists
nipkow
parents: 15690
diff changeset
    28
15469
nipkow
parents:
diff changeset
    29
(* SETS *)
nipkow
parents:
diff changeset
    30
nipkow
parents:
diff changeset
    31
(* empty set *)
nipkow
parents:
diff changeset
    32
syntax (latex output)
nipkow
parents:
diff changeset
    33
  "_emptyset" :: "'a set"              ("\<emptyset>")
nipkow
parents:
diff changeset
    34
translations
nipkow
parents:
diff changeset
    35
  "_emptyset"      <= "{}"
nipkow
parents:
diff changeset
    36
nipkow
parents:
diff changeset
    37
(* insert *)
nipkow
parents:
diff changeset
    38
translations 
nipkow
parents:
diff changeset
    39
  "{x} \<union> A" <= "insert x A"
15690
nipkow
parents: 15476
diff changeset
    40
  "{x,y}" <= "{x} \<union> {y}"
15469
nipkow
parents:
diff changeset
    41
  "{x,y} \<union> A" <= "{x} \<union> ({y} \<union> A)"
15476
b8cb20cc0c0b fixed bugs
nipkow
parents: 15469
diff changeset
    42
  "{x}" <= "{x} \<union> _emptyset"
15469
nipkow
parents:
diff changeset
    43
nipkow
parents:
diff changeset
    44
(* set comprehension *)
nipkow
parents:
diff changeset
    45
syntax (latex output)
nipkow
parents:
diff changeset
    46
  "_Collect" :: "pttrn => bool => 'a set"              ("(1{_ | _})")
nipkow
parents:
diff changeset
    47
translations
nipkow
parents:
diff changeset
    48
  "_Collect p P"      <= "{p. P}"
15690
nipkow
parents: 15476
diff changeset
    49
  "_Collect p P"      <= "{p|xs. P}"
15469
nipkow
parents:
diff changeset
    50
nipkow
parents:
diff changeset
    51
(* LISTS *)
nipkow
parents:
diff changeset
    52
nipkow
parents:
diff changeset
    53
(* Cons *)
nipkow
parents:
diff changeset
    54
syntax (latex)
nipkow
parents:
diff changeset
    55
  Cons :: "'a \<Rightarrow> 'a list \<Rightarrow> 'a list" ("_\<cdot>/_" [66,65] 65)
nipkow
parents:
diff changeset
    56
nipkow
parents:
diff changeset
    57
(* length *)
nipkow
parents:
diff changeset
    58
syntax (latex output)
nipkow
parents:
diff changeset
    59
  length :: "'a list \<Rightarrow> nat" ("|_|")
nipkow
parents:
diff changeset
    60
nipkow
parents:
diff changeset
    61
(* nth *)
nipkow
parents:
diff changeset
    62
syntax (latex output)
nipkow
parents:
diff changeset
    63
  nth :: "'a list \<Rightarrow> nat \<Rightarrow> 'a" ("_\<^raw:\ensuremath{_{[\mathit{>_\<^raw:}]}}>" [1000,0] 1000)
nipkow
parents:
diff changeset
    64
nipkow
parents:
diff changeset
    65
(* DUMMY *)
nipkow
parents:
diff changeset
    66
consts DUMMY :: 'a ("\<^raw:\_>")
nipkow
parents:
diff changeset
    67
nipkow
parents:
diff changeset
    68
(* THEOREMS *)
nipkow
parents:
diff changeset
    69
syntax (Rule output)
nipkow
parents:
diff changeset
    70
  "==>" :: "prop \<Rightarrow> prop \<Rightarrow> prop"
nipkow
parents:
diff changeset
    71
  ("\<^raw:\mbox{}\inferrule{\mbox{>_\<^raw:}}>\<^raw:{\mbox{>_\<^raw:}}>")
nipkow
parents:
diff changeset
    72
nipkow
parents:
diff changeset
    73
  "_bigimpl" :: "asms \<Rightarrow> prop \<Rightarrow> prop"
nipkow
parents:
diff changeset
    74
  ("\<^raw:\mbox{}\inferrule{>_\<^raw:}>\<^raw:{\mbox{>_\<^raw:}}>")
nipkow
parents:
diff changeset
    75
nipkow
parents:
diff changeset
    76
  "_asms" :: "prop \<Rightarrow> asms \<Rightarrow> asms" 
nipkow
parents:
diff changeset
    77
  ("\<^raw:\mbox{>_\<^raw:}\\>/ _")
nipkow
parents:
diff changeset
    78
nipkow
parents:
diff changeset
    79
  "_asm" :: "prop \<Rightarrow> asms" ("\<^raw:\mbox{>_\<^raw:}>")
nipkow
parents:
diff changeset
    80
nipkow
parents:
diff changeset
    81
syntax (IfThen output)
nipkow
parents:
diff changeset
    82
  "==>" :: "prop \<Rightarrow> prop \<Rightarrow> prop"
nipkow
parents:
diff changeset
    83
  ("\<^raw:{\rmfamily\upshape\normalsize{}>If\<^raw:\,}> _/ \<^raw:{\rmfamily\upshape\normalsize \,>then\<^raw:\,}>/ _.")
nipkow
parents:
diff changeset
    84
  "_bigimpl" :: "asms \<Rightarrow> prop \<Rightarrow> prop"
nipkow
parents:
diff changeset
    85
  ("\<^raw:{\rmfamily\upshape\normalsize{}>If\<^raw:\,}> _ /\<^raw:{\rmfamily\upshape\normalsize \,>then\<^raw:\,}>/ _.")
nipkow
parents:
diff changeset
    86
  "_asms" :: "prop \<Rightarrow> asms \<Rightarrow> asms" ("\<^raw:\mbox{>_\<^raw:}> /\<^raw:{\rmfamily\upshape\normalsize \,>and\<^raw:\,}>/ _")
nipkow
parents:
diff changeset
    87
  "_asm" :: "prop \<Rightarrow> asms" ("\<^raw:\mbox{>_\<^raw:}>")
nipkow
parents:
diff changeset
    88
nipkow
parents:
diff changeset
    89
syntax (IfThenNoBox output)
nipkow
parents:
diff changeset
    90
  "==>" :: "prop \<Rightarrow> prop \<Rightarrow> prop"
nipkow
parents:
diff changeset
    91
  ("\<^raw:{\rmfamily\upshape\normalsize{}>If\<^raw:\,}> _/ \<^raw:{\rmfamily\upshape\normalsize \,>then\<^raw:\,}>/ _.")
nipkow
parents:
diff changeset
    92
  "_bigimpl" :: "asms \<Rightarrow> prop \<Rightarrow> prop"
nipkow
parents:
diff changeset
    93
  ("\<^raw:{\rmfamily\upshape\normalsize{}>If\<^raw:\,}> _ /\<^raw:{\rmfamily\upshape\normalsize \,>then\<^raw:\,}>/ _.")
nipkow
parents:
diff changeset
    94
  "_asms" :: "prop \<Rightarrow> asms \<Rightarrow> asms" ("_ /\<^raw:{\rmfamily\upshape\normalsize \,>and\<^raw:\,}>/ _")
nipkow
parents:
diff changeset
    95
  "_asm" :: "prop \<Rightarrow> asms" ("_")
nipkow
parents:
diff changeset
    96
nipkow
parents:
diff changeset
    97
end
nipkow
parents:
diff changeset
    98
(*>*)