Lake's Environment #
Definitions related to a Lake environment. A Lake environment is computed on Lake's startup from user-specified CLI options and the process environment.
A Lake environment.
- lake : LakeInstallThe Lake installation of the environment. 
- lean : LeanInstallThe Lean installation of the environment. 
- elan? : Option ElanInstallThe Elan installation (if any) of the environment. 
- reservoirApiUrl : StringThe Reservoir API endpoint URL (e.g., https://reservoir.lean-lang.org/api/v1).
- githashOverride : StringOverrides the detected Lean's githash as the string Lake uses for Lean traces. 
- pkgUrlMap : Lean.NameMap StringA name-to-URL mapping of URL overrides for the named packages. 
- noCache : BoolWhether to disable downloading build caches for packages. Set via LAKE_NO_CACHE. Can be overridden on a per-command basis with--try-cache.
- enableArtifactCache : BoolWhether the Lake artifact cache should be enabled by default (i.e., LAKE_ARTIFACT_CACHE).
- noSystemCache : BoolWhether the system cache has been disabled ( LAKE_CACHE_DIRis set but empty).
- The directory for the Lake cache. Customized by - LAKE_CACHE_DIR.- If - none, no suitable system directory for the cache exists.
- The directory for the Lake cache. Customized by - LAKE_CACHE_DIR.- Unlike - lakeCache?, this excludes the toolchain directory from consideration.- If - none, no suitable system directory for the cache exists.
- The authentication key for cache uploads (i.e., - LAKE_CACHE_KEY).
- The base URL for artifact uploads and downloads from the cache (i.e., - LAKE_CACHE_ARTIFACT_ENDPOINT).
- The base URL for revision uploads and downloads from the cache (i.e., - LAKE_CACHE_REVISION_ENDPOINT).
- initLeanPath : System.SearchPathThe initial Lean library search path of the environment (i.e., LEAN_PATH).
- initLeanSrcPath : System.SearchPathThe initial Lean source search path of the environment (i.e., LEAN_SRC_PATH).
- initPath : System.SearchPathThe initial binary search path of the environment (i.e., PATH).
- toolchain : StringThe preferred toolchain of the environment. May be empty. Either ELAN_TOOLCHAINor, if none, Lake'sLean.toolchain.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lake.instInhabitedEnv = { default := Lake.instInhabitedEnv.default }
Returns the home directory of the current user (if possible).
Equations
- One or more equations did not get rendered due to their size.
Instances For
Returns the system directory that can be used to store caches (if one exists).
Equations
- One or more equations did not get rendered due to their size.
Instances For
Compute the Lean toolchain string used by Lake from the process environment.
Equations
- Lake.Env.computeToolchain = do let __do_lift ← IO.getEnv "ELAN_TOOLCHAIN" pure (__do_lift.getD Lean.toolchain)
Instances For
Compute the system cache location from the process environment.
If none, no system directory for workspace the cache exists.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Compute a Lake.Env object from the given installs
and the set environment variables.
Equations
- One or more equations did not get rendered due to their size.
Instances For
The string Lake uses to identify Lean in traces.
Either the environment-specified LEAN_GITHASH or the detected Lean's githash.
The override allows one to replace the Lean version used by a library (e.g., Mathlib) without completely rebuilding it, which is useful for testing custom builds of Lean.
Equations
- env.leanGithash = if env.githashOverride.isEmpty = true then env.lean.githash else env.githashOverride
Instances For
The binary search path of the environment (i.e., PATH).
Combines the initial path of the environment with that of the Lake installation.
Equations
Instances For
The Lean library search path of the environment (i.e., LEAN_PATH).
Combines the initial path of the environment with that of the Lake installation.
Instances For
The Lean source search path of the environment (i.e., LEAN_SRC_PATH).
Combines the initial path of the environment with that of the Lake and Lean
installations.
Equations
- env.leanSrcPath = env.lake.srcDir :: env.initLeanSrcPath
Instances For
The default search path the Lake executable uses when interpreting package configuration files.
In order to use the Lean stdlib (e.g., Init),
the executable needs the search path to include the directory
with the stdlib's .olean files (e.g., from <lean-sysroot>/lib/lean).
In order to use Lake's modules as well, the search path also
needs to include Lake's .olean files (e.g., from build).
While this can be done by having the user augment LEAN_PATH with
the necessary directories, Lake also intelligently augments the initial
search path with the .olean directories of the provided Lean and Lake
installations.
See findInstall? for more information on how Lake determines those
directories. If everything is configured as expected, the user will not
need to augment LEAN_PATH. Otherwise, they will need to provide Lake
with more information (either through LEAN_PATH or through other options).
Equations
- env.leanSearchPath = env.lake.libDir :: env.lean.leanLibDir :: env.leanPath