Type-Safe Code Transformations in Haskell

被引:3
|
作者
Guillemette, Louis-Julien [1 ]
Monnier, Stefan [1 ]
机构
[1] Univ Montreal, Dept Informat & Rech Operat, Montreal, PQ, Canada
关键词
compilation; program verification; type systems; higher-order abstract syntax;
D O I
10.1016/j.entcs.2006.10.036
中图分类号
TP301 [理论、方法];
学科分类号
081202 ;
摘要
The use of typed intermediate languages can significantly increase the reliability of a compiler. By type-checking the code produced at each transformation stage, one can identify bugs in the compiler that would otherwise be much harder to find. We propose to take the use of types in compilation a step further by verifying that the transformation itself is type correct, in the sense that it is impossible that it produces an ill typed term given a well typed term as input. We base our approach on higher-order abstract syntax (HOAS), a representation of programs where variables in the object language are represented by meta-variables. We use a representation that accounts for the object language's type system using generalized algebraic data types (GADTs). In this way, the full binding and type structure of the object language is exposed to the host language's type system. In this setting we encode a type preservation property of a CPS conversion in Haskell's type system, using witnesses of a type correctness proof encoded in a GADT.
引用
收藏
页码:23 / 39
页数:17
相关论文
共 50 条
  • [31] Type-safe dynamic update transaction
    Zhang, Shi
    Huang, LinPeng
    [J]. COMPSAC 2007: THE THIRTY-FIRST ANNUAL INTERNATIONAL COMPUTER SOFTWARE AND APPLICATIONS CONFERENCE, VOL II, PROCEEDINGS, 2007, : 335 - +
  • [32] Type-Safe Diff for Families of Datatypes
    Lempsink, Eelco
    Leather, Sean
    Loh, Andres
    [J]. WGP'09: PROCEEDINGS OF THE 2009 ACM SIGPLAN WORKSHOP ON GENERIC PROGRAMMING, 2009, : 61 - 72
  • [33] A PROPOSAL FOR MAKING EIFFEL TYPE-SAFE
    COOK, WR
    [J]. COMPUTER JOURNAL, 1989, 32 (04): : 305 - 311
  • [34] Generate and Offshore: Type-Safe and Modular Code Generation for Low-Level Optimization
    Takashima, Naoki
    Sakamoto, Hiroki
    Kameyama, Yukiyoshi
    [J]. FHPC'15 PROCEEDINGS OF THE 4TH ACM SIGPLAN WORKSHOP ON FUNCTIONAL HIGH-PERFORMANCE COMPUTING, 2015, : 45 - 53
  • [35] Type-safe Quantum Programming in Idris
    Dandy, Liliane-Joy
    Jeandel, Emmanuel
    Zamdzhiev, Vladimir
    [J]. PROGRAMMING LANGUAGES AND SYSTEMS, ESOP 2023, 2023, 13990 : 507 - 534
  • [36] A Type-Safe Embedding of XDuce into ML
    Sulzmann, Martin
    Lu, Kenny Zhuo Ming
    [J]. ELECTRONIC NOTES IN THEORETICAL COMPUTER SCIENCE, 2006, 148 (02) : 239 - 264
  • [37] Type-safe optimisation of plugin architectures
    Glew, N
    Palsberg, J
    Grothoff, C
    [J]. STATIC ANALYSIS, PROCEEDINGS, 2005, 3672 : 135 - 154
  • [38] Type-safe runtime class upgrades in Creol
    Yu, Ingrid Chieh
    Johnsen, Einar Broch
    Owe, Olaf
    [J]. FORMAL METHODS FOR OPEN OBJECT-BASED DISTRIBUTED SYSTEMS, 2006, 4037 : 202 - 217
  • [39] Type-safe trading proxies using TORBA
    Marvie, R
    Merle, P
    Geib, JM
    Leblane, S
    [J]. 5TH INTERNATIONAL SYMPOSIUM ON AUTONOMOUS DECENTRALIZED SYSTEMS, PROCEEDINGS, 2001, : 303 - 310
  • [40] Squid: Type-Safe, Hygienic, and Reusable Quasiquotes
    Parreaux, Lionel
    Shaikhha, Amir
    Koch, Christoph E.
    [J]. SCALA'17: PROCEEDINGS OF THE 8TH ACM SIGPLAN INTERNATIONAL SYMPOSIUM ON SCALA, 2017, : 56 - 66