Disable cloudproviders in RHEL

This commit is contained in:
Ondrej Holy 2023-06-27 10:09:10 +02:00
parent ebe2a94be7
commit 4feda3603b
2 changed files with 305 additions and 1 deletions

View File

@ -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

View 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