doc-src/IsarAdvanced/Codegen/Thy/examples/class.ML
author urbanc
Thu, 22 Mar 2007 11:17:32 +0100
changeset 22495 c54748fd1f43
parent 22386 4ebe883b02ff
child 22751 1bfd75c1f232
permissions -rw-r--r--
clarified an error-message
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     1
structure ROOT = 
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     2
struct
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     3
21190
08ec81dfc7fb (continued)
haftmann
parents: 21147
diff changeset
     4
structure Nat = 
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     5
struct
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     6
21190
08ec81dfc7fb (continued)
haftmann
parents: 21147
diff changeset
     7
datatype nat = Zero_nat | Suc of nat;
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     8
21190
08ec81dfc7fb (continued)
haftmann
parents: 21147
diff changeset
     9
end; (*struct Nat*)
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    10
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    11
structure Codegen = 
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    12
struct
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    13
22386
4ebe883b02ff new code theorems
haftmann
parents: 22188
diff changeset
    14
type 'a null = {null : 'a};
4ebe883b02ff new code theorems
haftmann
parents: 22188
diff changeset
    15
fun null (A_:'a null) = #null A_;
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    16
22188
a63889770d57 adjusted manual to improved treatment of overloaded constants
haftmann
parents: 21994
diff changeset
    17
fun head A_ (y :: xs) = y
a63889770d57 adjusted manual to improved treatment of overloaded constants
haftmann
parents: 21994
diff changeset
    18
  | head A_ [] = null A_;
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    19
22188
a63889770d57 adjusted manual to improved treatment of overloaded constants
haftmann
parents: 21994
diff changeset
    20
val null_option : 'a option = NONE;
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    21
22386
4ebe883b02ff new code theorems
haftmann
parents: 22188
diff changeset
    22
fun null_optiona () = {null = null_option} : ('b option) null;
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    23
21190
08ec81dfc7fb (continued)
haftmann
parents: 21147
diff changeset
    24
val dummy : Nat.nat option =
08ec81dfc7fb (continued)
haftmann
parents: 21147
diff changeset
    25
  head (null_optiona ()) [SOME (Nat.Suc Nat.Zero_nat), NONE];
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    26
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    27
end; (*struct Codegen*)
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    28
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    29
end; (*struct ROOT*)