Dependent Types for JavaScript

Ravi Chugh, David Herman, and Ranjit Jhala
OOPSLA 2012 [ papertech report (arxiv)slides (pdf)system d ]
STOP 2012 [ status reportslides (pdf) ]
Draft 2011 [ paper (arxiv) ]

We present Dependent JavaScript (DJS), a statically typed dialect of the imperative, object-oriented, dynamic language. DJS supports the particularly challenging features such as run-time type-tests, higher-order functions, extensible objects, prototype inheritance, and arrays through a combination of nested refinement types, strong updates to the heap, and heap unrolling to precisely track prototype hierarchies. With our implementation of DJS, we demonstrate that the type system is expressive enough to reason about a variety of tricky idioms found in small examples drawn from several sources, including the popular book JavaScript: The Good Parts and the SunSpider benchmark suite.