src/HOL/Library/Code_Char.thy
author blanchet
Fri, 07 Mar 2014 14:21:15 +0100
changeset 55969 8820ddb8f9f4
parent 55427 ff54d22fe357
child 57437 0baf08c075b9
permissions -rw-r--r--
use balanced tuples in 'primcorec'
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24999
haftmann
parents:
diff changeset
     1
(*  Title:      HOL/Library/Code_Char.thy
haftmann
parents:
diff changeset
     2
    Author:     Florian Haftmann
haftmann
parents:
diff changeset
     3
*)
haftmann
parents:
diff changeset
     4
haftmann
parents:
diff changeset
     5
header {* Code generation of pretty characters (and strings) *}
haftmann
parents:
diff changeset
     6
haftmann
parents:
diff changeset
     7
theory Code_Char
51542
738598beeb26 tuned imports;
wenzelm
parents: 51160
diff changeset
     8
imports Main Char_ord
24999
haftmann
parents:
diff changeset
     9
begin
haftmann
parents:
diff changeset
    10
52435
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    11
code_printing
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    12
  type_constructor char \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    13
    (SML) "char"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    14
    and (OCaml) "char"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    15
    and (Haskell) "Prelude.Char"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    16
    and (Scala) "Char"
24999
haftmann
parents:
diff changeset
    17
haftmann
parents:
diff changeset
    18
setup {*
37222
4d984bc33c66 added Scala code setup
haftmann
parents: 33234
diff changeset
    19
  fold String_Code.add_literal_char ["SML", "OCaml", "Haskell", "Scala"] 
31053
b7e1c065b6e4 confine term setup to Eval serialiser
haftmann
parents: 31046
diff changeset
    20
  #> String_Code.add_literal_list_string "Haskell"
24999
haftmann
parents:
diff changeset
    21
*}
haftmann
parents:
diff changeset
    22
52435
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    23
code_printing
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    24
  class_instance char :: equal \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    25
    (Haskell) -
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    26
| constant "HOL.equal :: char \<Rightarrow> char \<Rightarrow> bool" \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    27
    (SML) "!((_ : char) = _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    28
    and (OCaml) "!((_ : char) = _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    29
    and (Haskell) infix 4 "=="
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    30
    and (Scala) infixl 5 "=="
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    31
| constant "Code_Evaluation.term_of \<Colon> char \<Rightarrow> term" \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    32
    (Eval) "HOLogic.mk'_char/ (IntInf.fromInt/ (Char.ord/ _))"
24999
haftmann
parents:
diff changeset
    33
haftmann
parents:
diff changeset
    34
code_reserved SML
haftmann
parents:
diff changeset
    35
  char
haftmann
parents:
diff changeset
    36
haftmann
parents:
diff changeset
    37
code_reserved OCaml
haftmann
parents:
diff changeset
    38
  char
haftmann
parents:
diff changeset
    39
37222
4d984bc33c66 added Scala code setup
haftmann
parents: 33234
diff changeset
    40
code_reserved Scala
4d984bc33c66 added Scala code setup
haftmann
parents: 33234
diff changeset
    41
  char
4d984bc33c66 added Scala code setup
haftmann
parents: 33234
diff changeset
    42
33234
a5eba0447559 added implode and explode
haftmann
parents: 32657
diff changeset
    43
definition implode :: "string \<Rightarrow> String.literal" where
a5eba0447559 added implode and explode
haftmann
parents: 32657
diff changeset
    44
  "implode = STR"
a5eba0447559 added implode and explode
haftmann
parents: 32657
diff changeset
    45
a5eba0447559 added implode and explode
haftmann
parents: 32657
diff changeset
    46
code_reserved SML String
a5eba0447559 added implode and explode
haftmann
parents: 32657
diff changeset
    47
52435
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    48
code_printing
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    49
  constant implode \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    50
    (SML) "String.implode"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    51
    and (OCaml) "!(let l = _ in let res = String.create (List.length l) in let rec imp i = function | [] -> res | c :: l -> String.set res i c; imp (i + 1) l in imp 0 l)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    52
    and (Haskell) "_"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    53
    and (Scala) "!(\"\" ++/ _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    54
| constant explode \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    55
    (SML) "String.explode"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    56
    and (OCaml) "!(let s = _ in let rec exp i l = if i < 0 then l else exp (i - 1) (String.get s i :: l) in exp (String.length s - 1) [])"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    57
    and (Haskell) "_"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    58
    and (Scala) "!(_.toList)"
33234
a5eba0447559 added implode and explode
haftmann
parents: 32657
diff changeset
    59
