Hostname: page-component-77f85d65b8-lfk5g Total loading time: 0 Render date: 2026-04-18T15:39:32.976Z Has data issue: false hasContentIssue false

Hoare type theory, polymorphism and separation1

Published online by Cambridge University Press:  02 September 2008

ALEKSANDAR NANEVSKI
Affiliation:
Harvard University, Cambridge, MA, USA (e-mail: aleks@eecs.harvard.edu, greg@eecs.harvard.edu)
GREG MORRISETT
Affiliation:
Harvard University, Cambridge, MA, USA (e-mail: aleks@eecs.harvard.edu, greg@eecs.harvard.edu)
LARS BIRKEDAL
Affiliation:
IT University of Copenhagen, Copenhagen, Denmark (e-mail: birkedal@itu.dk)
Rights & Permissions [Opens in a new window]

Abstract

Core share and HTML view are not available for this content. However, as you have access to this content, a full PDF is available via the 'Save PDF' action button.

We consider the problem of reconciling a dependently typed functional language with imperative features such as mutable higher-order state, pointer aliasing, and nontermination. We propose Hoare type theory (HTT), which incorporates Hoare-style specifications into types, making it possible to statically track and enforce correct use of side effects.

The main feature of HTT is the Hoare type {P}x:A{Q} specifying computations with precondition P and postcondition Q that return a result of type A. Hoare types can be nested, combined with other types, and abstracted, leading to a smooth integration with higher-order functions and type polymorphism.

We further show that in the presence of type polymorphism, it becomes possible to interpret the Hoare types in the “small footprint” manner, as advocated by separation logic, whereby specifications tightly describe the state required by the computation.

We establish that HTT is sound and compositional, in the sense that separate verifications of individual program components suffice to ensure the correctness of the composite program.

Information

Type
Articles
Copyright
Copyright © Cambridge University Press 2008
Submit a response

Discussions

No Discussions have been published for this article.