Currently (as of August 2020) Rakudo does not typecheck the return values of functions at compile time; that is, it does not provide static guarantees that functions satisfy their return constraints. Concretely, the following two functions both compile as Raku:
sub get-int(--> Int) { 'bug' }
sub get-int($a --> Int) {
when $a == 5 { 'Rare bug' }
default { 42 }
}
I have two related questions:
Is there any way to know what (if any) typechecking currently takes place at compile time? (Either via a list someone has written, somewhere in the docs, or a central place in the Rakudo source) Or is it more ad hoc than that?
Is this lack of compile time typechecking an intentional design decision? Or is adding more static typechecking something that would be nice to have one day, but just hasn't yet been implemented?
(I'm familiar with Johnathan's great answer to The performance penalties for types/constraints in Raku?, which states that "Raku mandates that type constraints written into the program are enforced at runtime at latest." That answer describes various ways to avoid run-time costs of typechecks, but doesn't describe what, if any, typechecks are done at compile time (which would certainly avoid runtime costs!).)
Currently very little checking of types is done at compile time; that which is mostly takes place as a side-effect of the static optimizer. The checks today are largely about subroutine calls, where:
This is a leftover from when the static optimizer did more inlining work. These days, it only inlines native operators at compile time, and leaves the rest for the VM's dynamic optimizer, which is vastly more capable at inlining and can also uninline (permitting speculative optimization, but also meaning original stack traces can be recovered, whereas the static optimizer lost this information).
Doing more at compile time is considered desirable, however there are some practical issues to consider.
Once the current compiler frontend overhaul is complete, more compile-time checks being introduced (but only enabled from the next language version) seems quite likely - at least, so long as somebody works on it.
However, there's an even more exciting opportunity coming up in this area: since there will be an API to Raku programs, and with plans coming together for custom compiler passes, it will also soon be possible to implement type checkers as modules! Some of those may lead to checks that make it into future Raku language versions. Others may be quite domain-specific and aimed at enabling more correct use of a given module. Others may enforce rigors that are not in the spirit of the base language, but that some language users might wish to opt in to.