|
Nix 2.93.3
Lix: A modern, delicious implementation of the Nix package manager; unstable internal interfaces
|
Classes | |
| struct | PathInfoCacheValue |
| struct | State |
| struct | AssociatedCredentials |
| struct | Stats |
Public Types | |
| using | PathsSource |
Public Member Functions | |
| virtual std::optional< AssociatedCredentials > | associatedCredentials () const |
| virtual kj::Promise< Result< void > > | init () |
| virtual StoreConfig & | config ()=0 |
| virtual const StoreConfig & | config () const =0 |
| virtual std::string | getUri ()=0 |
| StorePath | parseStorePath (std::string_view path) const |
| std::optional< StorePath > | maybeParseStorePath (std::string_view path) const |
| std::string | printStorePath (const StorePath &path) const |
| StorePathSet | parseStorePathSet (const PathSet &paths) const |
| PathSet | printStorePathSet (const StorePathSet &path) const |
| std::string | showPaths (const StorePathSet &paths) |
| bool | isInStore (PathView path) const |
| bool | isStorePath (std::string_view path) const |
| std::pair< StorePath, Path > | toStorePath (PathView path) const |
| Path | followLinksToStore (std::string_view path) const |
| StorePath | followLinksToStorePath (std::string_view path) const |
| StorePath | makeStorePath (std::string_view type, std::string_view hash, std::string_view name) const |
| StorePath | makeStorePath (std::string_view type, const Hash &hash, std::string_view name) const |
| StorePath | makeOutputPath (std::string_view id, const Hash &hash, std::string_view name) const |
| StorePath | makeFixedOutputPath (std::string_view name, const FixedOutputInfo &info) const |
| StorePath | makeTextPath (std::string_view name, const TextInfo &info) const |
| StorePath | makeFixedOutputPathFromCA (std::string_view name, const ContentAddressWithReferences &ca) const |
| StorePath | computeStorePathForPathRecursive (std::string_view name, const PreparedDump &source) const |
| StorePath | computeStorePathForPathFlat (std::string_view name, const Path &srcPath) const |
| StorePath | computeStorePathForText (std::string_view name, std::string_view s, const StorePathSet &references) const |
| kj::Promise< Result< bool > > | isValidPath (const StorePath &path) |
| kj::Promise< Result< void > > | substitutePaths (const StorePathSet &paths) |
| virtual kj::Promise< Result< StorePathSet > > | queryValidPaths (const StorePathSet &paths, SubstituteFlag maybeSubstitute=NoSubstitute) |
| virtual kj::Promise< Result< StorePathSet > > | queryAllValidPaths () |
| kj::Promise< Result< ref< const ValidPathInfo > > > | queryPathInfo (const StorePath &path) |
| kj::Promise< Result< std::shared_ptr< const Realisation > > > | queryRealisation (const DrvOutput &) |
| virtual bool | pathInfoIsUntrusted (const ValidPathInfo &) |
| virtual bool | realisationIsUntrusted (const Realisation &) |
| virtual kj::Promise< Result< void > > | queryReferrers (const StorePath &path, StorePathSet &referrers) |
| virtual kj::Promise< Result< StorePathSet > > | queryValidDerivers (const StorePath &path) |
| virtual kj::Promise< Result< StorePathSet > > | queryDerivationOutputs (const StorePath &path) |
| virtual kj::Promise< Result< std::map< std::string, std::optional< StorePath > > > > | queryPartialDerivationOutputMap (const StorePath &path, Store *evalStore=nullptr) |
| virtual kj::Promise< Result< std::map< std::string, std::optional< StorePath > > > > | queryStaticPartialDerivationOutputMap (const StorePath &path) |
| kj::Promise< Result< OutputPathMap > > | queryDerivationOutputMap (const StorePath &path, Store *evalStore=nullptr) |
| virtual kj::Promise< Result< std::optional< StorePath > > > | queryPathFromHashPart (const std::string &hashPart)=0 |
| virtual kj::Promise< Result< StorePathSet > > | querySubstitutablePaths (const StorePathSet &paths) |
| virtual kj::Promise< Result< void > > | querySubstitutablePathInfos (const StorePathCAMap &paths, SubstitutablePathInfos &infos) |
| virtual kj::Promise< Result< void > > | addToStore (const ValidPathInfo &info, AsyncInputStream &narSource, RepairFlag repair=NoRepair, CheckSigsFlag checkSigs=CheckSigs)=0 |
| virtual kj::Promise< Result< void > > | addMultipleToStore (PathsSource &pathsToCopy, Activity &act, RepairFlag repair=NoRepair, CheckSigsFlag checkSigs=CheckSigs) |
| virtual kj::Promise< Result< StorePath > > | addToStoreRecursive (std::string_view name, const PreparedDump &source, HashType hashAlgo=HashType::SHA256, RepairFlag repair=NoRepair) |
| virtual kj::Promise< Result< StorePath > > | addToStoreFlat (std::string_view name, const Path &srcPath, HashType hashAlgo=HashType::SHA256, RepairFlag repair=NoRepair) |
| kj::Promise< Result< ValidPathInfo > > | addToStoreSlow (std::string_view name, const Path &srcPath, FileIngestionMethod method=FileIngestionMethod::Recursive, HashType hashAlgo=HashType::SHA256, std::optional< Hash > expectedCAHash={}) |
| virtual kj::Promise< Result< StorePath > > | addToStoreFromDump (AsyncInputStream &dump, std::string_view name, FileIngestionMethod method=FileIngestionMethod::Recursive, HashType hashAlgo=HashType::SHA256, RepairFlag repair=NoRepair, const StorePathSet &references=StorePathSet()) |
| virtual kj::Promise< Result< StorePath > > | addTextToStore (std::string_view name, std::string_view s, const StorePathSet &references, RepairFlag repair=NoRepair)=0 |
| virtual kj::Promise< Result< void > > | registerDrvOutput (const Realisation &output) |
| virtual kj::Promise< Result< void > > | registerDrvOutput (const Realisation &output, CheckSigsFlag checkSigs) |
| virtual kj::Promise< Result< box_ptr< Source > > > | narFromPath (const StorePath &path)=0 |
| virtual kj::Promise< Result< void > > | buildPaths (const std::vector< DerivedPath > &paths, BuildMode buildMode=bmNormal, std::shared_ptr< Store > evalStore=nullptr) |
| virtual kj::Promise< Result< std::vector< KeyedBuildResult > > > | buildPathsWithResults (const std::vector< DerivedPath > &paths, BuildMode buildMode=bmNormal, std::shared_ptr< Store > evalStore=nullptr) |
| virtual kj::Promise< Result< BuildResult > > | buildDerivation (const StorePath &drvPath, const BasicDerivation &drv, BuildMode buildMode=bmNormal) |
| virtual kj::Promise< Result< void > > | ensurePath (const StorePath &path) |
| virtual kj::Promise< Result< void > > | addTempRoot (const StorePath &path) |
| kj::Promise< Result< std::string > > | makeValidityRegistration (const StorePathSet &paths, bool showDerivers, bool showHash) |
| kj::Promise< Result< JSON > > | pathInfoToJSON (const StorePathSet &storePaths, bool includeImpureInfo, bool showClosureSize, Base hashBase=Base::Base32, AllowInvalidFlag allowInvalid=DisallowInvalid) |
| kj::Promise< Result< std::pair< uint64_t, uint64_t > > > | getClosureSize (const StorePath &storePath) |
| virtual kj::Promise< Result< void > > | optimiseStore () |
| virtual kj::Promise< Result< bool > > | verifyStore (bool checkContents, RepairFlag repair=NoRepair) |
| virtual ref< FSAccessor > | getFSAccessor ()=0 |
| virtual kj::Promise< Result< void > > | repairPath (const StorePath &path) |
| virtual kj::Promise< Result< void > > | addSignatures (const StorePath &storePath, const StringSet &sigs) |
| kj::Promise< Result< Derivation > > | derivationFromPath (const StorePath &drvPath) |
| kj::Promise< Result< Derivation > > | readDerivation (const StorePath &drvPath) |
| kj::Promise< Result< Derivation > > | readInvalidDerivation (const StorePath &drvPath) |
| virtual kj::Promise< Result< void > > | computeFSClosure (const StorePathSet &paths, StorePathSet &out, bool flipDirection=false, bool includeOutputs=false, bool includeDerivers=false) |
| kj::Promise< Result< void > > | computeFSClosure (const StorePath &path, StorePathSet &out, bool flipDirection=false, bool includeOutputs=false, bool includeDerivers=false) |
| virtual kj::Promise< Result< void > > | queryMissing (const std::vector< DerivedPath > &targets, StorePathSet &willBuild, StorePathSet &willSubstitute, StorePathSet &unknown, uint64_t &downloadSize, uint64_t &narSize) |
| kj::Promise< Result< StorePaths > > | topoSortPaths (const StorePathSet &paths) |
| kj::Promise< Result< void > > | exportPaths (const StorePathSet &paths, Sink &sink) |
| kj::Promise< Result< void > > | exportPath (const StorePath &path, Sink &sink) |
| kj::Promise< Result< StorePaths > > | importPaths (Source &source, CheckSigsFlag checkSigs=CheckSigs) |
| kj::Promise< Result< Stats<> > > | getStats () |
| kj::Promise< Result< StorePathSet > > | exportReferences (const StorePathSet &storePaths, const StorePathSet &inputPaths) |
| kj::Promise< Result< std::optional< StorePath > > > | getBuildDerivationPath (const StorePath &) |
| kj::Promise< void > | clearPathInfoCache () |
| virtual kj::Promise< Result< void > > | connect () |
| virtual kj::Promise< Result< unsigned int > > | getProtocol () |
| virtual kj::Promise< Result< std::optional< TrustedFlag > > > | isTrustedClient ()=0 |
| virtual Path | toRealPath (const Path &storePath) |
| Path | toRealPath (const StorePath &storePath) |
| virtual kj::Promise< Result< void > > | setOptions () |
| virtual kj::Promise< Result< std::optional< std::string > > > | getVersion () |
Static Public Attributes | |
| static constexpr const char * | MissingName = "x" |
Protected Member Functions | |
| Store (const StoreConfig &config) | |
| virtual kj::Promise< Result< bool > > | isValidPathUncached (const StorePath &path) |
| virtual kj::Promise< Result< std::shared_ptr< const ValidPathInfo > > > | queryPathInfoUncached (const StorePath &path)=0 |
| virtual kj::Promise< Result< std::shared_ptr< const Realisation > > > | queryRealisationUncached (const DrvOutput &)=0 |
| void | unsupported (const std::string &op) |
Protected Attributes | |
| Sync< State, AsyncMutex > | state |
| std::shared_ptr< NarInfoDiskCache > | diskCache |
| Stats< std::atomic > | stats |
| using nix::Store::PathsSource |
A list of paths infos along with a source providing the content of the associated store path
|
virtual |
Import multiple paths into the store.
Reimplemented in nix::RemoteStore.
|
inlinevirtual |
Add signatures to the specified store path. The signatures are not verified.
Reimplemented in nix::BinaryCacheStore, nix::LocalStore, and nix::RemoteStore.
|
inlinevirtual |
Add a store path as a temporary root of the garbage collector. The root disappears as soon as we exit.
Reimplemented in nix::LocalStore, and nix::RemoteStore.
|
pure virtual |
Like addToStore, but the contents written to the output path is a regular file containing the given string.
Implemented in nix::BinaryCacheStore, nix::DummyStore, nix::LegacySSHStore, nix::LocalStore, and nix::RemoteStore.
|
pure virtual |
Import a path into the store.
Implemented in nix::BinaryCacheStore, nix::DummyStore, nix::LegacySSHStore, nix::LocalStore, and nix::RemoteStore.
|
inlinevirtual |
Like addToStore(), but the contents of the path are contained in dump, which is either a NAR serialisation (if recursive == true) or simply the contents of a regular file (if recursive == false). dump may be drained
Reimplemented in nix::BinaryCacheStore, nix::LocalStore, and nix::RemoteStore.
|
virtual |
Copy the contents of a path to the store and register the validity the resulting path.
| filter | This function can be used to exclude files (see libutil/archive.hh). |
Reimplemented in nix::BinaryCacheStore, and nix::LegacySSHStore.
| kj::Promise< Result< ValidPathInfo > > nix::Store::addToStoreSlow | ( | std::string_view | name, |
| const Path & | srcPath, | ||
| FileIngestionMethod | method = FileIngestionMethod::Recursive, | ||
| HashType | hashAlgo = HashType::SHA256, | ||
| std::optional< Hash > | expectedCAHash = {} ) |
Copy the contents of a path to the store and register the validity the resulting path, using a constant amount of memory.
|
inlinevirtual |
Credentials of the context using this store if this store is proxied to somewhere else and the peer context is known. Only the daemon can set this to values that make any sense, using unix peer credentials.
Reimplemented in nix::LocalStore.
|
virtual |
Build a single non-materialized derivation (i.e. not from an on-disk .drv file).
| drvPath | This is used to deduplicate worker goals so it is imperative that is correct. That said, it doesn't literally need to be store path that would be calculated from writing this derivation to the store: it is OK if it instead is that of a Derivation which would resolve to this (by taking the outputs of it's input derivations and adding them as input sources) such that the build time referenceable-paths are the same. |
In the input-addressed case, we usually do use an "original" unresolved derivations's path, as that is what will be used in the buildPaths case. Also, the input-addressed output paths are verified only by that contents of that specific unresolved derivation, so it is nice to keep that information around so if the original derivation is ever obtained later, it can be verified whether the trusted user in fact used the proper output path.
In the content-addressed case, we want to always use the resolved drv path calculated from the provided derivation. This serves two purposes:
Reimplemented in nix::LegacySSHStore, and nix::RemoteStore.
|
virtual |
For each path, if it's a derivation, build it. Building a derivation means ensuring that the output paths are valid. If they are already valid, this is a no-op. Otherwise, validity can be reached in two ways. First, if the output paths is substitutable, then build the path that way. Second, the output paths can be created by running the builder, after recursively building any sub-derivations. For inputs that are not derivations, substitute them.
Reimplemented in nix::LegacySSHStore, and nix::RemoteStore.
|
virtual |
Like buildPaths(), but return a vector of BuildResult BuildResults corresponding to each element in paths. Note that in case of a build/substitution error, this function won't throw an exception, but return a BuildResult containing an error message.
Reimplemented in nix::RemoteStore.
|
inline |
Hack to allow long-running processes like hydra-queue-runner to occasionally flush their path info cache.
|
virtual |
| [out] | out | Place in here the set of all store paths in the file system closure of storePath; that is, all paths than can be directly or indirectly reached from it. out is not cleared. |
| flipDirection | If true, the set of paths that can reach storePath is returned; that is, the closures under the referrers relation instead of the references relation is returned. |
Reimplemented in nix::LegacySSHStore.
| StorePath nix::Store::computeStorePathForPathRecursive | ( | std::string_view | name, |
| const PreparedDump & | source ) const |
Preparatory part of addToStore().
| StorePath nix::Store::computeStorePathForText | ( | std::string_view | name, |
| std::string_view | s, | ||
| const StorePathSet & | references ) const |
Preparatory part of addTextToStore().
!!! Computation of the path should take the references given to addTextToStore() into account, otherwise we have a (relatively minor) security hole: a caller can register a source file with bogus references. If there are too many references, the path may not be garbage collected when it has to be (not really a problem, the caller could create a root anyway), or it may be garbage collected when it shouldn't be (more serious).
Hashing the references would solve this (bogus references would simply yield a different store path, so other users wouldn't be affected), but it has some backwards compatibility issues (the hashing scheme changes), so I'm not doing that for now.
|
inlinevirtual |
Establish a connection to the store, for store types that have a notion of connection. Otherwise this is a no-op.
Reimplemented in nix::LegacySSHStore, and nix::RemoteStore.
| kj::Promise< Result< Derivation > > nix::Store::derivationFromPath | ( | const StorePath & | drvPath | ) |
Read a derivation, after ensuring its existence through ensurePath().
|
virtual |
Ensure that a path is valid. If it is not currently valid, it may be made valid by running a substitute (if defined for the path).
Reimplemented in nix::LegacySSHStore, and nix::RemoteStore.
| kj::Promise< Result< void > > nix::Store::exportPaths | ( | const StorePathSet & | paths, |
| Sink & | sink ) |
Export multiple paths in the format expected by ‘nix-store –import’.
| kj::Promise< Result< StorePathSet > > nix::Store::exportReferences | ( | const StorePathSet & | storePaths, |
| const StorePathSet & | inputPaths ) |
Computes the full closure of of a set of store-paths for e.g. derivations that need this information for exportReferencesGraph.
| Path nix::Store::followLinksToStore | ( | std::string_view | path | ) | const |
Follow symlinks until we end up with a path in the Nix store.
| StorePath nix::Store::followLinksToStorePath | ( | std::string_view | path | ) | const |
Same as followLinksToStore(), but apply toStorePath() to the result.
| kj::Promise< Result< std::optional< StorePath > > > nix::Store::getBuildDerivationPath | ( | const StorePath & | path | ) |
Given a store path, return the realisation actually used in the realisation of this path:
| kj::Promise< Result< std::pair< uint64_t, uint64_t > > > nix::Store::getClosureSize | ( | const StorePath & | storePath | ) |
|
pure virtual |
Implemented in nix::BinaryCacheStore, nix::DummyStore, nix::LegacySSHStore, nix::LocalFSStore, nix::RemoteStore, and nix::UDSRemoteStore.
|
inlinevirtual |
Get the protocol version of this store or it's connection.
Reimplemented in nix::LegacySSHStore, nix::LocalStore, and nix::RemoteStore.
|
pure virtual |
Implemented in nix::LocalStore.
| kj::Promise< Result< StorePaths > > nix::Store::importPaths | ( | Source & | source, |
| CheckSigsFlag | checkSigs = CheckSigs ) |
Import a sequence of NAR dumps created by exportPaths() into the Nix store. Optionally, the contents of the NARs are preloaded into the specified FS accessor to speed up subsequent access.
|
inlinevirtual |
Perform any necessary effectful operation to make the store up and running
Reimplemented in nix::BinaryCacheStore, nix::HttpBinaryCacheStore, and nix::LocalBinaryCacheStore.
| bool nix::Store::isInStore | ( | PathView | path | ) | const |
| bool nix::Store::isStorePath | ( | std::string_view | path | ) | const |
|
pure virtual |
std::nullopt means we do not know.
Implemented in nix::DummyStore, nix::HttpBinaryCacheStore, nix::LegacySSHStore, nix::LocalBinaryCacheStore, nix::LocalStore, and nix::RemoteStore.
| kj::Promise< Result< bool > > nix::Store::isValidPath | ( | const StorePath & | path | ) |
Check whether a path is valid. A path is valid when it exists in the store now.
| StorePath nix::Store::makeStorePath | ( | std::string_view | type, |
| std::string_view | hash, | ||
| std::string_view | name ) const |
Constructs a unique store path name.
| kj::Promise< Result< std::string > > nix::Store::makeValidityRegistration | ( | const StorePathSet & | paths, |
| bool | showDerivers, | ||
| bool | showHash ) |
|
pure virtual |
Generate a NAR dump of a store path.
Implemented in nix::BinaryCacheStore, nix::DummyStore, nix::LegacySSHStore, nix::LocalFSStore, nix::RemoteStore, and nix::UDSRemoteStore.
|
inlinevirtual |
Optimise the disk space usage of the Nix store by hard-linking files with the same contents.
Reimplemented in nix::LocalStore, and nix::RemoteStore.
| StorePathSet nix::Store::parseStorePathSet | ( | const PathSet & | paths | ) | const |
Deprecated
|
inlinevirtual |
Check whether the given valid path info is sufficiently attested, by either being signed by a trusted public key or content-addressed, in order to be included in the given store.
These same checks would be performed in addToStore, but this allows an earlier failure in the case where dependencies need to be added too, but the addToStore wouldn't fail until those dependencies are added. Also, we don't really want to add the dependencies listed in a nar info we don't trust anyyways.
Reimplemented in nix::LocalStore.
| kj::Promise< Result< JSON > > nix::Store::pathInfoToJSON | ( | const StorePathSet & | storePaths, |
| bool | includeImpureInfo, | ||
| bool | showClosureSize, | ||
| Base | hashBase = Base::Base32, | ||
| AllowInvalidFlag | allowInvalid = DisallowInvalid ) |
Write a JSON representation of store path metadata, such as the hash and the references.
| includeImpureInfo | If true, variable elements such as the registration time are included. |
| showClosureSize | If true, the closure size of each path is included. |
|
inlinevirtual |
Query the set of all valid paths. Note that for some store backends, the name part of store paths may be replaced by 'x' (i.e. you'll get /nix/store/<hash>-x rather than /nix/store/<hash>-<name>). Use queryPathInfo() to obtain the full store path. FIXME: should return a set of std::variant<StorePath, HashPart> to get rid of this hack.
Reimplemented in nix::LocalBinaryCacheStore, nix::LocalStore, and nix::RemoteStore.
| kj::Promise< Result< OutputPathMap > > nix::Store::queryDerivationOutputMap | ( | const StorePath & | path, |
| Store * | evalStore = nullptr ) |
Query the mapping outputName=>outputPath for the given derivation. Assume every output has a mapping and throw an exception otherwise.
|
virtual |
Query the outputs of the derivation denoted by path.
Reimplemented in nix::RemoteStore.
|
virtual |
Given a set of paths that are to be built, return the set of derivations that will be built, and the set of output paths that will be substituted.
Reimplemented in nix::RemoteStore.
|
virtual |
Query the mapping outputName => outputPath for the given derivation. All outputs are mentioned so ones mising the mapping are mapped to std::nullopt.
Reimplemented in nix::RemoteStore.
|
pure virtual |
Query the full store path given the hash part of a valid store path, or empty if the path doesn't exist.
Implemented in nix::BinaryCacheStore, nix::DummyStore, nix::LegacySSHStore, nix::LocalStore, and nix::RemoteStore.
| kj::Promise< Result< ref< const ValidPathInfo > > > nix::Store::queryPathInfo | ( | const StorePath & | path | ) |
Query information about a valid path. It is permitted to omit the name part of the store path.
|
protectedpure virtual |
Queries the path info without caching. Note to implementors: should return nullptr when the path is not found.
Implemented in nix::BinaryCacheStore, nix::DummyStore, nix::LegacySSHStore, nix::LocalStore, and nix::RemoteStore.
| kj::Promise< Result< std::shared_ptr< const Realisation > > > nix::Store::queryRealisation | ( | const DrvOutput & | id | ) |
Query the information about a realisation.
|
inlinevirtual |
Queries the set of incoming FS references for a store path. The result is not cleared.
Reimplemented in nix::LocalStore, and nix::RemoteStore.
|
virtual |
Like queryPartialDerivationOutputMap but only considers statically known output paths (i.e. those that can be gotten from the derivation itself.
Just a helper function for implementing queryPartialDerivationOutputMap.
Reimplemented in nix::LocalStore.
|
virtual |
Query substitute info (i.e. references, derivers and download sizes) of a map of paths to their optional ca values. The info of the first succeeding substituter for each path will be returned. If a path does not have substitute info, it's omitted from the resulting ‘infos’ map.
Reimplemented in nix::RemoteStore.
|
inlinevirtual |
Query which of the given paths have substitutes.
Reimplemented in nix::LocalStore, and nix::RemoteStore.
|
inlinevirtual |
(Note that the result of queryDeriver() is the derivation that was actually used to produce path, which may not exist anymore.)
Reimplemented in nix::LocalStore, and nix::RemoteStore.
|
virtual |
Query which of the given paths is valid. Optionally, try to substitute missing paths.
Reimplemented in nix::LegacySSHStore, nix::LocalStore, and nix::RemoteStore.
| kj::Promise< Result< Derivation > > nix::Store::readDerivation | ( | const StorePath & | drvPath | ) |
Read a derivation (which must already be valid).
| kj::Promise< Result< Derivation > > nix::Store::readInvalidDerivation | ( | const StorePath & | drvPath | ) |
Read a derivation from a potentially invalid path.
|
inlinevirtual |
Add a mapping indicating that deriver!outputName maps to the output path output.
This is redundant for known-input-addressed and fixed-output derivations as this information is already present in the drv file, but necessary for floating-ca derivations and their dependencies as there's no way to retrieve this information otherwise.
Reimplemented in nix::BinaryCacheStore, nix::LocalStore, and nix::RemoteStore.
|
virtual |
Repair the contents of the given path by redownloading it using a substituter (if available).
Reimplemented in nix::LegacySSHStore, and nix::RemoteStore.
|
inlinevirtual |
Synchronises the options of the client with those of the daemon (a no-op when there’s no daemon)
Reimplemented in nix::RemoteStore.
| std::string nix::Store::showPaths | ( | const StorePathSet & | paths | ) |
Display a set of paths in human-readable form (i.e., between quotes and separated by commas).
| kj::Promise< Result< void > > nix::Store::substitutePaths | ( | const StorePathSet & | paths | ) |
If requested, substitute missing paths. This implements nix-copy-closure's –use-substitutes flag.
| kj::Promise< Result< StorePaths > > nix::Store::topoSortPaths | ( | const StorePathSet & | paths | ) |
Sort a set of paths topologically under the references relation. If p refers to q, then p precedes q in this list.
Split a path like /nix/store/<hash>-<name>/<bla> into /nix/store/<hash>-<name> and /<bla>.
|
inlineprotected |
Helper for methods that are not unsupported: this is used for default definitions for virtual methods that are meant to be overriden.
|
inlinevirtual |
Check the integrity of the Nix store.
Reimplemented in nix::LocalStore, and nix::RemoteStore.