Documentation

Lean.Compiler.LCNF.LambdaLifting

Context for the LiftM monad.

  • liftInstParamOnly : Bool

    If liftInstParamOnly is true, then only local functions that take local instances as parameters are lambda lifted.

  • suffix : Name

    Suffix for the new auxiliary declarations being created.

  • mainDecl : Decl Purity.pure

    Declaration where lambda lifting is being applied. We use it to provide the "base name" for auxiliary declarations and the flag safe.

  • inheritInlineAttrs : Bool

    If true, the lambda-lifted functions inherit the inline attribute from mainDecl. We use this feature to implement @[inline] instance ... and @[always_inline] instance ...

  • minSize : Nat

    Only local functions with size > minSize are lambda lifted. We use this feature to implement @[inline] instance ... and @[always_inline] instance ...

  • allowEtaContraction : Bool

    Allow for eta contraction instead of lifting to a lambda if possible.

Instances For

    State for the LiftM monad.

    • New auxiliary declarations

    • nextIdx : Nat

      Next index for generating auxiliary declaration name.

    Instances For
      @[reducible, inline]

      Monad for applying lambda lifting.

      Instances For

        Return true if the given declaration takes a local instance as a parameter. We lambda lift this kind of local function declaration before specialization.

        Instances For

          Return true if the given declaration should be lambda lifted.

          Instances For

            Create a new auxiliary declaration. The array closure contains all free variables occurring in decl.

            Instances For
              def Lean.Compiler.LCNF.Decl.lambdaLifting (decl : Decl Purity.pure) (liftInstParamOnly allowEtaContraction : Bool) (suffix : Name) (inheritInlineAttrs : Bool := false) (minSize : Nat := 0) :
              Instances For

                Eliminate all local function declarations.

                Instances For

                  During eager lambda lifting, we inspect declarations that are not inlineable or instances (doing it everywhere can accidentally introduce mutual recursion which the compiler cannot handle well at the moment). We then lift local function declarations that take local instances as parameters from their body to ensure they are specialized.

                  Instances For