diff --git a/.gitignore b/.gitignore index fb22883..a5b5d28 100644 --- a/.gitignore +++ b/.gitignore @@ -67,3 +67,4 @@ /gnome-control-center-45.0.tar.xz /gnome-control-center-45.1.tar.xz /gnome-control-center-45.2.tar.xz +/gnome-control-center-46.alpha.tar.xz diff --git a/0001-keyboard-Use-new-gnome-desktop-api-for-getting-defau.patch b/0001-keyboard-Use-new-gnome-desktop-api-for-getting-defau.patch deleted file mode 100644 index cf38c3a..0000000 --- a/0001-keyboard-Use-new-gnome-desktop-api-for-getting-defau.patch +++ /dev/null @@ -1,438 +0,0 @@ -From c4639980f92550a65eda96d9a564940b9a18e000 Mon Sep 17 00:00:00 2001 -From: Ray Strode -Date: Mon, 28 Aug 2023 14:40:29 -0400 -Subject: [PATCH] keyboard: Use new gnome-desktop api for getting default input - sources - -gnome-desktop now offers a way to get the default input sources for -a system when no input settings are set. - -This commit changes control-center to use that api instead of just -leaving things blank. ---- - panels/keyboard/cc-input-list-box.c | 126 ++++++++++++++++++---------- - 1 file changed, 82 insertions(+), 44 deletions(-) - -diff --git a/panels/keyboard/cc-input-list-box.c b/panels/keyboard/cc-input-list-box.c -index fc0e32092..7d9c9f014 100644 ---- a/panels/keyboard/cc-input-list-box.c -+++ b/panels/keyboard/cc-input-list-box.c -@@ -1,56 +1,57 @@ - /* cc-input-list-box.c - * - * Copyright (C) 2010 Intel, Inc - * Copyright (C) 2020 System76, Inc. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see . - * - * Author: Sergey Udaltsov - * Ian Douglas Scott - * - * SPDX-License-Identifier: GPL-2.0-or-later - */ - - #define GNOME_DESKTOP_USE_UNSTABLE_API - #include -+#include - - #include "cc-input-list-box.h" - #include "cc-input-chooser.h" - #include "cc-input-row.h" - #include "cc-input-source-ibus.h" - #include "cc-input-source-xkb.h" - - #ifdef HAVE_IBUS - #include - #endif - - #define GNOME_DESKTOP_INPUT_SOURCES_DIR "org.gnome.desktop.input-sources" - #define KEY_INPUT_SOURCES "sources" - #define KEY_MRU_SOURCES "mru-sources" - - struct _CcInputListBox { - AdwBin parent_instance; - - GtkListBoxRow *add_input_row; - GtkListBox *listbox; - GtkListBoxRow *no_inputs_row; - - GCancellable *cancellable; - - gboolean login; - gboolean login_auto_apply; - GPermission *permission; - GDBusProxy *localed; - - GSettings *input_settings; -@@ -324,112 +325,187 @@ add_input_sources (CcInputListBox *self, - - if (g_variant_n_children (sources) < 1) { - gtk_widget_set_visible (GTK_WIDGET (self->no_inputs_row), TRUE); - return; - } - - g_variant_iter_init (&iter, sources); - while (g_variant_iter_next (&iter, "(&s&s)", &type, &id)) { - g_autoptr(CcInputSource) source = NULL; - - if (g_str_equal (type, "xkb")) { - source = CC_INPUT_SOURCE (cc_input_source_xkb_new_from_id (self->xkb_info, id)); - } else if (g_str_equal (type, "ibus")) { - source = CC_INPUT_SOURCE (cc_input_source_ibus_new (id)); - #ifdef HAVE_IBUS - if (self->ibus_engines) { - IBusEngineDesc *engine_desc = g_hash_table_lookup (self->ibus_engines, id); - if (engine_desc != NULL) - cc_input_source_ibus_set_engine_desc (CC_INPUT_SOURCE_IBUS (source), engine_desc); - } - #endif - } else { - g_warning ("Unhandled input source type '%s'", type); - continue; - } - - add_input_row (self, source); - } - } - -+static gboolean -+settings_have_input_sources (CcInputListBox *self) -+{ -+ g_autoptr(GVariant) user_value = NULL; -+ -+ user_value = g_settings_get_user_value (self->input_settings, KEY_INPUT_SOURCES); -+ -+ return user_value != NULL; -+} -+ -+static void -+on_got_default_sources (GObject *source, -+ GAsyncResult *res, -+ gpointer data) -+{ -+ CcInputListBox *self = data; -+ g_autoptr (GError) error = NULL; -+ gboolean success = FALSE; -+ g_auto (GStrv) ids = NULL; -+ g_auto (GStrv) types = NULL; -+ gsize number_of_input_sources = 0; -+ gsize i; -+ -+ success = gnome_get_default_input_sources_finish (res, &ids, &types, NULL, &error); -+ -+ if (!success) { -+ g_warning ("Could not fetch default input sources: %s", error->message); -+ gtk_widget_set_visible (GTK_WIDGET (self->no_inputs_row), TRUE); -+ return; -+ } -+ -+ number_of_input_sources = g_strv_length (ids); -+ -+ if (number_of_input_sources == 0) { -+ gtk_widget_set_visible (GTK_WIDGET (self->no_inputs_row), TRUE); -+ return; -+ } -+ -+ for (i = 0; ids[i] != NULL && types[i] != NULL; i++) { -+ g_autoptr(CcInputSource) source = NULL; -+ const char *id = ids[i]; -+ const char *type = types[i]; -+ -+ if (g_str_equal (type, "xkb")) { -+ source = CC_INPUT_SOURCE (cc_input_source_xkb_new_from_id (self->xkb_info, id)); -+ } else if (g_str_equal (type, "ibus")) { -+ source = CC_INPUT_SOURCE (cc_input_source_ibus_new (id)); -+#ifdef HAVE_IBUS -+ if (self->ibus_engines) { -+ IBusEngineDesc *engine_desc = g_hash_table_lookup (self->ibus_engines, id); -+ if (engine_desc != NULL) -+ cc_input_source_ibus_set_engine_desc (CC_INPUT_SOURCE_IBUS (source), engine_desc); -+ } -+#endif -+ } else { -+ g_warning ("Unhandled input source type '%s'", type); -+ continue; -+ } -+ -+ add_input_row (self, source); -+ } -+} -+ -+static void -+add_input_sources_from_defaults (CcInputListBox *self) -+{ -+ gnome_get_default_input_sources (self->cancellable, on_got_default_sources, self); -+} -+ - static void - add_input_sources_from_settings (CcInputListBox *self) - { - g_autoptr(GVariant) sources = NULL; - sources = g_settings_get_value (self->input_settings, "sources"); - add_input_sources (self, sources); - } - - static void - clear_input_sources (CcInputListBox *self) - { - GtkWidget *child; - - child = gtk_widget_get_first_child (GTK_WIDGET (self->listbox)); - while (child) { - GtkWidget *next = gtk_widget_get_next_sibling (child); - - if (CC_IS_INPUT_ROW (child)) - gtk_list_box_remove (self->listbox, GTK_WIDGET (child)); - - child = next; - } - } - - static CcInputRow * - get_row_by_source (CcInputListBox *self, CcInputSource *source) - { - GtkWidget *child; - - for (child = gtk_widget_get_first_child (GTK_WIDGET (self->listbox)); - child; - child = gtk_widget_get_next_sibling (child)) { - CcInputRow *row; - - if (!CC_IS_INPUT_ROW (child)) - continue; - row = CC_INPUT_ROW (child); - - if (cc_input_source_matches (source, cc_input_row_get_source (row))) - return row; - } - - return NULL; - } - - static void - input_sources_changed (CcInputListBox *self, - const gchar *key) - { - CcInputRow *selected; - g_autoptr(CcInputSource) source = NULL; - -+ if (!settings_have_input_sources (self)) { -+ clear_input_sources (self); -+ add_input_sources_from_defaults (self); -+ return; -+ } -+ - selected = CC_INPUT_ROW (gtk_list_box_get_selected_row (self->listbox)); - if (selected) - source = g_object_ref (cc_input_row_get_source (selected)); - clear_input_sources (self); - add_input_sources_from_settings (self); - if (source != NULL) { - CcInputRow *row = get_row_by_source (self, source); - if (row != NULL) - gtk_list_box_select_row (self->listbox, GTK_LIST_BOX_ROW (row)); - } - } - - static void - set_input_settings (CcInputListBox *self) - { - GVariantBuilder builder; - GtkWidget *child; - GVariant *value; - GVariant *previous_value = g_settings_get_value (self->input_settings, KEY_INPUT_SOURCES); - - g_variant_builder_init (&builder, G_VARIANT_TYPE ("a(ss)")); - - for (child = gtk_widget_get_first_child (GTK_WIDGET (self->listbox)); - child; - child = gtk_widget_get_next_sibling (child)) { - CcInputRow *row; - CcInputSource *source; - - if (!CC_IS_INPUT_ROW (child)) - continue; -@@ -633,101 +709,60 @@ move_input_permission_cb (GObject *source, GAsyncResult *res, gpointer user_data - RowData *data = user_data; - if (permission_acquired (G_PERMISSION (source), res, "move input")) - do_move_input (data->panel, data->source, data->dest); - } - - static void - move_input (CcInputListBox *self, - CcInputRow *source, - CcInputRow *dest) - { - if (!self->login) { - do_move_input (self, source, dest); - } else if (g_permission_get_allowed (self->permission)) { - do_move_input (self, source, dest); - } else if (g_permission_get_can_acquire (self->permission)) { - g_permission_acquire_async (self->permission, - self->cancellable, - move_input_permission_cb, - row_data_new (self, source, dest)); - } - } - - static void - input_row_activated_cb (CcInputListBox *self, GtkListBoxRow *row) - { - if (row == self->add_input_row) { - add_input (self); - } - } - --static void --add_input_sources_from_localed (CcInputListBox *self) --{ -- g_autoptr(GVariant) layout_property = NULL; -- g_autoptr(GVariant) variant_property = NULL; -- const gchar *s; -- g_auto(GStrv) layouts = NULL; -- g_auto(GStrv) variants = NULL; -- gint i, n; -- -- if (!self->localed) -- return; -- -- layout_property = g_dbus_proxy_get_cached_property (self->localed, "X11Layout"); -- if (layout_property) { -- s = g_variant_get_string (layout_property, NULL); -- layouts = g_strsplit (s, ",", -1); -- } -- -- variant_property = g_dbus_proxy_get_cached_property (self->localed, "X11Variant"); -- if (variant_property) { -- s = g_variant_get_string (variant_property, NULL); -- if (s && *s) -- variants = g_strsplit (s, ",", -1); -- } -- -- if (variants && variants[0]) -- n = MIN (g_strv_length (layouts), g_strv_length (variants)); -- else if (layouts && layouts[0]) -- n = g_strv_length (layouts); -- else -- n = 0; -- -- for (i = 0; i < n && layouts[i][0]; i++) { -- const char *variant = variants ? variants[i] : NULL; -- g_autoptr(CcInputSourceXkb) source = cc_input_source_xkb_new (self->xkb_info, layouts[i], variant); -- add_input_row (self, CC_INPUT_SOURCE (source)); -- } -- gtk_widget_set_visible (GTK_WIDGET (self->no_inputs_row), n == 0); --} -- - static void - set_localed_input (CcInputListBox *self) - { - g_autoptr(GString) layouts = NULL; - g_autoptr(GString) variants = NULL; - GtkWidget *child; - - layouts = g_string_new (""); - variants = g_string_new (""); - - for (child = gtk_widget_get_first_child (GTK_WIDGET (self->listbox)); - child; - child = gtk_widget_get_next_sibling (child)) { - CcInputRow *row; - CcInputSourceXkb *source; - g_autofree gchar *id = NULL; - const gchar *l, *v; - - if (!CC_IS_INPUT_ROW (child)) - continue; - row = CC_INPUT_ROW (child); - - if (!CC_IS_INPUT_SOURCE_XKB (cc_input_row_get_source (row))) - continue; - source = CC_INPUT_SOURCE_XKB (cc_input_row_get_source (row)); - - id = cc_input_source_xkb_get_id (source); - if (gnome_xkb_info_get_layout_info (self->xkb_info, id, NULL, NULL, &l, &v)) { - if (layouts->str[0]) { - g_string_append_c (layouts, ','); -@@ -786,61 +821,64 @@ cc_input_list_box_init (CcInputListBox *self) - gtk_widget_init_template (GTK_WIDGET (self)); - - self->login = FALSE; - self->login_auto_apply = FALSE; - self->localed = NULL; - self->permission = NULL; - - self->cancellable = g_cancellable_new(); - - self->input_settings = g_settings_new (GNOME_DESKTOP_INPUT_SOURCES_DIR); - - self->xkb_info = gnome_xkb_info_new (); - - #ifdef HAVE_IBUS - ibus_init (); - if (!self->ibus) { - self->ibus = ibus_bus_new_async (); - if (ibus_bus_is_connected (self->ibus)) - fetch_ibus_engines (self); - else - g_signal_connect_object (self->ibus, "connected", - G_CALLBACK (fetch_ibus_engines), self, - G_CONNECT_SWAPPED); - } - maybe_start_ibus (); - #endif - - g_signal_connect_object (self->input_settings, "changed::" KEY_INPUT_SOURCES, - G_CALLBACK (input_sources_changed), self, G_CONNECT_SWAPPED); - -- add_input_sources_from_settings (self); -+ if (!settings_have_input_sources (self)) -+ add_input_sources_from_defaults (self); -+ else -+ add_input_sources_from_settings (self); - } - - void - cc_input_list_box_set_login (CcInputListBox *self, gboolean login) - { - self->login = login; - clear_input_sources (self); -- if (login) -- add_input_sources_from_localed (self); -+ if (login || !settings_have_input_sources (self)) -+ add_input_sources_from_defaults (self); - else - add_input_sources_from_settings (self); - } - - void - cc_input_list_box_set_login_auto_apply (CcInputListBox *self, gboolean login_auto_apply) - { - self->login_auto_apply = login_auto_apply; - } - - void - cc_input_list_box_set_localed (CcInputListBox *self, GDBusProxy *localed) - { - self->localed = localed; - } - - void - cc_input_list_box_set_permission (CcInputListBox *self, GPermission *permission) - { - self->permission = permission; - } --- -2.41.0.rc2 - diff --git a/gnome-control-center-c99.patch b/gnome-control-center-c99.patch deleted file mode 100644 index 86f3218..0000000 --- a/gnome-control-center-c99.patch +++ /dev/null @@ -1,32 +0,0 @@ -commit 13c939659a844049ddc68e90c7830bf96ebe174d -Author: Marco Melorio -Date: Thu Oct 5 19:21:39 2023 +0200 - - misc: Fix incompatible type warnings - -diff --git a/panels/datetime/cc-datetime-panel.c b/panels/datetime/cc-datetime-panel.c -index 3544411d04431411..204b8ce44dc3ddd6 100644 ---- a/panels/datetime/cc-datetime-panel.c -+++ b/panels/datetime/cc-datetime-panel.c -@@ -695,7 +695,7 @@ list_box_row_activated (CcDateTimePanel *self, - } - else if (row == GTK_LIST_BOX_ROW (self->timezone_row)) - { -- present_window (self, self->timezone_dialog); -+ present_window (self, GTK_WINDOW (self->timezone_dialog)); - } - } - -diff --git a/panels/network/net-device-wifi.c b/panels/network/net-device-wifi.c -index c4792e194ef76499..dbc79b7466339c87 100644 ---- a/panels/network/net-device-wifi.c -+++ b/panels/network/net-device-wifi.c -@@ -773,7 +773,7 @@ net_device_wifi_dispose (GObject *object) - NetDeviceWifi *self = NET_DEVICE_WIFI (object); - - if (self->hotspot_dialog) { -- gtk_window_destroy (self->hotspot_dialog); -+ gtk_window_destroy (GTK_WINDOW (self->hotspot_dialog)); - self->hotspot_dialog = NULL; - } - diff --git a/gnome-control-center.spec b/gnome-control-center.spec index f78c866..fd5c2a1 100644 --- a/gnome-control-center.spec +++ b/gnome-control-center.spec @@ -1,5 +1,5 @@ %define gnome_online_accounts_version 3.25.3 -%define glib2_version 2.75.0 +%define glib2_version 2.76.6 %define gnome_desktop_version 44.0-7 %define gsd_version 41.0 %define gsettings_desktop_schemas_version 42~alpha @@ -15,16 +15,13 @@ %bcond malcontent %[!0%{?rhel}] Name: gnome-control-center -Version: 45.2 +Version: 46~alpha Release: %autorelease Summary: Utilities to configure the GNOME desktop License: GPL-2.0-or-later AND CC0-1.0 URL: https://gitlab.gnome.org/GNOME/gnome-control-center/ -Source0: https://download.gnome.org/sources/%{name}/45/%{name}-%{tarball_version}.tar.xz -Patch0: gnome-control-center-c99.patch - -Patch: 0001-keyboard-Use-new-gnome-desktop-api-for-getting-defau.patch +Source0: https://download.gnome.org/sources/%{name}/46/%{name}-%{tarball_version}.tar.xz BuildRequires: desktop-file-utils BuildRequires: docbook-style-xsl libxslt @@ -56,6 +53,7 @@ BuildRequires: pkgconfig(libnma-gtk4) BuildRequires: pkgconfig(libpulse) BuildRequires: pkgconfig(libpulse-mainloop-glib) BuildRequires: pkgconfig(libsecret-1) +BuildRequires: pkgconfig(libsoup-3.0) BuildRequires: pkgconfig(libxml-2.0) %if %{with malcontent} BuildRequires: pkgconfig(malcontent-0) diff --git a/sources b/sources index de7c3d9..9560f16 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (gnome-control-center-45.2.tar.xz) = 08749b6246e401982bd9c0088a5e2e517c7e8e2cea2fdce5fd29841a6c73b6bad9fba2d2af726f31cde3b64705cc9db22982673117f170cea27bae48911775de +SHA512 (gnome-control-center-46.alpha.tar.xz) = f1041c518663b54a18f155524bd8e8c7d6984cdfec4f9daef3d5a4ece840ddee0642b02e40bfd821b4dad71264f699530498dbbe3b914e7b24acf912f37e6287