2016-02-09 21:07:48 +01:00
|
|
|
#include "common-args.hh"
|
|
|
|
#include "globals.hh"
|
2020-06-05 17:01:02 +02:00
|
|
|
#include "loggers.hh"
|
2016-02-09 21:07:48 +01:00
|
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
|
|
|
MixCommonArgs::MixCommonArgs(const string & programName)
|
2016-02-09 21:28:29 +01:00
|
|
|
: programName(programName)
|
2016-02-09 21:07:48 +01:00
|
|
|
{
|
2020-05-04 22:40:19 +02:00
|
|
|
addFlag({
|
|
|
|
.longName = "verbose",
|
|
|
|
.shortName = 'v',
|
2021-01-13 14:18:04 +01:00
|
|
|
.description = "Increase the logging verbosity level.",
|
2021-01-25 19:03:13 +01:00
|
|
|
.category = loggingCategory,
|
2020-05-04 22:40:19 +02:00
|
|
|
.handler = {[]() { verbosity = (Verbosity) (verbosity + 1); }},
|
|
|
|
});
|
|
|
|
|
|
|
|
addFlag({
|
|
|
|
.longName = "quiet",
|
2021-01-13 14:18:04 +01:00
|
|
|
.description = "Decrease the logging verbosity level.",
|
2021-01-25 19:03:13 +01:00
|
|
|
.category = loggingCategory,
|
2020-05-04 22:40:19 +02:00
|
|
|
.handler = {[]() { verbosity = verbosity > lvlError ? (Verbosity) (verbosity - 1) : lvlError; }},
|
|
|
|
});
|
|
|
|
|
|
|
|
addFlag({
|
|
|
|
.longName = "debug",
|
2021-01-13 14:18:04 +01:00
|
|
|
.description = "Set the logging verbosity level to 'debug'.",
|
2021-01-25 19:03:13 +01:00
|
|
|
.category = loggingCategory,
|
2020-05-04 22:40:19 +02:00
|
|
|
.handler = {[]() { verbosity = lvlDebug; }},
|
|
|
|
});
|
|
|
|
|
|
|
|
addFlag({
|
|
|
|
.longName = "option",
|
2021-01-13 14:18:04 +01:00
|
|
|
.description = "Set the Nix configuration setting *name* to *value* (overriding `nix.conf`).",
|
2020-05-04 22:40:19 +02:00
|
|
|
.labels = {"name", "value"},
|
|
|
|
.handler = {[](std::string name, std::string value) {
|
2017-04-13 20:53:23 +02:00
|
|
|
try {
|
2020-05-04 22:40:19 +02:00
|
|
|
globalConfig.set(name, value);
|
2017-04-13 20:53:23 +02:00
|
|
|
} catch (UsageError & e) {
|
2020-05-10 20:32:21 +02:00
|
|
|
if (!completions)
|
|
|
|
warn(e.what());
|
2017-04-13 20:53:23 +02:00
|
|
|
}
|
2020-05-04 22:40:19 +02:00
|
|
|
}},
|
2020-05-10 21:50:32 +02:00
|
|
|
.completer = [](size_t index, std::string_view prefix) {
|
|
|
|
if (index == 0) {
|
|
|
|
std::map<std::string, Config::SettingInfo> settings;
|
|
|
|
globalConfig.getSettings(settings);
|
|
|
|
for (auto & s : settings)
|
|
|
|
if (hasPrefix(s.first, prefix))
|
2020-10-29 18:26:35 +01:00
|
|
|
completions->add(s.first, fmt("Set the `%s` setting.", s.first));
|
2020-05-10 21:50:32 +02:00
|
|
|
}
|
|
|
|
}
|
2020-05-04 22:40:19 +02:00
|
|
|
});
|
|
|
|
|
2020-06-05 17:01:02 +02:00
|
|
|
addFlag({
|
|
|
|
.longName = "log-format",
|
2021-01-13 14:18:04 +01:00
|
|
|
.description = "Set the format of log output; one of `raw`, `internal-json`, `bar` or `bar-with-logs`.",
|
2021-01-25 19:03:13 +01:00
|
|
|
.category = loggingCategory,
|
2020-06-05 17:01:02 +02:00
|
|
|
.labels = {"format"},
|
|
|
|
.handler = {[](std::string format) { setLogFormat(format); }},
|
|
|
|
});
|
|
|
|
|
2020-05-04 22:40:19 +02:00
|
|
|
addFlag({
|
|
|
|
.longName = "max-jobs",
|
|
|
|
.shortName = 'j',
|
2021-01-13 14:18:04 +01:00
|
|
|
.description = "The maximum number of parallel builds.",
|
2020-05-04 22:40:19 +02:00
|
|
|
.labels = Strings{"jobs"},
|
|
|
|
.handler = {[=](std::string s) {
|
2019-06-15 16:34:06 +02:00
|
|
|
settings.set("max-jobs", s);
|
2020-05-04 22:40:19 +02:00
|
|
|
}}
|
|
|
|
});
|
2019-06-15 16:34:06 +02:00
|
|
|
|
2021-01-25 19:03:13 +01:00
|
|
|
std::string cat = "Options to override configuration settings";
|
2018-03-27 18:41:31 +02:00
|
|
|
globalConfig.convertToArgs(*this, cat);
|
2018-02-08 15:25:03 +01:00
|
|
|
|
|
|
|
// Backward compatibility hack: nix-env already had a --system flag.
|
|
|
|
if (programName == "nix-env") longFlags.erase("system");
|
|
|
|
|
2017-11-14 14:04:09 +01:00
|
|
|
hiddenCategories.insert(cat);
|
2016-02-09 21:07:48 +01:00
|
|
|
}
|
|
|
|
|
2021-01-28 15:37:43 +01:00
|
|
|
void MixCommonArgs::initialFlagsProcessed()
|
|
|
|
{
|
|
|
|
initPlugins();
|
|
|
|
pluginsInited();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-02-09 21:07:48 +01:00
|
|
|
}
|