Warning
This program is experimental and its interface is subject to change.
Name
nix registry pin - pin a flake to its current version or to the current version of a flake URL
Synopsis
nix registry pin [option...] url locked
Examples
- 
Pin nixpkgsto its most recent Git revision:# nix registry pin nixpkgsAfterwards the user registry will have an entry like this: nix registry list | grep '^user ' user flake:nixpkgs github:NixOS/nixpkgs/925b70cd964ceaedee26fde9b19cc4c4f081196aand nix flake metadatawill say:# nix flake metadata nixpkgs Resolved URL: github:NixOS/nixpkgs/925b70cd964ceaedee26fde9b19cc4c4f081196a Locked URL: github:NixOS/nixpkgs/925b70cd964ceaedee26fde9b19cc4c4f081196a …
- 
Pin nixpkgsin a custom registry to its most recent Git revision:# nix registry pin --registry ./custom-flake-registry.json nixpkgs
Description
This command adds an entry to the user registry that maps flake reference url to the corresponding locked flake reference, that is, a flake reference that specifies an exact revision or content hash. This ensures that until this registry entry is removed, all uses of url will resolve to exactly the same flake.
Entries can be removed using nix registry remove.
Options
- 
--registryregistryThe registry to operate on. 
Common evaluation options
- 
--argname exprPass the value expr as the argument name to Nix functions. 
- 
--arg-from-filename pathPass the contents of file path as the argument name to Nix functions. 
- 
--arg-from-stdinnamePass the contents of stdin as the argument name to Nix functions. 
- 
--argstrname stringPass the string string as the argument name to Nix functions. 
- 
Start an interactive environment if evaluation fails. 
- 
--eval-storestore-urlThe URL of the Nix store to use for evaluation, i.e. to store derivations ( .drvfiles) and inputs referenced by them.
- 
Allow access to mutable paths and repositories. 
- 
--include/-IpathAdd path to search path entries used to resolve lookup paths This option may be given multiple times. Paths added through -Itake precedence over thenix-pathconfiguration setting and theNIX_PATHenvironment variable.
- 
--override-flakeoriginal-ref resolved-refOverride the flake registries, redirecting original-ref to resolved-ref. 
Logging-related options
- 
Set the logging verbosity level to 'debug'. 
- 
--log-formatformatSet the format of log output; one of raw,internal-json,barorbar-with-logs.
- 
--print-build-logs/-LPrint full build logs on standard error. 
- 
Decrease the logging verbosity level. 
- 
--verbose/-vIncrease the logging verbosity level. 
Miscellaneous global options
- 
Show usage information. 
- 
Disable substituters and consider all previously downloaded files up-to-date. 
- 
--optionname valueSet the Nix configuration setting name to value (overriding nix.conf).
- 
Consider all previously downloaded files out-of-date. 
- 
During evaluation, rewrite missing or corrupted files in the Nix store. During building, rebuild missing or corrupted store paths. 
- 
Show version information. 
Note
See
man nix.conffor overriding configuration settings with command line flags.