view src/sys/glib/dark_theme.cc @ 253:b3549da699a6

*: ooooh! stupid big commit! oops
author Paper <paper@paper.us.eu.org>
date Tue, 06 Feb 2024 16:56:32 -0500
parents c130f47f6f48
children 862d0d8619f6
line wrap: on
line source

#include <gio/gio.h>
#include <cstring>
#include <string_view>

namespace glib {

bool IsInDarkTheme() {
	bool success = false;

	GSettings* settings = ::g_settings_new("org.gnome.desktop.interface");
	if (!settings)
		return false;

	GVariant* val = ::g_settings_get_value(settings, "color-scheme");
	if (!val)
		return false;

	const gchar* str;
	::g_variant_get(val, "&s", &str); /* should not be freed */
	if (!str) /* how */
		return false;

	success |= !std::strcmp(str, "prefer-dark");

	::g_variant_unref(val);

	if (success) {
		::g_object_unref(settings);
		return success;
	}

	GVariant* gtk_theme = ::g_settings_get_value(settings, "gtk-theme");
	if (!gtk_theme)
		return false;

	const gchar* gtk_theme_str;
	::g_variant_get(gtk_theme, "&s", gtk_theme_str);
	if (!gtk_theme_str)
		return false;

	static constexpr std::string_view suffix = "-dark";

	size_t gtk_theme_len = strlen(gtk_theme_str);

	success |= !std::strncmp(gtk_theme_str + gtk_theme_len - suffix.length(), suffix.data(), suffix.length());

	::g_object_unref(settings);
	return success;
}

}