From 74870600fa54a48d4c1ce4b19861a9b0ce027fee Mon Sep 17 00:00:00 2001 From: Aqua-sama Date: Sun, 22 Mar 2020 14:59:04 +0200 Subject: lib/configuration improvements Configuration changes: - Configuration::value return type is now [[nodiscard]] - Configuration::value is now a generic template that only works with the exact types of the underlying std::variant - Add Configuration::value for standard library types compatible with the types of std::variant - Add Configuration::shortcut<> placeholder, and QAction and QKeySequence specializations as a convenient way to set up shortcuts - Deprecate setShortcut - Add Configuration::read_file convenience member that takes file path as parameter Format changes: - Configuration files can now have sections, specified as [section name]. Section names are prepended to keys. Section names cannot be nested. - Configuration files can now have @@include directives, causing another file to be read as well. The included file is not treated as nested into a section, and will overwrite values previously set. Others: - add some tests for libconfiguration. QAction/QKeySequence require a QApplication be set up, so the test application may require running xorg/wayland. old coverage: lines: 15.6% (960 out of 6172) branches: 9.9% (1187 out of 12012) new coverage: lines: 17.1% (1067 out of 6254) branches: 11.0% (1388 out of 12644) --- test/conf/main.cpp | 54 ------------------------------------------------------ 1 file changed, 54 deletions(-) delete mode 100644 test/conf/main.cpp (limited to 'test/conf/main.cpp') diff --git a/test/conf/main.cpp b/test/conf/main.cpp deleted file mode 100644 index e499a4d..0000000 --- a/test/conf/main.cpp +++ /dev/null @@ -1,54 +0,0 @@ -#include -#include -#include -#include "configuration.h" -#include - -int main(int, char**) -{ - std::fstream fs; - fs.open("smolbote.cfg", std::fstream::in); - assert(fs.is_open()); - - { - auto value_map = std::make_unique>>({ - { "test", std::string("unknown") }, - { "integer-1", 20 }, - { "integer-2", 30 } - }); - value_map->read(fs); - - Configuration::move_global(std::move(value_map)); - fs.close(); - } - - { - Configuration g; - assert(g.value("test") == "value"); - assert(g.value("plugins.path") == "/usr/local/lib/smolbote/plugins"); - assert(g.value("integer-1") == 20); - assert(g.value("integer-2") == 22); - } - -/* - { - const Configuration conf(std::move(value_map)); - - assert(conf.value("test") == "value"); - assert(conf.value("plugins.path") == "/usr/local/lib/smolbote/plugins"); - assert(conf.value("integer-1") == 20); - assert(conf.value("integer-2") == 22); - } -*/ - // Configuration is now destroyed - - - // This should be a compiler warning - //const Configuration c(std::move(value_map)); - //assert(c.value("test") == "value"); - - // This should be a compiler warning and runtime error - //assert(value_map.value("test").value() == "value"); - - return 0; -} -- cgit v1.2.1