Remove libnotify dependency
Instead just talk directly to the service. This fixes *sending* a notification being blocking IO.
This commit is contained in:
parent
482efae89a
commit
c144d0468b
2
.github/workflows/ubuntu-build.yml
vendored
2
.github/workflows/ubuntu-build.yml
vendored
@ -10,7 +10,7 @@ jobs:
|
|||||||
- name: Install Dependencies
|
- name: Install Dependencies
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y meson libcanberra-dev libdbus-glib-1-dev libglib2.0-dev libgtk2.0-dev libluajit-5.1-dev libnotify-dev libpci-dev libperl-dev libproxy-dev libssl-dev python3-dev python3-cffi mono-devel desktop-file-utils
|
sudo apt-get install -y meson libcanberra-dev libdbus-glib-1-dev libglib2.0-dev libgtk2.0-dev libluajit-5.1-dev libpci-dev libperl-dev libproxy-dev libssl-dev python3-dev python3-cffi mono-devel desktop-file-utils
|
||||||
|
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: meson build -Dtext=true -Dtheme-manager=true -Dauto_features=enabled
|
run: meson build -Dtext=true -Dtheme-manager=true -Dauto_features=enabled
|
||||||
|
@ -19,7 +19,6 @@ libgmodule_dep = dependency('gmodule-2.0')
|
|||||||
libcanberra_dep = dependency('libcanberra', version: '>= 0.22',
|
libcanberra_dep = dependency('libcanberra', version: '>= 0.22',
|
||||||
required: get_option('libcanberra'))
|
required: get_option('libcanberra'))
|
||||||
dbus_glib_dep = dependency('dbus-glib-1', required: get_option('dbus'))
|
dbus_glib_dep = dependency('dbus-glib-1', required: get_option('dbus'))
|
||||||
libnotify_dep = dependency('libnotify', required: get_option('libnotify'))
|
|
||||||
|
|
||||||
global_deps = []
|
global_deps = []
|
||||||
if cc.get_id() == 'msvc'
|
if cc.get_id() == 'msvc'
|
||||||
@ -182,7 +181,6 @@ if meson.version().version_compare('>= 0.53.0')
|
|||||||
'TLS (openssl)': libssl_dep.found(),
|
'TLS (openssl)': libssl_dep.found(),
|
||||||
'Plugin Support': get_option('plugin'),
|
'Plugin Support': get_option('plugin'),
|
||||||
'DBus Support': dbus_glib_dep.found(),
|
'DBus Support': dbus_glib_dep.found(),
|
||||||
'libnotify': libnotify_dep.found(),
|
|
||||||
'libcanberra': libcanberra_dep.found(),
|
'libcanberra': libcanberra_dep.found(),
|
||||||
}, section: 'Features')
|
}, section: 'Features')
|
||||||
|
|
||||||
|
@ -19,9 +19,6 @@ option('plugin', type: 'boolean',
|
|||||||
option('dbus', type: 'feature', value: 'auto',
|
option('dbus', type: 'feature', value: 'auto',
|
||||||
description: 'Support used for single-instance and scripting interface, Unix only'
|
description: 'Support used for single-instance and scripting interface, Unix only'
|
||||||
)
|
)
|
||||||
option('libnotify', type: 'feature', value: 'auto',
|
|
||||||
description: 'Support for freedesktop notifications, Unix only'
|
|
||||||
)
|
|
||||||
option('libcanberra', type: 'feature', value: 'auto',
|
option('libcanberra', type: 'feature', value: 'auto',
|
||||||
description: 'Support for sound alerts, Unix only'
|
description: 'Support for sound alerts, Unix only'
|
||||||
)
|
)
|
||||||
|
@ -43,11 +43,7 @@ hexchat_gtk_cflags = []
|
|||||||
|
|
||||||
hexchat_gtk_ldflags = []
|
hexchat_gtk_ldflags = []
|
||||||
|
|
||||||
if libnotify_dep.found()
|
if host_machine.system() == 'windows'
|
||||||
hexchat_gtk_sources += 'notifications/notification-libnotify.c'
|
|
||||||
hexchat_gtk_deps += libnotify_dep
|
|
||||||
elif false # TODO HAVE_GTK_MAC
|
|
||||||
elif host_machine.system() == 'windows'
|
|
||||||
hexchat_gtk_sources += 'notifications/notification-windows.c'
|
hexchat_gtk_sources += 'notifications/notification-windows.c'
|
||||||
|
|
||||||
# TODO: mingw doesn't have these headers or libs
|
# TODO: mingw doesn't have these headers or libs
|
||||||
@ -57,7 +53,7 @@ elif host_machine.system() == 'windows'
|
|||||||
#)
|
#)
|
||||||
|
|
||||||
else
|
else
|
||||||
hexchat_gtk_sources += 'notifications/notification-dummy.c'
|
hexchat_gtk_sources += 'notifications/notification-freedesktop.c'
|
||||||
endif
|
endif
|
||||||
|
|
||||||
iso_codes = dependency('iso-codes', required: false)
|
iso_codes = dependency('iso-codes', required: false)
|
||||||
|
147
src/fe-gtk/notifications/notification-freedesktop.c
Normal file
147
src/fe-gtk/notifications/notification-freedesktop.c
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
/* HexChat
|
||||||
|
* Copyright (C) 2021 Patrick Griffis.
|
||||||
|
*
|
||||||
|
* 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, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include <gio/gio.h>
|
||||||
|
|
||||||
|
static GDBusProxy *fdo_notifications;
|
||||||
|
static gboolean strip_markup;
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_notify_ready (GDBusProxy *proxy, GAsyncResult *res, gpointer user_data)
|
||||||
|
{
|
||||||
|
GError *error = NULL;
|
||||||
|
guint32 notification_id;
|
||||||
|
GVariant *response = g_dbus_proxy_call_finish (proxy, res, &error);
|
||||||
|
if (error)
|
||||||
|
{
|
||||||
|
g_info ("Failed to send notification: %s", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_variant_get (response, "(u)", ¬ification_id);
|
||||||
|
g_info ("Notification sent. ID=%u", notification_id);
|
||||||
|
|
||||||
|
g_variant_unref (response);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
notification_backend_show (const char *title, const char *text)
|
||||||
|
{
|
||||||
|
GVariantBuilder params;
|
||||||
|
|
||||||
|
g_assert (fdo_notifications);
|
||||||
|
|
||||||
|
if (strip_markup)
|
||||||
|
text = g_markup_escape_text (text, -1);
|
||||||
|
|
||||||
|
g_variant_builder_init (¶ms, G_VARIANT_TYPE ("(susssasa{sv}i)"));
|
||||||
|
g_variant_builder_add (¶ms, "s", "hexchat"); /* App name */
|
||||||
|
g_variant_builder_add (¶ms, "u", 0); /* ID, 0 means don't replace */
|
||||||
|
g_variant_builder_add (¶ms, "s", ""); /* App icon (set from hints instead) */
|
||||||
|
g_variant_builder_add (¶ms, "s", title);
|
||||||
|
g_variant_builder_add (¶ms, "s", text);
|
||||||
|
g_variant_builder_add (¶ms, "as", NULL); /* Actions */
|
||||||
|
|
||||||
|
/* Hints */
|
||||||
|
g_variant_builder_open (¶ms, G_VARIANT_TYPE ("a{sv}"));
|
||||||
|
g_variant_builder_open (¶ms, G_VARIANT_TYPE ("{sv}"));
|
||||||
|
g_variant_builder_add (¶ms, "s", "desktop-entry");
|
||||||
|
g_variant_builder_add (¶ms, "v", g_variant_new_string ("io.github.Hexchat"));
|
||||||
|
g_variant_builder_close (¶ms);
|
||||||
|
g_variant_builder_close (¶ms);
|
||||||
|
|
||||||
|
g_variant_builder_add (¶ms, "i", -1); /* Expiration */
|
||||||
|
|
||||||
|
g_dbus_proxy_call (fdo_notifications,
|
||||||
|
"Notify",
|
||||||
|
g_variant_builder_end (¶ms),
|
||||||
|
G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
1000,
|
||||||
|
NULL,
|
||||||
|
(GAsyncReadyCallback)on_notify_ready,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
if (strip_markup)
|
||||||
|
g_free ((char*)text);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
notification_backend_init (const char **error)
|
||||||
|
{
|
||||||
|
GError *err = NULL;
|
||||||
|
GVariant *response;
|
||||||
|
char **capabilities;
|
||||||
|
guint i;
|
||||||
|
|
||||||
|
fdo_notifications = g_dbus_proxy_new_for_bus_sync (G_BUS_TYPE_SESSION,
|
||||||
|
G_DBUS_PROXY_FLAGS_NONE,
|
||||||
|
NULL,
|
||||||
|
"org.freedesktop.Notifications",
|
||||||
|
"/org/freedesktop/Notifications",
|
||||||
|
"org.freedesktop.Notifications",
|
||||||
|
NULL,
|
||||||
|
&err);
|
||||||
|
|
||||||
|
if (err)
|
||||||
|
goto return_error;
|
||||||
|
|
||||||
|
response = g_dbus_proxy_call_sync (fdo_notifications,
|
||||||
|
"GetCapabilities",
|
||||||
|
NULL,
|
||||||
|
G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
30,
|
||||||
|
NULL,
|
||||||
|
&err);
|
||||||
|
|
||||||
|
if (err)
|
||||||
|
{
|
||||||
|
g_clear_object (&fdo_notifications);
|
||||||
|
goto return_error;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_variant_get (response, "(^a&s)", &capabilities);
|
||||||
|
for (i = 0; capabilities[i]; i++)
|
||||||
|
{
|
||||||
|
if (strcmp (capabilities[i], "body-markup") == 0)
|
||||||
|
strip_markup = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free (capabilities);
|
||||||
|
g_variant_unref (response);
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
return_error:
|
||||||
|
*error = g_strdup (err->message);
|
||||||
|
g_error_free (err);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
notification_backend_deinit (void)
|
||||||
|
{
|
||||||
|
g_clear_object (&fdo_notifications);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
notification_backend_supported (void)
|
||||||
|
{
|
||||||
|
return fdo_notifications != NULL;
|
||||||
|
}
|
@ -1,81 +0,0 @@
|
|||||||
/* HexChat
|
|
||||||
* Copyright (C) 2015 Patrick Griffis.
|
|
||||||
*
|
|
||||||
* 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, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "config.h"
|
|
||||||
#include <glib.h>
|
|
||||||
#include <libnotify/notify.h>
|
|
||||||
|
|
||||||
#ifndef NOTIFY_CHECK_VERSION
|
|
||||||
#define NOTIFY_CHECK_VERSION(x,y,z) 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static gboolean strip_markup = FALSE;
|
|
||||||
|
|
||||||
void
|
|
||||||
notification_backend_show (const char *title, const char *text)
|
|
||||||
{
|
|
||||||
NotifyNotification *notification;
|
|
||||||
|
|
||||||
if (strip_markup)
|
|
||||||
text = g_markup_escape_text (text, -1);
|
|
||||||
|
|
||||||
#if NOTIFY_CHECK_VERSION(0,7,0)
|
|
||||||
notification = notify_notification_new (title, text, "hexchat");
|
|
||||||
#else
|
|
||||||
notification = notify_notification_new (title, text, "hexchat", NULL);
|
|
||||||
#endif
|
|
||||||
#if NOTIFY_CHECK_VERSION(0,6,0)
|
|
||||||
notify_notification_set_hint (notification, "desktop-entry", g_variant_new_string ("io.github.Hexchat"));
|
|
||||||
#else
|
|
||||||
notify_notification_set_hint_string (notification, "desktop-entry", "io.github.Hexchat");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
notify_notification_show (notification, NULL);
|
|
||||||
|
|
||||||
g_object_unref (notification);
|
|
||||||
if (strip_markup)
|
|
||||||
g_free ((char*)text);
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
notification_backend_init (const char **error)
|
|
||||||
{
|
|
||||||
GList* server_caps;
|
|
||||||
|
|
||||||
if (!notify_init (PACKAGE_NAME))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
server_caps = notify_get_server_caps ();
|
|
||||||
if (g_list_find_custom (server_caps, "body-markup", (GCompareFunc)g_strcmp0))
|
|
||||||
strip_markup = TRUE;
|
|
||||||
g_list_free_full (server_caps, g_free);
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
notification_backend_deinit (void)
|
|
||||||
{
|
|
||||||
notify_uninit ();
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
notification_backend_supported (void)
|
|
||||||
{
|
|
||||||
return notify_is_initted ();
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user