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