2016-02-09 22:07:48 +02:00
|
|
|
#include "common-args.hh"
|
|
|
|
#include "globals.hh"
|
|
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
|
|
|
MixCommonArgs::MixCommonArgs(const string & programName)
|
2016-02-09 22:28:29 +02:00
|
|
|
: programName(programName)
|
2016-02-09 22:07:48 +02:00
|
|
|
{
|
2017-10-24 13:45:11 +03:00
|
|
|
mkFlag()
|
|
|
|
.longName("verbose")
|
|
|
|
.shortName('v')
|
|
|
|
.description("increase verbosity level")
|
|
|
|
.handler([]() { verbosity = (Verbosity) (verbosity + 1); });
|
2016-02-09 22:07:48 +02:00
|
|
|
|
2017-10-24 13:45:11 +03:00
|
|
|
mkFlag()
|
|
|
|
.longName("quiet")
|
|
|
|
.description("decrease verbosity level")
|
|
|
|
.handler([]() { verbosity = verbosity > lvlError ? (Verbosity) (verbosity - 1) : lvlError; });
|
2016-02-09 22:07:48 +02:00
|
|
|
|
2017-10-24 13:45:11 +03:00
|
|
|
mkFlag()
|
|
|
|
.longName("debug")
|
|
|
|
.description("enable debug output")
|
|
|
|
.handler([]() { verbosity = lvlDebug; });
|
2016-02-09 22:07:48 +02:00
|
|
|
|
2017-06-07 19:41:20 +03:00
|
|
|
mkFlag()
|
|
|
|
.longName("option")
|
|
|
|
.labels({"name", "value"})
|
|
|
|
.description("set a Nix configuration option (overriding nix.conf)")
|
|
|
|
.arity(2)
|
2017-10-24 13:45:11 +03:00
|
|
|
.handler([](std::vector<std::string> ss) {
|
2017-04-13 21:53:23 +03:00
|
|
|
try {
|
2018-03-27 19:41:31 +03:00
|
|
|
globalConfig.set(ss[0], ss[1]);
|
2017-04-13 21:53:23 +03:00
|
|
|
} catch (UsageError & e) {
|
|
|
|
warn(e.what());
|
|
|
|
}
|
2016-02-09 22:07:48 +02:00
|
|
|
});
|
2017-11-14 15:04:09 +02:00
|
|
|
|
2019-06-15 17:34:06 +03:00
|
|
|
mkFlag()
|
|
|
|
.longName("max-jobs")
|
|
|
|
.shortName('j')
|
|
|
|
.label("jobs")
|
|
|
|
.description("maximum number of parallel builds")
|
|
|
|
.handler([=](std::string s) {
|
|
|
|
settings.set("max-jobs", s);
|
|
|
|
});
|
|
|
|
|
2017-11-14 15:04:09 +02:00
|
|
|
std::string cat = "config";
|
2018-03-27 19:41:31 +03:00
|
|
|
globalConfig.convertToArgs(*this, cat);
|
2018-02-08 16:25:03 +02:00
|
|
|
|
|
|
|
// Backward compatibility hack: nix-env already had a --system flag.
|
|
|
|
if (programName == "nix-env") longFlags.erase("system");
|
|
|
|
|
2017-11-14 15:04:09 +02:00
|
|
|
hiddenCategories.insert(cat);
|
2016-02-09 22:07:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|