51160
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    60
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    61
definition integer_of_char :: "char \<Rightarrow> integer"
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    62
where
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    63
  "integer_of_char = integer_of_nat o nat_of_char"
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    64
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    65
definition char_of_integer :: "integer \<Rightarrow> char"
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    66
where
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    67
  "char_of_integer = char_of_nat \<circ> nat_of_integer"
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    68
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    69
lemma [code]:
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    70
  "nat_of_char = nat_of_integer o integer_of_char"
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    71
  by (simp add: integer_of_char_def fun_eq_iff)
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    72
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    73
lemma [code]:
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    74
  "char_of_nat = char_of_integer o integer_of_nat"
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    75
  by (simp add: char_of_integer_def fun_eq_iff)
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
    76
55427
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    77
lemmas integer_of_char_code [code] =
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    78
  nat_of_char_simps[
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    79
    THEN arg_cong[where f="integer_of_nat"],
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    80
    unfolded integer_of_nat_numeral integer_of_nat_1 integer_of_nat_0,
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    81
    folded fun_cong[OF integer_of_char_def, unfolded o_apply]]
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    82
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    83
lemma char_of_integer_code [code]:
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    84
  "char_of_integer n = enum_class.enum ! (nat_of_integer n mod 256)"
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    85
by(simp add: char_of_integer_def char_of_nat_def)
ff54d22fe357 make integer_of_char and char_of_integer work with NBE and code_simp
Andreas Lochbihler
parents: 54599
diff changeset
    86
52435
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    87
code_printing
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    88
  constant integer_of_char \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    89
    (SML) "!(IntInf.fromInt o Char.ord)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    90
    and (OCaml) "Big'_int.big'_int'_of'_int (Char.code _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    91
    and (Haskell) "Prelude.toInteger (Prelude.fromEnum (_ :: Prelude.Char))"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    92
    and (Scala) "BigInt(_.toInt)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    93
| constant char_of_integer \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    94
    (SML) "!(Char.chr o IntInf.toInt)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    95
    and (OCaml) "Char.chr (Big'_int.int'_of'_big'_int _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    96
    and (Haskell) "!(let chr k | (0 <= k && k < 256) = Prelude.toEnum k :: Prelude.Char in chr . Prelude.fromInteger)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    97
    and (Scala) "!((k: BigInt) => if (BigInt(0) <= k && k < BigInt(256)) k.charValue else error(\"character value out of range\"))"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    98
| constant "Orderings.less_eq :: char \<Rightarrow> char \<Rightarrow> bool" \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
    99
    (SML) "!((_ : char) <= _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   100
    and (OCaml) "!((_ : char) <= _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   101
    and (Haskell) infix 4 "<="
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   102
    and (Scala) infixl 4 "<="
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   103
    and (Eval) infixl 6 "<="
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   104
| constant "Orderings.less :: char \<Rightarrow> char \<Rightarrow> bool" \<rightharpoonup>
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   105
    (SML) "!((_ : char) < _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   106
    and (OCaml) "!((_ : char) < _)"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   107
    and (Haskell) infix 4 "<"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   108
    and (Scala) infixl 4 "<"
6646bb548c6b migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents: 51542
diff changeset
   109
    and (Eval) infixl 6 "<"
54596
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   110
|  constant "Orderings.less_eq :: String.literal \<Rightarrow> String.literal \<Rightarrow> bool" \<rightharpoonup>
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   111
    (SML) "!((_ : string) <= _)"
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   112
    and (OCaml) "!((_ : string) <= _)"
54599
17d76426c7da revert 4af7c82463d3 and document type class problem in Haskell
Andreas Lochbihler
parents: 54596
diff changeset
   113
    -- {* Order operations for @{typ String.literal} work in Haskell only 
17d76426c7da revert 4af7c82463d3 and document type class problem in Haskell
Andreas Lochbihler
parents: 54596
diff changeset
   114
          if no type class instance needs to be generated, because String = [Char] in Haskell
17d76426c7da revert 4af7c82463d3 and document type class problem in Haskell
Andreas Lochbihler
parents: 54596
diff changeset
   115
          and @{typ "char list"} need not have the same order as @{typ String.literal}. *}
54596
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   116
    and (Haskell) infix 4 "<="
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   117
    and (Scala) infixl 4 "<="
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   118
    and (Eval) infixl 6 "<="
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   119
| constant "Orderings.less :: String.literal \<Rightarrow> String.literal \<Rightarrow> bool" \<rightharpoonup>
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   120
    (SML) "!((_ : string) < _)"
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   121
    and (OCaml) "!((_ : string) < _)"
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   122
    and (Haskell) infix 4 "<"
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   123
    and (Scala) infixl 4 "<"
368c70ee1f46 implement comparisons on String.literal by target-language comparisons
Andreas Lochbihler
parents: 52435
diff changeset
   124
    and (Eval) infixl 6 "<"
51160
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
   125
24999
haftmann
parents:
diff changeset
   126
end
51160
599ff65b85e2 systematic conversions between nat and nibble/char;
haftmann
parents: 48431
diff changeset
   127