diff options
author | Eelco Dolstra <edolstra@gmail.com> | 2017-08-29T12·28+0200 |
---|---|---|
committer | Eelco Dolstra <edolstra@gmail.com> | 2017-08-29T12·42+0200 |
commit | 5cc8609e30ab4f76053f3159c51ea78d9215bc8c (patch) | |
tree | 1a8d1d78f82389280f6c59954b8f82bdb2823f43 /src/libutil | |
parent | 93a5ef0516881ec133fc5e54069add6dd64ffbdd (diff) |
nix run: Allow passing a command to execute
E.g. nix run nixpkgs.hello -c hello --greeting Hallo Note that unlike "nix-shell --command", no quoting of arguments is necessary. "-c" (short for "--command") cannot be combined with "--" because they both consume all remaining arguments. But since installables shouldn't start with a dash, this is unlikely to cause problems.
Diffstat (limited to 'src/libutil')
-rw-r--r-- | src/libutil/args.cc | 4 | ||||
-rw-r--r-- | src/libutil/args.hh | 2 |
2 files changed, 5 insertions, 1 deletions
diff --git a/src/libutil/args.cc b/src/libutil/args.cc index 2b72079f2b47..d17a1e7a9abb 100644 --- a/src/libutil/args.cc +++ b/src/libutil/args.cc @@ -102,9 +102,11 @@ bool Args::processFlag(Strings::iterator & pos, Strings::iterator end) ++pos; Strings args; for (size_t n = 0 ; n < flag.arity; ++n) { - if (pos == end) + if (pos == end) { + if (flag.arity == ArityAny) break; throw UsageError(format("flag '%1%' requires %2% argument(s)") % name % flag.arity); + } args.push_back(*pos++); } flag.handler(args); diff --git a/src/libutil/args.hh b/src/libutil/args.hh index fd910b965ccc..044ed209e3bf 100644 --- a/src/libutil/args.hh +++ b/src/libutil/args.hh @@ -26,6 +26,8 @@ public: protected: + static const size_t ArityAny = std::numeric_limits<size_t>::max(); + /* Flags. */ struct Flag { |