summaryrefslogtreecommitdiff
path: root/gui
diff options
context:
space:
mode:
authorFelix Morgner <felix.morgner@gmail.com>2025-05-28 20:30:10 +0200
committerFelix Morgner <felix.morgner@gmail.com>2025-05-28 20:30:10 +0200
commita92eaa4c1bffc97db037328249b52a0740651a07 (patch)
tree251867584a9a6607fcf3bd0597fc8641d964e689 /gui
parent62f67faaed7577e5bfab2148ffcdda529dfe19a6 (diff)
downloadturns-a92eaa4c1bffc97db037328249b52a0740651a07.tar.xz
turns-a92eaa4c1bffc97db037328249b52a0740651a07.zip
gui: reintroduce settings schemas
Diffstat (limited to 'gui')
-rw-r--r--gui/CMakeLists.txt24
-rw-r--r--gui/ch.arknet.Turns.gschema.xml (renamed from gui/gschema.xml)0
-rw-r--r--gui/include/settings.hpp8
-rw-r--r--gui/src/main.cpp4
-rw-r--r--gui/src/settings.cpp10
5 files changed, 37 insertions, 9 deletions
diff --git a/gui/CMakeLists.txt b/gui/CMakeLists.txt
index d9d3410..3753979 100644
--- a/gui/CMakeLists.txt
+++ b/gui/CMakeLists.txt
@@ -62,6 +62,28 @@ target_compile_definitions("resources" PUBLIC
"LOCALEDIR=\"$<IF:$<BOOL:${TURNS_USE_INSTALLED_TRANSLATIONS}>,${CMAKE_INSTALL_FULL_LOCALEDIR},${CMAKE_CURRENT_BINARY_DIR}/locale>\""
)
+# Library
+
+add_library("gui_impl"
+ "src/settings.cpp"
+)
+
+target_include_directories("gui_impl" PUBLIC
+ "include"
+)
+
+target_link_libraries("gui_impl" PUBLIC
+ "resources"
+ "adwaitamm::adwaitamm"
+ "turns::mm"
+)
+
+target_compile_definitions("gui_impl" PUBLIC
+ "$<$<NOT:$<BOOL:${TURNS_USE_INSTALLED_SCHEMA_FILES}>>:SCHEMADIR=\"${CMAKE_CURRENT_BINARY_DIR}\">"
+)
+
+glib_add_schemas("gui_impl")
+
# Application
add_executable("gui" "src/main.cpp")
@@ -77,6 +99,8 @@ target_include_directories("gui" PUBLIC
)
target_link_libraries("gui" PUBLIC
+ "gui_impl"
+
"adwaitamm::adwaitamm"
"PkgConfig::glib"
"PkgConfig::glibmm"
diff --git a/gui/gschema.xml b/gui/ch.arknet.Turns.gschema.xml
index bea1f8b..bea1f8b 100644
--- a/gui/gschema.xml
+++ b/gui/ch.arknet.Turns.gschema.xml
diff --git a/gui/include/settings.hpp b/gui/include/settings.hpp
index 70e429a..668758f 100644
--- a/gui/include/settings.hpp
+++ b/gui/include/settings.hpp
@@ -3,14 +3,14 @@
* SPDX-License-Identifier: LGPL-2.1-only
*/
-#ifndef TURNS_CORE_SETTINGS_HPP
-#define TURNS_CORE_SETTINGS_HPP
+#ifndef TURNS_GUI_SETTINGS_HPP
+#define TURNS_GUI_SETTINGS_HPP
#include <glibmm/refptr.h>
#include <giomm/settings.h>
-namespace turns::core
+namespace Turns::gui
{
namespace settings::key
{
@@ -21,6 +21,6 @@ namespace turns::core
} // namespace settings::key
auto get_settings() -> Glib::RefPtr<Gio::Settings>;
-} // namespace turns::core
+} // namespace Turns::gui
#endif \ No newline at end of file
diff --git a/gui/src/main.cpp b/gui/src/main.cpp
index a4dd2ae..8c20b31 100644
--- a/gui/src/main.cpp
+++ b/gui/src/main.cpp
@@ -3,6 +3,8 @@
* SPDX-License-Identifier: LGPL-2.1-only
*/
+#include "settings.hpp"
+
#include <giomm/application.h>
#include <adwaitamm/application.hpp>
@@ -20,6 +22,8 @@ auto main(int argc, char ** argv) -> int
auto app = Adwaita::Application::create("ch.arknet.Turns", Gio::Application::Flags::HANDLES_OPEN);
+ [[maybe_unused]] auto settings = Turns::gui::get_settings();
+
return app->run(argc, argv);
}
diff --git a/gui/src/settings.cpp b/gui/src/settings.cpp
index 161a709..fed7452 100644
--- a/gui/src/settings.cpp
+++ b/gui/src/settings.cpp
@@ -3,7 +3,7 @@
* SPDX-License-Identifier: LGPL-2.1-only
*/
-#include "turns/core/settings.hpp"
+#include "settings.hpp"
#include <glibmm/refptr.h>
#include <glibmm/wrap.h>
@@ -13,15 +13,15 @@
#include <gio/gsettings.h>
-namespace turns::core
+namespace Turns::gui
{
auto get_settings() -> Glib::RefPtr<Gio::Settings>
{
auto constexpr schema_id = "ch.arknet.Turns";
-#ifdef TURNS_SETTINGS_SCHEMA_DIR
- auto source = Gio::SettingsSchemaSource::create(TURNS_SETTINGS_SCHEMA_DIR "/glib-2.0/schemas", true);
+#ifdef SCHEMADIR
+ auto source = Gio::SettingsSchemaSource::create(SCHEMADIR "/glib-2.0/schemas", true);
auto schema = source->lookup(schema_id, true);
auto settings = g_settings_new_full(Glib::unwrap(schema), nullptr, nullptr);
return Glib::wrap(settings);
@@ -30,4 +30,4 @@ namespace turns::core
#endif
}
-} // namespace turns::core
+} // namespace Turns::gui