We present Turnstile+, a high-level, macros-based metaDSL for building dependently typed languages.
With it, programmers may rapidly prototype and iterate on the design of new dependently typed features and extensions.
Or they may create entirely new DSLs whose dependent type “power” is tailored to a specific domain.
Our framework’s support of language-oriented programming also makes it suitable for experimenting with systems of interacting components, e.g., a proof assistant and its companion DSLs.
This paper explains the implementation details of Turnstile+, as well as how it may be used to create a wide-variety of dependently typed languages, from a lightweight one with indexed types, to a full spectrum proof assistant, complete with a tactic system and extensions for features like sized types and SMT interaction.
Dependent Type Systems as Macros (slides) (2020-01-23 POPL.pdf) | 563KiB |
Thu 23 JanDisplayed time zone: Saskatchewan, Central America change
14:00 - 15:05 | Type SystemsResearch Papers at Ile de France II (IDF II) Chair(s): Peter Thiemann University of Freiburg, Germany | ||
14:00 21mTalk | Undecidability of D<: and Its Decidable FragmentsDistinguished Paper Research Papers Link to publication DOI Media Attached File Attached | ||
14:21 21mTalk | Decidable Subtyping for Path Dependent Types Research Papers Julian Mackay Victoria University of Wellington, Alex Potanin Victoria University of Wellington, Jonathan Aldrich Carnegie Mellon University, Lindsay Groves Victoria University of Wellington Link to publication DOI Media Attached | ||
14:43 21mTalk | Dependent Type Systems as Macros Research Papers Stephen Chang Northeastern University, Michael Ballantyne PLT @ Northeastern University, Milo Turner PLT @ Northeastern University, William J. Bowman University of British Columbia Link to publication DOI Media Attached File Attached |