Documentation

Lake.Config.LeanLib

@[reducible, inline]

A Lean library -- its package plus its configuration.

Equations
Instances For
@[inline]

The Lean libraries of the package (as an Array).

Equations
@[inline]

Try to find a Lean library in the package with the given name.

Equations
@[inline]

The library's user-defined configuration.

Equations
@[inline]

The package's srcDir joined with the library's srcDir.

Equations
@[inline]

The library's root directory for lean (i.e., srcDir).

Equations
@[inline]

The names of the library's root modules (i.e., the library's roots configuration).

Equations
@[inline]

Whether the given module is considered local to the library.

Equations
@[inline]

Whether the given module is a buildable part of the library.

Equations
@[inline]

The name of the library artifact.

Equations
@[inline]

The file name of the library's static binary (i.e., its .a)

Equations
@[inline]

The path to the static library in the package's libDir.

Equations
@[inline]

The path to the static library (with exported symbols) in the package's libDir.

Equations
@[inline]

The file name of the library's shared binary (i.e., its dll, dylib, or so) .

Equations
@[inline]

The path to the shared library in the package's libDir.

Equations
@[inline]

The library's extraDepTargets configuration.

Equations
@[inline]

Whether to precompile the library's modules. Is true if either the package or the library have precompileModules set.

Equations
@[inline]

Whether to the library's Lean code is platform-independent. Returns the library's platformIndependent configuration if non-none. Otherwise, falls back to the package's.

Equations
@[inline]

The library's defaultFacets configuration.

Equations
@[inline]

The library's nativeFacets configuration.

Equations
@[inline]

The build type for modules of this library. That is, the minimum of package's buildType and the library's buildType.

Equations
@[inline]

The arguments to pass to lean --server when running the Lean language server. serverOptions is the accumulation of:

  • the build type's leanOptions
  • the package's leanOptions
  • the package's moreServerOptions
  • the library's leanOptions
  • the library's moreServerOptions
Equations
@[inline]

The backend type for modules of this library. Prefer the library's backend configuration, then the package's, then the default (which is C for now).

Equations
@[inline]

The dynamic libraries to load for modules of this library. The targets of the package plus the targets of the library (in that order).

Equations
@[inline]

The Lean plugins for modules of this library. The targets of the package plus the targets of the library (in that order).

Equations
@[inline]

The arguments to pass to lean when compiling the library's Lean files. leanArgs is the accumulation of:

  • the build type's leanArgs
  • the package's leanOptions
  • the package's moreLeanArgs
  • the library's leanOptions
  • the library's moreLeanArgs
Equations
@[inline]

The arguments to weakly pass to lean when compiling the library's Lean files. That is, the package's weakLeanArgs plus the library's weakLeanArgs.

Equations
@[inline]

The arguments to pass to leanc when compiling the library's Lean-produced C files. That is, the build type's leancArgs, the package's moreLeancArgs, and then the library's moreLeancArgs.

Equations
@[inline]

The arguments to weakly pass to leanc when compiling the library's Lean-produced C files. That is, the package's weakLeancArgs plus the library's weakLeancArgs.

Equations
@[inline]

Additionl target objects to pass to ar when linking the static library. That is, the package's moreLinkObjs plus the library's moreLinkObjs.

Equations
@[inline]

The arguments to pass to leanc when linking the shared library. That is, the package's moreLinkArgs plus the library's moreLinkArgs.

Equations
@[inline]

The arguments to weakly pass to leanc when linking the shared library. That is, the package's weakLinkArgs plus the library's weakLinkArgs.

Equations