Getting into the Flow: Towards Better Type Error Messages for Constraint-Based Type Inference
Proceedings of the ACM on Programming Languages(2024)
摘要
Creating good type error messages for constraint-based type inference systems
is difficult. Typical type error messages reflect implementation details of the
underlying constraint-solving algorithms rather than the specific factors
leading to type mismatches. We propose using subtyping constraints that capture
data flow to classify and explain type errors. Our algorithm explains type
errors as faulty data flows, which programmers are already used to reasoning
about, and illustrates these data flows as sequences of relevant program
locations. We show that our ideas and algorithm are not limited to languages
with subtyping, as they can be readily integrated with Hindley-Milner type
inference. In addition to these core contributions, we present the results of a
user study to evaluate the quality of our messages compared to other
implementations. While the quantitative evaluation does not show that
flow-based messages improve the localization or understanding of the causes of
type errors, the qualitative evaluation suggests a real need and demand for
flow-based messages.
更多查看译文
关键词
type inference,better type error messages,constraint-based
AI 理解论文
溯源树
样例
生成溯源树,研究论文发展脉络
Chat Paper
正在生成论文摘要