Responding to referee comments on the HATRA 23 paper (#1014)

This commit is contained in:
Alan Jeffrey 2023-08-21 14:21:10 -05:00 committed by GitHub
parent e25b0a6275
commit d5e37ab367
Signed by: DevComp
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 7 deletions

Binary file not shown.

View file

@ -12,6 +12,7 @@
\newcommand{\ANY}{\mathtt{any}} \newcommand{\ANY}{\mathtt{any}}
\newcommand{\ERROR}{\mathtt{error}} \newcommand{\ERROR}{\mathtt{error}}
\newcommand{\NUMBER}{\mathtt{number}}
\begin{document} \begin{document}
@ -58,9 +59,9 @@ quality concerns of more experienced developers; for all users
type-driven tooling is important for productivity. These needs result in a design with two modes: type-driven tooling is important for productivity. These needs result in a design with two modes:
\begin{itemize} \begin{itemize}
\item \emph{non-strict mode}, aimed at non-professionals, focused on \item \emph{non-strict mode}, aimed at non-professionals, focused on
minimizing false positives, and minimizing false positives (that is, in non-strict mode, any program with a type error has a defect), and
\item \emph{strict mode}, aimed at professionals, focused on \item \emph{strict mode}, aimed at professionals, focused on
minimizing false negatives (i.e.~type soundness). minimizing false negatives (that is, in strict mode, any program with a defect has a type error).
\end{itemize} \end{itemize}
%% For both communities, type-driven tooling is important, so we %% For both communities, type-driven tooling is important, so we
%% provide \emph{infallible type inference}, which infers types %% provide \emph{infallible type inference}, which infers types
@ -81,9 +82,24 @@ inclusion~\cite{GF05:GentleIntroduction}. This is aligned with the
\emph{minimize false positives} goal of Luau non-strict mode, since \emph{minimize false positives} goal of Luau non-strict mode, since
semantic subtyping only reports a failure of subtyping when there is a semantic subtyping only reports a failure of subtyping when there is a
value which inhabits the candidate subtype, but not the candidate value which inhabits the candidate subtype, but not the candidate
supertype. This has the added benefit of improving error reporting in supertype.
the prototype implementation: since the prototype is constructive, the For example, the program:
witness for the failure of subtyping can help drive error reports. \begin{verbatim}
local x : CFrame = CFrame.new()
local y : Vector3 | CFrame
if math.random() < 0.5 then y = CFrame.new() else y = Vector3.new() end
local z : Vector3 | CFrame = x * y
\end{verbatim}
cannot produce a run-time error, since multiplication of \verb|CFrame|s is overloaded:
\begin{verbatim}
((CFrame, CFrame) -> CFrame) & ((CFrame, Vector3) -> Vector3)
\end{verbatim}
In order to typecheck this program, we check that that type is a subtype of:
\begin{verbatim}
(CFrame, Vector3 | CFrame) -> (Vector3 | CFrame)
\end{verbatim}
In the previous, syntax-driven, implementation of subtyping, this subtype check would fail, resulting in a false positive.
We have now released an implementation of semantic subtyping, which does not suffer from this defect.
See our technical blog for more details~\cite{Jef22:SemanticSubtyping}. See our technical blog for more details~\cite{Jef22:SemanticSubtyping}.
Rather than the gradual typing approach Rather than the gradual typing approach
@ -94,8 +110,30 @@ an error-suppressing type, and any failures of subtyping involving
error-suppressing types are not reported. Users can explicitly error-suppressing types are not reported. Users can explicitly
suppress type errors by declaring variables with type $\ANY$, and suppress type errors by declaring variables with type $\ANY$, and
since an expression with a type error has an error-suppressing type we since an expression with a type error has an error-suppressing type we
avoid cascading errors. Error suppression is in production Luau, and is avoid cascading errors.
mechanically verified~\cite{BJ23:agda-typeck}.
We do this by defining a \emph{infallible} typing judgment $\Gamma \vdash M : T$
such that for any $\Gamma$ and $M$, there is a $T$ such that $\Gamma \vdash M : T$.
For example the rule for addition (ignoring overloads for simplicity) is:
\[
\frac{\Gamma \vdash M : T \quad \Gamma \vdash M : U}{\Gamma \vdash M+N : \NUMBER}
\]
We define which judgments produce warnings, for example that rule produces a warning
when
\begin{itemize}
\item either $T \not<: \NUMBER$ and $T$ is not error-suppressing,
\item or $U \not<: \NUMBER$ and $U$ is not error-suppressing.
\end{itemize}
To retain type soundness (in the absence of user-supplied error-suppressing types)
we show that
if $\Gamma \vdash M : T$ and $T$ is error-suppressing, then either
\begin{itemize}
\item $\Gamma$ or $M$ contains an error-suppressing type, or
\item $\Gamma \vdash M : T$ produces a warning.
\end{itemize}
From this it is straightforward to show the usual ``well typed
programs don't go wrong'' type soundness result for programs without explicit
error-suppressing types~\cite{BJ23:agda-typeck}.
\section{Further work} \section{Further work}