Publication | Open Access
Scala step-by-step: soundness for DOT with step-indexed logical relations in Iris
15
Citations
36
References
2020
Year
EngineeringType TheoryStep-indexed Logical RelationsScala Step-by-stepGdot Type SystemSemanticsHigher-order LogicFormal VerificationSymbolic ComputationIris FrameworkComputational LogicNon-monotonic LogicDependently Typed ProgrammingCompilersProgramming LanguagesKnowledge RepresentationAbstract InterpretationComputer ScienceType SystemFunctional ProgrammingRelational QueriesAutomated ReasoningScala ExamplesFormal Methods
The metatheory of Scala’s core type system—the Dependent Object Types (DOT) calculus—is hard to extend, like the metatheory of other type systems combining subtyping and dependent types. Soundness of important Scala features therefore remains an open problem in theory and in practice. To address some of these problems, we use a semantics-first approach to develop a logical relations model for a new version of DOT, called guarded DOT (gDOT) . Our logical relations model makes use of an abstract form of step-indexing , as supported by the Iris framework, to model various forms of recursion in gDOT. To demonstrate the expressiveness of gDOT, we show that it handles Scala examples that could not be handled by previous versions of DOT, and prove using our logical relations model that gDOT provides the desired data abstraction. The gDOT type system, its semantic model, its soundness proofs, and all examples in the paper have been mechanized in Coq.
| Year | Citations | |
|---|---|---|
Page 1
Page 1