src/HOL/BCV/JType.thy
author wenzelm
Fri, 01 Dec 2000 19:43:06 +0100
changeset 10569 e8346dad78e1
parent 9791 a39e5d43de55
permissions -rw-r--r--
ignore quick_and_dirty for coind;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
9791
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/BCV/JType.thy
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     2
    ID:         $Id$
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     3
    Author:     Tobias Nipkow
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     4
    Copyright   2000 TUM
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     5
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     6
The type system of the JVM
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     7
*)
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     8
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
     9
JType = Err +
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    10
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    11
types cname
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    12
arities cname :: term
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    13
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    14
types subclass = "(cname*cname)set"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    15
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    16
datatype ty = Void | Integer | NullT | Class cname
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    17
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    18
constdefs
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    19
 is_Class :: ty => bool
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    20
"is_Class T == case T of Void => False | Integer => False | NullT => False
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    21
               | Class C => True"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    22
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    23
 is_ref :: ty => bool
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    24
"is_ref T == T=NullT | is_Class T"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    25
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    26
 subtype :: subclass => ty ord
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    27
"subtype S T1 T2 ==
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    28
 (T1=T2) | T1=NullT & is_Class T2 |
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    29
 (? C D. T1 = Class C & T2 = Class D & (C,D) : S^*)"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    30
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    31
 sup :: "subclass => ty => ty => ty err"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    32
"sup S T1 T2 ==
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    33
 case T1 of Void => (case T2 of Void    => OK Void
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    34
                              | Integer => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    35
                              | NullT   => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    36
                              | Class D => Err)
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    37
          | Integer => (case T2 of Void    => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    38
                                 | Integer => OK Integer
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    39
                                 | NullT   => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    40
                                 | Class D => Err)
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    41
          | NullT => (case T2 of Void    => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    42
                               | Integer => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    43
                               | NullT   => OK NullT
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    44
                               | Class D => OK(Class D))
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    45
          | Class C => (case T2 of Void    => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    46
                                 | Integer => Err
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    47
                                 | NullT   => OK(Class C)
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    48
                                 | Class D => OK(Class(some_lub (S^*) C D)))"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    49
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    50
 Object :: cname
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    51
"Object == arbitrary"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    52
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    53
 is_type :: subclass => ty => bool
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    54
"is_type S T == case T of Void => True | Integer => True | NullT => True
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    55
                | Class C => (C,Object):S^*"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    56
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    57
syntax
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    58
 "types" :: subclass => ty set
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    59
 "@subty" :: ty => subclass => ty => bool  ("(_ /[='__ _)" [50, 1000, 51] 50)
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    60
translations
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    61
 "types S" == "Collect(is_type S)"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    62
 "x [=_S y"  == "x <=_(subtype S) y"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    63
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    64
constdefs
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    65
 esl :: "subclass => ty esl"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    66
"esl S == (types S, subtype S, sup S)"
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    67
a39e5d43de55 Completely new version of BCV
nipkow
parents:
diff changeset
    68
end