diff options
author | Eelco Dolstra <edolstra@gmail.com> | 2018-02-19T12·58+0100 |
---|---|---|
committer | Eelco Dolstra <edolstra@gmail.com> | 2018-02-19T12·58+0100 |
commit | 75a1d96cfd931e6e598040f5961d6d33f417ba56 (patch) | |
tree | e995eeaf138895275a69a7050507ef9c94f098b4 /src/libstore | |
parent | 7fe5910bf8a9d104354df14b6b2faa69a6718e70 (diff) | |
parent | de4934ab3b26aa851b7044e9884102cc054dc092 (diff) |
Merge branch 'register-settings' of https://github.com/shlevy/nix
Diffstat (limited to 'src/libstore')
-rw-r--r-- | src/libstore/globals.cc | 16 | ||||
-rw-r--r-- | src/libstore/globals.hh | 7 | ||||
-rw-r--r-- | src/libstore/store-api.cc | 2 |
3 files changed, 24 insertions, 1 deletions
diff --git a/src/libstore/globals.cc b/src/libstore/globals.cc index 247040606fb7..f46e8326235f 100644 --- a/src/libstore/globals.cc +++ b/src/libstore/globals.cc @@ -162,6 +162,22 @@ void initPlugins() throw Error("could not dynamically open plugin file '%s%': %s%", file, dlerror()); } } + /* We handle settings registrations here, since plugins can add settings */ + if (RegisterSetting::settingRegistrations) { + for (auto & registration : *RegisterSetting::settingRegistrations) + settings.addSetting(registration); + delete RegisterSetting::settingRegistrations; + } + settings.handleUnknownSettings(); +} + +RegisterSetting::SettingRegistrations * RegisterSetting::settingRegistrations; + +RegisterSetting::RegisterSetting(AbstractSetting * s) +{ + if (!settingRegistrations) + settingRegistrations = new SettingRegistrations; + settingRegistrations->emplace_back(s); } diff --git a/src/libstore/globals.hh b/src/libstore/globals.hh index fd3fbec9f017..dd01f832df0c 100644 --- a/src/libstore/globals.hh +++ b/src/libstore/globals.hh @@ -386,5 +386,12 @@ void initPlugins(); extern const string nixVersion; +struct RegisterSetting +{ + typedef std::vector<AbstractSetting *> SettingRegistrations; + static SettingRegistrations * settingRegistrations; + RegisterSetting(AbstractSetting * s); +}; + } diff --git a/src/libstore/store-api.cc b/src/libstore/store-api.cc index 4d43ef082d53..8830edcc3449 100644 --- a/src/libstore/store-api.cc +++ b/src/libstore/store-api.cc @@ -839,7 +839,7 @@ ref<Store> openStore(const std::string & uri_, for (auto fun : *RegisterStoreImplementation::implementations) { auto store = fun(uri, params); if (store) { - store->warnUnknownSettings(); + store->handleUnknownSettings(); return ref<Store>(store); } } |