about summary refs log tree commit diff
path: root/src/libutil/config.hh
AgeCommit message (Collapse)AuthorFilesLines
2018-05-30 Modularize config settingsEelco Dolstra1-16/+65
Allow global config settings to be defined in multiple Config classes. For example, this means that libutil can have settings and evaluator settings can be moved out of libstore. The Config classes are registered in a new GlobalConfig class to which config files etc. are applied. Relevant to https://github.com/NixOS/nix/issues/2009 in that it removes the need for ad hoc handling of useCaseHack, which was the underlying cause of that issue.
2018-02-19 Config::handleUnknownSettings(): Remove unused 'fatal' argumentEelco Dolstra1-1/+1
2018-02-13 Allow plugins to define new settings.Shea Levy1-4/+4
2017-11-21 Propagate flags like --sandbox to the daemon properlyEelco Dolstra1-0/+6
2017-06-07 Don't show flags from config settings in "nix --help"Eelco Dolstra1-3/+3
2017-06-07 nix: Add --help-config flagEelco Dolstra1-1/+9
2017-06-07 nix: Make all options available as flagsEelco Dolstra1-0/+6
Thus, instead of ‘--option <name> <value>’, you can write ‘--<name> <value>’. So --option http-connections 100 becomes --http-connections 100 Apart from brevity, the difference is that it's not an error to set a non-existent option via --option, but unrecognized arguments are fatal. Boolean options have special treatment: they're mapped to the argument-less flags ‘--<name>’ and ‘--no-<name>’. E.g. --option auto-optimise-store false becomes --no-auto-optimise-store
2017-05-03 Fix build on gcc 4.9Eelco Dolstra1-1/+4
http://hydra.nixos.org/build/52408843
2017-04-20 Improve nix show-config --jsonEelco Dolstra1-0/+8
In particular, show descriptions. This could be used for manpage generation etc.
2017-04-20 Setting: Remove "Tag" template argumentEelco Dolstra1-18/+30
2017-04-20 Read per-user settings from ~/.config/nix/nix.confEelco Dolstra1-2/+8
2017-04-13 Convert Settings to the new config systemEelco Dolstra1-5/+17
This makes all config options self-documenting. Unknown or unparseable config settings and --option flags now cause a warning.
2017-04-13 Add a Config class to simplify adding configuration settingsEelco Dolstra1-0/+151
The typical use is to inherit Config and add Setting<T> members: class MyClass : private Config { Setting<int> foo{this, 123, "foo", "the number of foos to use"}; Setting<std::string> bar{this, "blabla", "bar", "the name of the bar"}; MyClass() : Config(readConfigFile("/etc/my-app.conf")) { std::cout << foo << "\n"; // will print 123 unless overriden } }; Currently, this is used by Store and its subclasses for store parameters. You now get a warning if you specify a non-existant store parameter in a store URI.