diff options
author | Naïm Favier <n@monade.li> | 2022-02-19 16:59:52 +0100 |
---|---|---|
committer | Naïm Favier <n@monade.li> | 2022-03-07 12:01:54 +0100 |
commit | da7d8daa77c2cce5805947a012060b02be9e4a43 (patch) | |
tree | e1975cf7843ce60e93c263fdac1bd066908b3fb1 /src | |
parent | 55c6906701ee7fc7e915f7889fea86957b020f94 (diff) |
Add shell completion for --override-flake
Requires moving the MixEvalArgs class from libexpr to libcmd because
that's where completeFlakeRef is.
Diffstat (limited to 'src')
-rw-r--r-- | src/libcmd/common-eval-args.cc (renamed from src/libexpr/common-eval-args.cc) | 4 | ||||
-rw-r--r-- | src/libcmd/common-eval-args.hh (renamed from src/libexpr/common-eval-args.hh) | 0 |
2 files changed, 4 insertions, 0 deletions
diff --git a/src/libexpr/common-eval-args.cc b/src/libcmd/common-eval-args.cc index e50ff244c..5b6e82388 100644 --- a/src/libexpr/common-eval-args.cc +++ b/src/libcmd/common-eval-args.cc @@ -7,6 +7,7 @@ #include "registry.hh" #include "flake/flakeref.hh" #include "store-api.hh" +#include "command.hh" namespace nix { @@ -59,6 +60,9 @@ MixEvalArgs::MixEvalArgs() fetchers::Attrs extraAttrs; if (to.subdir != "") extraAttrs["dir"] = to.subdir; fetchers::overrideRegistry(from.input, to.input, extraAttrs); + }}, + .completer = {[&](size_t, std::string_view prefix) { + completeFlakeRef(openStore(), prefix); }} }); diff --git a/src/libexpr/common-eval-args.hh b/src/libcmd/common-eval-args.hh index 03fa226aa..03fa226aa 100644 --- a/src/libexpr/common-eval-args.hh +++ b/src/libcmd/common-eval-args.hh |