doc-src/IsarAdvanced/Codegen/Thy/examples/Codegen.hs
author urbanc
Fri, 17 Nov 2006 17:32:30 +0100
changeset 21405 26b51f724fe6
parent 21189 5435ccdb4ea1
child 21993 4b802a9e0738
permissions -rw-r--r--
added an intro lemma for freshness of products; set up the simplifier so that it can deal with the compact and long notation for freshness constraints (FIXME: it should also be able to deal with the special case of freshness of atoms)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     1
module Codegen where
21189
5435ccdb4ea1 (continued)
haftmann
parents: 21147
diff changeset
     2
import qualified Nat
21147
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     3
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     4
class Null a where
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     5
  null :: a
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     6
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     7
head :: (Codegen.Null a_1) => [a_1] -> a_1
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     8
head (y : xs) = y
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
     9
head [] = Codegen.null
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    10
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    11
null_option :: Maybe b
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    12
null_option = Nothing
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    13
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    14
instance Codegen.Null (Maybe b) where
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    15
  null = Codegen.null_option
737a94f047e3 continued tutorial
haftmann
parents:
diff changeset
    16
21189
5435ccdb4ea1 (continued)
haftmann
parents: 21147
diff changeset
    17
dummy :: Maybe Nat.Nat
5435ccdb4ea1 (continued)
haftmann
parents: 21147
diff changeset
    18
dummy = Codegen.head [Just (Nat.Suc Nat.Zero_nat), Nothing]