Subtyping:
- τ <: τ' means τ' is a higher security class than τ (e.g. L <: H)
- τ var <: τ' var if τ <: τ' (covariant)
- τ' cmd <: τ cmd if τ <: τ' (contravariant)
- Subtyping is reflexive (and transitive). All types are subtypes of themselves (τ <: τ)
Allows for more complex set of security classes (e.g. {H,L1,L2 | L1 <: H & L2 <: H}
data:image/s3,"s3://crabby-images/6877e/6877e8abb8462528ea3ba467c8940abcd848370f" alt="Previous page"
data:image/s3,"s3://crabby-images/ba461/ba4616a922d3fc7b5dbcf0e8eca2ad179b45ac87" alt="Contents"
data:image/s3,"s3://crabby-images/c191f/c191f63aaa1eaaf5deb3984604245cc37518a2a2" alt="Next page"