Useless is an optimization pass for the SSA IntermediateLanguage, invoked from SSASimplify.

Description

This pass:

  • removes components of tuples that are constants (use unification)

  • removes function arguments that are constants

  • builds some kind of dependence graph where

    • a value of ground type is useful if it is an arg to a primitive

    • a tuple is useful if it contains a useful component

    • a constructor is useful if it contains a useful component or is used in a Case transfer

If a useful tuple is coerced to another useful tuple, then all of their components must agree (exactly). It is trivial to convert a useful value to a useless one.

Implementation

Details and Notes

It is also trivial to convert a useful tuple to one of its useful components — but this seems hard.

Suppose that you have a ref/array/vector that is useful, but the components aren’t — then the components are converted to type unit, and any primitive args must be as well.

Unify all handler arguments so that raise/handle has a consistent calling convention.