Documentation

Lake.Build.Info

Build Info #

This module defines the Lake build info type and related utilities. Build info is what is the data passed to a Lake build function to facilitate the build.

inductive Lake.BuildInfo :

The type of Lake's build info.

Build Info & Keys #

Build Key Helper Constructors #

@[reducible, inline]
Equations
@[reducible, inline]
Equations
@[reducible, inline]
Equations
@[reducible, inline]
Equations

Build Info to Key #

Instances for deducing data types of BuildInfo keys #

Build Info & Facets #

Complex Builtin Facet Declarations #

Additional builtin facets missing from Build.Facets. These are defined here because they need configuration definitions (e.g., Module), whereas the facets there are needed by the configuration definitions.

@[reducible, inline]

The direct local imports of the Lean module.

Equations
@[reducible, inline]

The transitive local imports of the Lean module.

Equations
@[reducible, inline]

The transitive local imports of the Lean module.

Equations
@[reducible, inline]

Shared library for --load-dynlib.

Equations
@[reducible, inline]

A Lean library's Lean modules.

Equations
@[reducible, inline]

The package's array of dependencies.

Equations
@[reducible, inline]

The package's complete array of transitive dependencies.

Equations

Facet Build Info Helper Constructors #

Definitions to easily construct BuildInfo values for module, package, and target facets.

@[reducible, inline]
abbrev Lake.Module.facet (facet : Lean.Name) (self : Module) :

Build info for the module's specified facet.

Equations
@[reducible, inline]

The direct local imports of the Lean module.

Equations
@[reducible, inline]

The transitive local imports of the Lean module.

Equations
@[reducible, inline]

The transitive local imports of the Lean module.

Equations
@[reducible, inline]

The facet which builds all of a module's dependencies (i.e., transitive local imports and --load-dynlib shared libraries). Returns the list of shared libraries to load along with their search path.

Equations
@[reducible, inline]

The core build facet of a Lean file. Elaborates the Lean file via lean and produces all the Lean artifacts of the module (i.e., olean, ilean, c). Its trace just includes its dependencies.

Equations
@[reducible, inline]

The olean file produced by lean.

Equations
@[reducible, inline]

The ilean file produced by lean.

Equations
@[reducible, inline]
abbrev Lake.Module.c (self : Module) :

The C file built from the Lean file via lean.

Equations
@[reducible, inline]

The C file built from the Lean file via lean.

Equations
@[reducible, inline]
abbrev Lake.Module.o (self : Module) :

The object file built from c/bc. On Windows with the C backend, no Lean symbols are exported. On every other configuration, symbols are exported.

Equations
@[reducible, inline]

The object file built from c/bc (with Lean symbols exported).

Equations
@[reducible, inline]

The object file built from c/bc (without Lean symbols exported).

Equations
@[reducible, inline]

The object file .c.o built from c. On Windows, this is c.o.noexport, on other systems it is c.o.export).

Equations
@[reducible, inline]

The object file .c.o.export built from c (with -DLEAN_EXPORTING).

Equations
@[reducible, inline]

The object file .c.o.noexport built from c (without -DLEAN_EXPORTING).

Equations
@[reducible, inline]

The object file .bc.o built from bc.

Equations
@[reducible, inline]

Shared library for --load-dynlib.

Equations
@[reducible, inline]
abbrev Lake.Package.facet (facet : Lean.Name) (self : Package) :

Build info for the package's specified facet.

Equations
@[reducible, inline]

A package's cached build archive (e.g., from Reservoir or GitHub). Will cause the whole build to fail if the archive cannot be fetched.

Equations
@[reducible, inline]

A package's optional cached build archive (e.g., from Reservoir or GitHub). Will NOT cause the whole build to fail if the archive cannot be fetched.

Equations
@[reducible, inline]

A package's Reservoir build archive from Reservoir. Will cause the whole build to fail if the barrel cannot be fetched.

Equations
@[reducible, inline]

A package's optional build archive from Reservoir. Will NOT cause the whole build to fail if the barrel cannot be fetched.

Equations
@[reducible, inline]

A package's build archive from a GitHub release. Will cause the whole build to fail if the release cannot be fetched.

Equations
@[reducible, inline]

A package's optional build archive from a GitHub release. Will NOT cause the whole build to fail if the release cannot be fetched.

Equations
@[reducible, inline, deprecated Lake.Package.gitHubRelease (since := "2024-09-27")]
Equations
@[reducible, inline, deprecated Lake.Package.optGitHubRelease (since := "2024-09-27")]
Equations
@[reducible, inline]

A package's extraDepTargets mixed with its transitive dependencies'.

Equations
@[reducible, inline]

The package's array of dependencies.

Equations
@[reducible, inline]

The package's complete array of transitive dependencies.

Equations
@[reducible, inline]
abbrev Lake.Package.target (target : Lean.Name) (self : Package) :

Build info for a custom package target.

Equations
@[reducible, inline]
abbrev Lake.LeanLib.facet (self : LeanLib) (facet : Lean.Name) :

Build info of the Lean library's Lean binaries.

Equations
@[reducible, inline]

A Lean library's Lean modules.

Equations
@[reducible, inline]

A Lean library's Lean artifacts (i.e., olean, ilean, c).

Equations
@[reducible, inline]

A Lean library's static artifact.

Equations
@[reducible, inline]

A Lean library's static artifact (with exported symbols).

Equations
@[reducible, inline]

A Lean library's shared artifact.

Equations
@[reducible, inline]

A Lean library's extraDepTargets mixed with its package's.

Equations
@[reducible, inline]

Build info of the Lean executable.

Equations
@[reducible, inline]

Build info of the external library's static binary.

Equations
@[reducible, inline]

Build info of the external library's shared binary.

Equations
@[reducible, inline]

Build info of the external library's dynlib.

Equations