From aa952d5f0bc623a1584f2d589209f586e594c75f Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Wed, 7 Jun 2017 16:49:54 +0200 Subject: [PATCH] nix: Add --help-config flag --- src/libutil/args.hh | 2 +- src/libutil/config.hh | 10 +++++++++- src/nix/main.cc | 20 ++++++++++++++++++++ 3 files changed, 30 insertions(+), 2 deletions(-) diff --git a/src/libutil/args.hh b/src/libutil/args.hh index ac12f8be6..f70bb7823 100644 --- a/src/libutil/args.hh +++ b/src/libutil/args.hh @@ -41,7 +41,7 @@ protected: virtual bool processFlag(Strings::iterator & pos, Strings::iterator end); - void printFlags(std::ostream & out); + virtual void printFlags(std::ostream & out); /* Positional arguments. */ struct ExpectedArg diff --git a/src/libutil/config.hh b/src/libutil/config.hh index 2ca643fe0..994eab911 100644 --- a/src/libutil/config.hh +++ b/src/libutil/config.hh @@ -31,6 +31,8 @@ class Config { friend class AbstractSetting; +public: + struct SettingData { bool isAlias; @@ -40,7 +42,11 @@ class Config { } }; - std::map _settings; + typedef std::map Settings; + +private: + + Settings _settings; StringMap initials; @@ -58,6 +64,8 @@ public: StringMap getSettings(bool overridenOnly = false); + const Settings & _getSettings() { return _settings; } + void applyConfigFile(const Path & path, bool fatal = false); void resetOverriden(); diff --git a/src/nix/main.cc b/src/nix/main.cc index f83843415..ea6838cd7 100644 --- a/src/nix/main.cc +++ b/src/nix/main.cc @@ -21,10 +21,30 @@ struct NixArgs : virtual MultiCommand, virtual MixCommonArgs throw Exit(); }); + mkFlag(0, "help-config", "show configuration options", [=]() { + std::cout << "The following configuration options are available:\n\n"; + Table2 tbl; + for (const auto & s : settings._getSettings()) + if (!s.second.isAlias) + tbl.emplace_back(s.first, s.second.setting->description); + printTable(std::cout, tbl); + throw Exit(); + }); + mkFlag(0, "version", "show version information", std::bind(printVersion, programName)); settings.convertToArgs(*this); } + + void printFlags(std::ostream & out) override + { + Args::printFlags(out); + std::cout << + "\n" + "In addition, most configuration settings can be overriden using ‘-- ’.\n" + "Boolean settings can be overriden using ‘--’ or ‘--no-’. See ‘nix\n" + "--help-config’ for a list of configuration settings.\n"; + } }; void mainWrapped(int argc, char * * argv)