Title
Document Type
Book Chapter
Publication Title
Programming Languages and Systems: 25th European Symposium on Programming, ESOP 2016, Held as Part of the European Joint Conferences on Theory and Practice of Software, ETAPS 2016, Eindhoven, The Netherlands, April 2-8, 2016, Proceedings
Version
Author's Final Manuscript
Volume
9632
Publication Date
2016
Abstract
The Hindley-Milner HM type system automatically infers the types at which polymorphic functions are used. In HM, the inferred types are unambiguous, and every expression has a principal type. Type annotations make HM compatible with extensions where complete type inference is impossible, such as higher-rank polymorphism and type-level functions. However, programmers cannot use annotations to explicitly provide type arguments to polymorphic functions, as HM requires type instantiations to be inferred.
We describe an extension to HM that allows visible type application. Our extension requires a novel type inference algorithm, yet its declarative presentation is a simple extension to HM. We prove that our extended system is a conservative extension of HM and admits principal types. We then extend our approach to a higher-rank type system with bidirectional type-checking. We have implemented this system in the Glasgow Haskell Compiler and show how our approach scales in the presence of complex type system features.
Publisher's Statement
The final publication is available at Springer via http://dx.doi.org/10.1007/978-3-662-49498-1_10.
DOI
http://link.springer.com/chapter/10.1007%2F978-3-662-49498-1_10
Citation
Richard A. Eisenberg, Stephanie Weirich, and Hamidhasan Ahmed, "Visible Type Application," in Programming Languages and Systems: 25th European Symposium on Programming, ESOP 2016, Held as Part of the European Joint Conferences on Theory and Practice of Software, ETAPS 2016, Eindhoven, The Netherlands, April 2-8, 2016, Proceedings, ed. Peter Thiemann (Berlin, Heidelberg: Springer Berlin Heidelberg, 2015) 229-254. (Chicago: University of Chicago Press, 2010), 77.