Disable cloudproviders in RHEL
This commit is contained in:
parent
ebe2a94be7
commit
4feda3603b
@ -1,3 +1,5 @@
|
||||
%bcond cloudproviders %{undefined rhel}
|
||||
|
||||
%global glib2_version 2.72.1
|
||||
%global gnome_autoar_version 0.4.0
|
||||
%global gtk4_version 4.10.3
|
||||
@ -7,13 +9,15 @@
|
||||
|
||||
Name: nautilus
|
||||
Version: 44.2.1
|
||||
Release: 1%{?dist}
|
||||
Release: 2%{?dist}
|
||||
Summary: File manager for GNOME
|
||||
|
||||
License: GPL-3.0-or-later
|
||||
URL: https://wiki.gnome.org/Apps/Nautilus
|
||||
Source0: https://download.gnome.org/sources/%{name}/44/%{name}-%{tarball_version}.tar.xz
|
||||
|
||||
Patch0: sidebar-Make-cloudproviders-dependency-optional-agai.patch
|
||||
|
||||
BuildRequires: desktop-file-utils
|
||||
BuildRequires: gcc
|
||||
BuildRequires: gettext
|
||||
@ -29,7 +33,9 @@ BuildRequires: pkgconfig(gstreamer-pbutils-1.0)
|
||||
BuildRequires: pkgconfig(gstreamer-tag-1.0)
|
||||
BuildRequires: pkgconfig(gtk4) >= %{gtk4_version}
|
||||
BuildRequires: pkgconfig(libadwaita-1) >= %{libadwaita_version}
|
||||
%if %{with cloudproviders}
|
||||
BuildRequires: pkgconfig(cloudproviders)
|
||||
%endif
|
||||
BuildRequires: pkgconfig(libportal)
|
||||
BuildRequires: pkgconfig(libportal-gtk4)
|
||||
BuildRequires: pkgconfig(libseccomp)
|
||||
@ -89,6 +95,7 @@ sed -i '/-Werror/d' meson.build
|
||||
-Dextensions=true \
|
||||
-Dintrospection=true \
|
||||
-Dselinux=true \
|
||||
-Dcloudproviders=%{?with_cloudproviders:true}%{?!with_cloudproviders:false}
|
||||
%{nil}
|
||||
%meson_build
|
||||
|
||||
@ -139,6 +146,9 @@ desktop-file-validate $RPM_BUILD_ROOT%{_datadir}/applications/*.desktop
|
||||
%doc %{_datadir}/doc/nautilus/
|
||||
|
||||
%changelog
|
||||
* Mon Jun 26 2023 Ondrej Holy <oholy@redhat.com> - 44.2.1-2
|
||||
- Disable cloudproviders in RHEL
|
||||
|
||||
* Mon Jun 05 2023 Kalev Lember <klember@redhat.com> - 44.2.1-1
|
||||
- Update to 44.2.1
|
||||
|
||||
|
294
sidebar-Make-cloudproviders-dependency-optional-agai.patch
Normal file
294
sidebar-Make-cloudproviders-dependency-optional-agai.patch
Normal file
@ -0,0 +1,294 @@
|
||||
From ed6c79ecfa0d5303694015cb7509091038b98c76 Mon Sep 17 00:00:00 2001
|
||||
From: Ondrej Holy <oholy@redhat.com>
|
||||
Date: Thu, 22 Jun 2023 10:03:07 +0200
|
||||
Subject: [PATCH] sidebar: Make cloudproviders dependency optional again
|
||||
|
||||
This partially reverts commit 673e6b157a125e321049d4abea3bb5a6ddc7570e.
|
||||
It turns out that the cloudproviders dependency is not desired for RHEL.
|
||||
---
|
||||
meson.build | 6 +++++-
|
||||
meson_options.txt | 6 ++++++
|
||||
src/gtk/nautilusgtkplacessidebar.c | 30 ++++++++++++++++++++++++++++++
|
||||
src/gtk/nautilusgtksidebarrow.c | 10 ++++++++++
|
||||
4 files changed, 51 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/meson.build b/meson.build
|
||||
index 51f8350ad..a123b5062 100644
|
||||
--- a/meson.build
|
||||
+++ b/meson.build
|
||||
@@ -114,7 +114,10 @@ if get_option('selinux')
|
||||
endif
|
||||
tracker_sparql = dependency('tracker-sparql-3.0')
|
||||
xml = dependency('libxml-2.0', version: '>= 2.7.8')
|
||||
-cloudproviders = dependency('cloudproviders', version: '>= 0.3.1')
|
||||
+cloudproviders = []
|
||||
+if get_option('cloudproviders')
|
||||
+ cloudproviders = dependency('cloudproviders', version: '>= 0.3.1')
|
||||
+endif
|
||||
gi_docgen = find_program('gi-docgen', required: get_option('docs'))
|
||||
|
||||
####################
|
||||
@@ -156,6 +159,7 @@ conf.set_quoted('VERSION', version_string)
|
||||
conf.set('ENABLE_PACKAGEKIT', get_option('packagekit'))
|
||||
conf.set('ENABLE_PROFILING', get_option('profiling'))
|
||||
conf.set('HAVE_SELINUX', get_option('selinux'))
|
||||
+conf.set('HAVE_CLOUDPROVIDERS', get_option('cloudproviders'))
|
||||
|
||||
#############################################################
|
||||
# config.h dependency, add to target dependencies if needed #
|
||||
diff --git a/meson_options.txt b/meson_options.txt
|
||||
index fce5f16f9..ebc0ed640 100644
|
||||
--- a/meson_options.txt
|
||||
+++ b/meson_options.txt
|
||||
@@ -38,6 +38,12 @@ option(
|
||||
value: false,
|
||||
description: 'Enable SELinux context support in file properties dialog',
|
||||
)
|
||||
+option(
|
||||
+ 'cloudproviders',
|
||||
+ type: 'boolean',
|
||||
+ value: true,
|
||||
+ description: 'Enable the cloudproviders support',
|
||||
+)
|
||||
################
|
||||
# End features #
|
||||
################
|
||||
diff --git a/src/gtk/nautilusgtkplacessidebar.c b/src/gtk/nautilusgtkplacessidebar.c
|
||||
index f270588bb..0ae39f12c 100644
|
||||
--- a/src/gtk/nautilusgtkplacessidebar.c
|
||||
+++ b/src/gtk/nautilusgtkplacessidebar.c
|
||||
@@ -27,7 +27,9 @@
|
||||
#include "nautilus-enum-types.h"
|
||||
|
||||
#include <gio/gio.h>
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
#include <cloudproviders.h>
|
||||
+#endif
|
||||
|
||||
#include "nautilusgtkplacessidebarprivate.h"
|
||||
#include "nautilusgtksidebarrowprivate.h"
|
||||
@@ -109,8 +111,10 @@ struct _NautilusGtkPlacesSidebar {
|
||||
|
||||
GActionGroup *row_actions;
|
||||
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
CloudProvidersCollector *cloud_manager;
|
||||
GList *unready_accounts;
|
||||
+#endif
|
||||
|
||||
GVolumeMonitor *volume_monitor;
|
||||
GtkSettings *gtk_settings;
|
||||
@@ -395,7 +399,11 @@ add_place (NautilusGtkPlacesSidebar *sidebar,
|
||||
GDrive *drive,
|
||||
GVolume *volume,
|
||||
GMount *mount,
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
CloudProvidersAccount *cloud_provider_account,
|
||||
+#else
|
||||
+ gpointer *cloud_provider_account,
|
||||
+#endif
|
||||
const int index,
|
||||
const char *tooltip)
|
||||
{
|
||||
@@ -435,7 +443,9 @@ add_place (NautilusGtkPlacesSidebar *sidebar,
|
||||
"drive", drive,
|
||||
"volume", volume,
|
||||
"mount", mount,
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
"cloud-provider-account", cloud_provider_account,
|
||||
+#endif
|
||||
NULL);
|
||||
|
||||
eject_button = nautilus_gtk_sidebar_row_get_eject_button (NAUTILUS_GTK_SIDEBAR_ROW (row));
|
||||
@@ -852,6 +862,8 @@ update_trash_icon (NautilusGtkPlacesSidebar *sidebar)
|
||||
}
|
||||
}
|
||||
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
+
|
||||
static gboolean
|
||||
create_cloud_provider_account_row (NautilusGtkPlacesSidebar *sidebar,
|
||||
CloudProvidersAccount *account)
|
||||
@@ -929,6 +941,8 @@ on_account_updated (GObject *object,
|
||||
}
|
||||
}
|
||||
|
||||
+#endif
|
||||
+
|
||||
static void
|
||||
update_places (NautilusGtkPlacesSidebar *sidebar)
|
||||
{
|
||||
@@ -949,10 +963,12 @@ update_places (NautilusGtkPlacesSidebar *sidebar)
|
||||
GList *network_mounts, *network_volumes;
|
||||
GIcon *new_bookmark_icon;
|
||||
GtkWidget *child;
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
GList *cloud_providers;
|
||||
GList *cloud_providers_accounts;
|
||||
CloudProvidersAccount *cloud_provider_account;
|
||||
CloudProvidersProvider *cloud_provider;
|
||||
+#endif
|
||||
|
||||
/* save original selection */
|
||||
selected = gtk_list_box_get_selected_row (GTK_LIST_BOX (sidebar->list_box));
|
||||
@@ -1057,6 +1073,7 @@ update_places (NautilusGtkPlacesSidebar *sidebar)
|
||||
add_application_shortcuts (sidebar);
|
||||
|
||||
/* Cloud providers */
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
cloud_providers = cloud_providers_collector_get_providers (sidebar->cloud_manager);
|
||||
for (l = sidebar->unready_accounts; l != NULL; l = l->next)
|
||||
{
|
||||
@@ -1091,6 +1108,7 @@ update_places (NautilusGtkPlacesSidebar *sidebar)
|
||||
|
||||
}
|
||||
}
|
||||
+#endif
|
||||
|
||||
/* go through all connected drives */
|
||||
drives = g_volume_monitor_get_connected_drives (sidebar->volume_monitor);
|
||||
@@ -3193,6 +3211,7 @@ on_row_popover_destroy (GtkWidget *row_popover,
|
||||
sidebar->popover = NULL;
|
||||
}
|
||||
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
static void
|
||||
build_popup_menu_using_gmenu (NautilusGtkSidebarRow *row)
|
||||
{
|
||||
@@ -3258,6 +3277,7 @@ build_popup_menu_using_gmenu (NautilusGtkSidebarRow *row)
|
||||
g_object_unref (cloud_provider_account);
|
||||
}
|
||||
}
|
||||
+#endif
|
||||
|
||||
/* Constructs the popover for the sidebar row if needed */
|
||||
static void
|
||||
@@ -3278,7 +3298,9 @@ create_row_popover (NautilusGtkPlacesSidebar *sidebar,
|
||||
gboolean show_properties;
|
||||
g_autoptr (GFile) trash = NULL;
|
||||
gboolean is_trash;
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
CloudProvidersAccount *cloud_provider_account;
|
||||
+#endif
|
||||
|
||||
g_object_get (row,
|
||||
"place-type", &type,
|
||||
@@ -3302,6 +3324,7 @@ create_row_popover (NautilusGtkPlacesSidebar *sidebar,
|
||||
is_trash = FALSE;
|
||||
}
|
||||
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
g_object_get (row, "cloud-provider-account", &cloud_provider_account, NULL);
|
||||
|
||||
if (cloud_provider_account)
|
||||
@@ -3309,6 +3332,7 @@ create_row_popover (NautilusGtkPlacesSidebar *sidebar,
|
||||
build_popup_menu_using_gmenu (row);
|
||||
return;
|
||||
}
|
||||
+#endif
|
||||
|
||||
action = g_action_map_lookup_action (G_ACTION_MAP (sidebar->row_actions), "remove");
|
||||
g_simple_action_set_enabled (G_SIMPLE_ACTION (action), (type == NAUTILUS_GTK_PLACES_BOOKMARK));
|
||||
@@ -3979,11 +4003,13 @@ nautilus_gtk_places_sidebar_init (NautilusGtkPlacesSidebar *sidebar)
|
||||
sidebar->show_desktop = show_desktop;
|
||||
|
||||
/* Cloud providers */
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
sidebar->cloud_manager = cloud_providers_collector_dup_singleton ();
|
||||
g_signal_connect_swapped (sidebar->cloud_manager,
|
||||
"providers-changed",
|
||||
G_CALLBACK (update_places),
|
||||
sidebar);
|
||||
+#endif
|
||||
|
||||
/* populate the sidebar */
|
||||
update_places (sidebar);
|
||||
@@ -4100,7 +4126,9 @@ static void
|
||||
nautilus_gtk_places_sidebar_dispose (GObject *object)
|
||||
{
|
||||
NautilusGtkPlacesSidebar *sidebar;
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
GList *l;
|
||||
+#endif
|
||||
|
||||
sidebar = NAUTILUS_GTK_PLACES_SIDEBAR (object);
|
||||
|
||||
@@ -4164,6 +4192,7 @@ nautilus_gtk_places_sidebar_dispose (GObject *object)
|
||||
|
||||
g_clear_handle_id (&sidebar->hover_timer_id, g_source_remove);
|
||||
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
for (l = sidebar->unready_accounts; l != NULL; l = l->next)
|
||||
{
|
||||
g_signal_handlers_disconnect_by_data (l->data, sidebar);
|
||||
@@ -4181,6 +4210,7 @@ nautilus_gtk_places_sidebar_dispose (GObject *object)
|
||||
g_object_unref (sidebar->cloud_manager);
|
||||
sidebar->cloud_manager = NULL;
|
||||
}
|
||||
+#endif
|
||||
|
||||
G_OBJECT_CLASS (nautilus_gtk_places_sidebar_parent_class)->dispose (object);
|
||||
}
|
||||
diff --git a/src/gtk/nautilusgtksidebarrow.c b/src/gtk/nautilusgtksidebarrow.c
|
||||
index 4fa69358b..f7e2f7657 100644
|
||||
--- a/src/gtk/nautilusgtksidebarrow.c
|
||||
+++ b/src/gtk/nautilusgtksidebarrow.c
|
||||
@@ -26,7 +26,9 @@
|
||||
/* For section and place type enums */
|
||||
#include "nautilusgtkplacessidebarprivate.h"
|
||||
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
#include <cloudproviders.h>
|
||||
+#endif
|
||||
|
||||
struct _NautilusGtkSidebarRow
|
||||
{
|
||||
@@ -83,6 +85,8 @@ enum
|
||||
|
||||
static GParamSpec *properties [LAST_PROP];
|
||||
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
+
|
||||
static void
|
||||
cloud_row_update (NautilusGtkSidebarRow *self)
|
||||
{
|
||||
@@ -124,6 +128,8 @@ cloud_row_update (NautilusGtkSidebarRow *self)
|
||||
g_object_unref (end_icon);
|
||||
}
|
||||
|
||||
+#endif
|
||||
+
|
||||
static void
|
||||
nautilus_gtk_sidebar_row_get_property (GObject *object,
|
||||
guint prop_id,
|
||||
@@ -322,6 +328,7 @@ nautilus_gtk_sidebar_row_set_property (GObject *object,
|
||||
break;
|
||||
|
||||
case PROP_CLOUD_PROVIDER_ACCOUNT:
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
if (self->cloud_provider_account != NULL)
|
||||
g_signal_handlers_disconnect_by_data (self->cloud_provider_account, self);
|
||||
|
||||
@@ -336,6 +343,7 @@ nautilus_gtk_sidebar_row_set_property (GObject *object,
|
||||
g_signal_connect_swapped (self->cloud_provider_account, "notify::status-details",
|
||||
G_CALLBACK (cloud_row_update), self);
|
||||
}
|
||||
+#endif
|
||||
break;
|
||||
|
||||
case PROP_PLACEHOLDER:
|
||||
@@ -464,9 +472,11 @@ nautilus_gtk_sidebar_row_finalize (GObject *object)
|
||||
g_clear_object (&self->drive);
|
||||
g_clear_object (&self->volume);
|
||||
g_clear_object (&self->mount);
|
||||
+#ifdef HAVE_CLOUDPROVIDERS
|
||||
if (self->cloud_provider_account != NULL)
|
||||
g_signal_handlers_disconnect_by_data (self->cloud_provider_account, self);
|
||||
g_clear_object (&self->cloud_provider_account);
|
||||
+#endif
|
||||
|
||||
G_OBJECT_CLASS (nautilus_gtk_sidebar_row_parent_class)->finalize (object);
|
||||
}
|
||||
--
|
||||
2.40.0
|
||||
|
Loading…
Reference in New Issue
Block a user