Dependent types for JavaScript

Ravi Chugh,David Herman,Ranjit Jhala
DOI: https://doi.org/10.1145/2398857.2384659
2012-11-15
ACM SIGPLAN Notices
Abstract: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.
What problem does this paper attempt to address?