[balsa/popover: 5/5] libbalsa-vfs: New API to use with GMenu
- From: Peter Bloomfield <peterb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [balsa/popover: 5/5] libbalsa-vfs: New API to use with GMenu
- Date: Thu, 30 Jan 2020 20:23:43 +0000 (UTC)
commit 3cc84f55bf3b73ee814635aa398890f2c4c7771f
Author: Peter Bloomfield <PeterBloomfield bellsouth net>
Date: Tue Jan 21 16:28:17 2020 -0500
libbalsa-vfs: New API to use with GMenu
libbalsa/libbalsa-vfs.c | 33 ++++++++++++++++++++++-----------
libbalsa/libbalsa-vfs.h | 18 +++++++++---------
2 files changed, 31 insertions(+), 20 deletions(-)
---
diff --git a/libbalsa/libbalsa-vfs.c b/libbalsa/libbalsa-vfs.c
index 621404fcb..f2e7eec64 100644
--- a/libbalsa/libbalsa-vfs.c
+++ b/libbalsa/libbalsa-vfs.c
@@ -530,17 +530,26 @@ libbalsa_vfs_file_unlink(LibbalsaVfs * file, GError **err)
gboolean
-libbalsa_vfs_launch_app(LibbalsaVfs * file, GObject * object, GError **err)
+libbalsa_vfs_launch_app(LibbalsaVfs * file, const gchar *app_name, GError **err)
{
+ GList *app_list;
+ GList *list;
GAppInfo *app;
GList * args;
gboolean result;
g_return_val_if_fail(LIBBALSA_IS_VFS(file), FALSE);
- g_return_val_if_fail(G_IS_OBJECT(object), FALSE);
+ g_return_val_if_fail(app_name != NULL, FALSE);
+
+ app_list = g_app_info_get_all();
+ for (list = app_list; list != NULL; list = list->next) {
+ app = G_APP_INFO(list->data);
+ if (strcmp(app_name, g_app_info_get_name(app)) == 0)
+ break;
+ }
+ g_list_free_full(app_list, g_object_unref);
- app = G_APP_INFO(g_object_get_data(object, LIBBALSA_VFS_MIME_ACTION));
- if (app == NULL) {
+ if (list == NULL) {
g_set_error(err, LIBBALSA_VFS_ERROR_QUARK, -1,
_("Cannot launch, missing application"));
return FALSE;
@@ -556,14 +565,14 @@ libbalsa_vfs_launch_app(LibbalsaVfs * file, GObject * object, GError **err)
gboolean
libbalsa_vfs_launch_app_for_body(LibBalsaMessageBody * mime_body,
- GObject * object, GError **err)
+ const gchar *app_name, GError **err)
{
gchar *uri;
LibbalsaVfs * file;
gboolean result;
g_return_val_if_fail(mime_body != NULL, FALSE);
- g_return_val_if_fail(G_IS_OBJECT(object), FALSE);
+ g_return_val_if_fail(app_name != NULL, FALSE);
if (!libbalsa_message_body_save_temporary(mime_body, err))
return FALSE;
@@ -572,7 +581,7 @@ libbalsa_vfs_launch_app_for_body(LibBalsaMessageBody * mime_body,
file = libbalsa_vfs_new_from_uri(uri);
g_free(uri);
- result = libbalsa_vfs_launch_app(file, object, err);
+ result = libbalsa_vfs_launch_app(file, app_name, err);
g_object_unref(file);
return result;
@@ -611,15 +620,17 @@ gio_add_vfs_menu_item(GMenu *menu,
GAppInfo *app,
const gchar *action)
{
+ const gchar *name;
gchar *menu_label;
GMenuItem *menu_item;
- menu_label = g_strdup_printf(_("Open with %s"), g_app_info_get_name(app));
- menu_item = g_menu_item_new(menu_label, action);
+ name = g_app_info_get_name(app);
+
+ menu_label = g_strdup_printf(_("Open with %s"), name);
+ menu_item = g_menu_item_new(menu_label, NULL);
g_free(menu_label);
- g_object_set_data_full(G_OBJECT(menu_item), LIBBALSA_VFS_MIME_ACTION,
- g_object_ref(app), g_object_unref);
+ g_menu_item_set_action_and_target(menu_item, action, "s", name);
g_menu_append_item(menu, menu_item);
}
diff --git a/libbalsa/libbalsa-vfs.h b/libbalsa/libbalsa-vfs.h
index b2cf3c471..f123e7579 100644
--- a/libbalsa/libbalsa-vfs.h
+++ b/libbalsa/libbalsa-vfs.h
@@ -68,15 +68,15 @@ gint libbalsa_vfs_file_unlink(LibbalsaVfs * file,
GError **err);
/* application launch helpers */
-gboolean libbalsa_vfs_launch_app(LibbalsaVfs * file,
- GObject * object,
- GError **err);
-gboolean libbalsa_vfs_launch_app_for_body(LibBalsaMessageBody * mime_body,
- GObject * object,
- GError **err);
-void libbalsa_vfs_fill_menu_by_content_type(GMenu * menu,
- const gchar * content_type,
- const gchar * action);
+gboolean libbalsa_vfs_launch_app(LibbalsaVfs *file,
+ const gchar *app_name,
+ GError **err);
+gboolean libbalsa_vfs_launch_app_for_body(LibBalsaMessageBody *mime_body,
+ const gchar *app_name,
+ GError **err);
+void libbalsa_vfs_fill_menu_by_content_type(GMenu *menu,
+ const gchar *content_type,
+ const gchar *action);
GtkWidget * libbalsa_vfs_mime_button(LibBalsaMessageBody * mime_body,
const gchar * content_type,
GCallback callback,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]