Coding style fixups

This commit adjusts the app chooser code to GTK+ coding style:
- line up prototypes
- remove some excess {}
- remove tabs and trailing whitespace
- add docs
This commit is contained in:
Matthias Clasen 2010-11-24 18:32:05 -05:00
parent f64448473e
commit a498d9a9ba
17 changed files with 954 additions and 750 deletions

View File

@ -21,7 +21,7 @@
* Authors: Cosimo Cecchi <ccecchi@redhat.com> * Authors: Cosimo Cecchi <ccecchi@redhat.com>
*/ */
#include <config.h> #include "config.h"
#include "gtkappchooser.h" #include "gtkappchooser.h"
@ -39,11 +39,11 @@ gtk_app_chooser_default_init (GtkAppChooserIface *iface)
GParamSpec *pspec; GParamSpec *pspec;
pspec = g_param_spec_string ("content-type", pspec = g_param_spec_string ("content-type",
P_("Content type"), P_("Content type"),
P_("The content type used by the open with object"), P_("The content type used by the open with object"),
NULL, NULL,
G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE |
G_PARAM_STATIC_STRINGS); G_PARAM_STATIC_STRINGS);
g_object_interface_install_property (iface, pspec); g_object_interface_install_property (iface, pspec);
} }
@ -55,18 +55,37 @@ gtk_app_chooser_get_content_type (GtkAppChooser *self)
g_return_val_if_fail (GTK_IS_APP_CHOOSER (self), NULL); g_return_val_if_fail (GTK_IS_APP_CHOOSER (self), NULL);
g_object_get (self, g_object_get (self,
"content-type", &retval, "content-type", &retval,
NULL); NULL);
return retval; return retval;
} }
/**
* gtk_app_chooser_get_app_info:
* @self: a #GtkAppChooser
*
* Returns the currently selected application.
*
* Returns: (transfer full): a #GAppInfo for the currently selected
* application, or %NULL if none is selected. Free with g_object_unref().
*
* Since: 3.0
*/
GAppInfo * GAppInfo *
gtk_app_chooser_get_app_info (GtkAppChooser *self) gtk_app_chooser_get_app_info (GtkAppChooser *self)
{ {
return GTK_APP_CHOOSER_GET_IFACE (self)->get_app_info (self); return GTK_APP_CHOOSER_GET_IFACE (self)->get_app_info (self);
} }
/**
* gtk_app_chooser_refresh:
* @self: a #GtkAppChooser
*
* Reload the list of applications.
*
* Since: 3.0
*/
void void
gtk_app_chooser_refresh (GtkAppChooser *self) gtk_app_chooser_refresh (GtkAppChooser *self)
{ {

View File

@ -33,20 +33,17 @@
G_BEGIN_DECLS G_BEGIN_DECLS
#define GTK_TYPE_APP_CHOOSER\ #define GTK_TYPE_APP_CHOOSER (gtk_app_chooser_get_type ())
(gtk_app_chooser_get_type ()) #define GTK_APP_CHOOSER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER, GtkAppChooser))
#define GTK_APP_CHOOSER(obj)\ #define GTK_IS_APP_CHOOSER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER))
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER, GtkAppChooser))
#define GTK_IS_APP_CHOOSER(obj)\
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER))
typedef struct _GtkAppChooser GtkAppChooser; typedef struct _GtkAppChooser GtkAppChooser;
GType gtk_app_chooser_get_type () G_GNUC_CONST; GType gtk_app_chooser_get_type (void) G_GNUC_CONST;
GAppInfo * gtk_app_chooser_get_app_info (GtkAppChooser *self); GAppInfo * gtk_app_chooser_get_app_info (GtkAppChooser *self);
gchar * gtk_app_chooser_get_content_type (GtkAppChooser *self); gchar * gtk_app_chooser_get_content_type (GtkAppChooser *self);
void gtk_app_chooser_refresh (GtkAppChooser *self); void gtk_app_chooser_refresh (GtkAppChooser *self);
G_END_DECLS G_END_DECLS

View File

@ -21,7 +21,7 @@
* Authors: Cosimo Cecchi <ccecchi@redhat.com> * Authors: Cosimo Cecchi <ccecchi@redhat.com>
*/ */
#include <config.h> #include "config.h"
#include "gtkappchoosercombobox.h" #include "gtkappchoosercombobox.h"
@ -73,14 +73,14 @@ custom_app_data_free (gpointer boxed)
#define CUSTOM_COMBO_DATA_TYPE custom_app_combo_data_get_type() #define CUSTOM_COMBO_DATA_TYPE custom_app_combo_data_get_type()
G_DEFINE_BOXED_TYPE (CustomAppComboData, custom_app_combo_data, G_DEFINE_BOXED_TYPE (CustomAppComboData, custom_app_combo_data,
custom_app_data_copy, custom_app_data_copy,
custom_app_data_free); custom_app_data_free);
static void app_chooser_iface_init (GtkAppChooserIface *iface); static void app_chooser_iface_init (GtkAppChooserIface *iface);
G_DEFINE_TYPE_WITH_CODE (GtkAppChooserComboBox, gtk_app_chooser_combo_box, GTK_TYPE_COMBO_BOX, G_DEFINE_TYPE_WITH_CODE (GtkAppChooserComboBox, gtk_app_chooser_combo_box, GTK_TYPE_COMBO_BOX,
G_IMPLEMENT_INTERFACE (GTK_TYPE_APP_CHOOSER, G_IMPLEMENT_INTERFACE (GTK_TYPE_APP_CHOOSER,
app_chooser_iface_init)); app_chooser_iface_init));
struct _GtkAppChooserComboBoxPrivate { struct _GtkAppChooserComboBoxPrivate {
gchar *content_type; gchar *content_type;
@ -89,21 +89,21 @@ struct _GtkAppChooserComboBoxPrivate {
static gboolean static gboolean
row_separator_func (GtkTreeModel *model, row_separator_func (GtkTreeModel *model,
GtkTreeIter *iter, GtkTreeIter *iter,
gpointer user_data) gpointer user_data)
{ {
gboolean separator; gboolean separator;
gtk_tree_model_get (model, iter, gtk_tree_model_get (model, iter,
COLUMN_SEPARATOR, &separator, COLUMN_SEPARATOR, &separator,
-1); -1);
return separator; return separator;
} }
static void static void
get_first_iter (GtkListStore *store, get_first_iter (GtkListStore *store,
GtkTreeIter *iter) GtkTreeIter *iter)
{ {
GtkTreeIter iter2; GtkTreeIter iter2;
@ -138,27 +138,27 @@ gtk_app_chooser_combo_box_populate (GtkAppChooserComboBox *self)
icon = g_app_info_get_icon (app); icon = g_app_info_get_icon (app);
if (icon == NULL) if (icon == NULL)
icon = g_themed_icon_new ("x-application/executable"); icon = g_themed_icon_new ("application-x-executable");
else else
g_object_ref (icon); g_object_ref (icon);
if (first) if (first)
{ {
get_first_iter (self->priv->store, &iter); get_first_iter (self->priv->store, &iter);
first = FALSE; first = FALSE;
} }
else else
{ {
gtk_list_store_insert_after (self->priv->store, &iter2, &iter); gtk_list_store_insert_after (self->priv->store, &iter2, &iter);
iter = iter2; iter = iter2;
} }
gtk_list_store_set (self->priv->store, &iter, gtk_list_store_set (self->priv->store, &iter,
COLUMN_APP_INFO, app, COLUMN_APP_INFO, app,
COLUMN_NAME, g_app_info_get_display_name (app), COLUMN_NAME, g_app_info_get_display_name (app),
COLUMN_ICON, icon, COLUMN_ICON, icon,
COLUMN_CUSTOM, FALSE, COLUMN_CUSTOM, FALSE,
-1); -1);
g_object_unref (icon); g_object_unref (icon);
} }
@ -172,30 +172,30 @@ gtk_app_chooser_combo_box_build_ui (GtkAppChooserComboBox *self)
GtkCellRenderer *cell; GtkCellRenderer *cell;
self->priv->store = gtk_list_store_new (NUM_COLUMNS, self->priv->store = gtk_list_store_new (NUM_COLUMNS,
G_TYPE_APP_INFO, G_TYPE_APP_INFO,
G_TYPE_STRING, G_TYPE_STRING,
G_TYPE_ICON, G_TYPE_ICON,
G_TYPE_BOOLEAN, G_TYPE_BOOLEAN,
G_TYPE_BOOLEAN, G_TYPE_BOOLEAN,
CUSTOM_COMBO_DATA_TYPE); CUSTOM_COMBO_DATA_TYPE);
gtk_combo_box_set_model (GTK_COMBO_BOX (self), gtk_combo_box_set_model (GTK_COMBO_BOX (self),
GTK_TREE_MODEL (self->priv->store)); GTK_TREE_MODEL (self->priv->store));
gtk_combo_box_set_row_separator_func (GTK_COMBO_BOX (self), gtk_combo_box_set_row_separator_func (GTK_COMBO_BOX (self),
row_separator_func, NULL, NULL); row_separator_func, NULL, NULL);
cell = gtk_cell_renderer_pixbuf_new (); cell = gtk_cell_renderer_pixbuf_new ();
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (self), cell, FALSE); gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (self), cell, FALSE);
gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (self), cell, gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (self), cell,
"gicon", COLUMN_ICON, "gicon", COLUMN_ICON,
NULL); NULL);
cell = gtk_cell_renderer_text_new (); cell = gtk_cell_renderer_text_new ();
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (self), cell, TRUE); gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (self), cell, TRUE);
gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (self), cell, gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (self), cell,
"text", COLUMN_NAME, "text", COLUMN_NAME,
NULL); NULL);
gtk_app_chooser_combo_box_populate (self); gtk_app_chooser_combo_box_populate (self);
} }
@ -207,15 +207,15 @@ gtk_app_chooser_combo_box_remove_non_custom (GtkAppChooserComboBox *self)
GtkTreeIter iter; GtkTreeIter iter;
gboolean custom, res; gboolean custom, res;
model = GTK_TREE_MODEL (self->priv->store); model = GTK_TREE_MODEL (self->priv->store);
if (!gtk_tree_model_get_iter_first (model, &iter)) if (!gtk_tree_model_get_iter_first (model, &iter))
return; return;
do { do {
gtk_tree_model_get (model, &iter, gtk_tree_model_get (model, &iter,
COLUMN_CUSTOM, &custom, COLUMN_CUSTOM, &custom,
-1); -1);
if (custom) if (custom)
res = gtk_tree_model_iter_next (model, &iter); res = gtk_tree_model_iter_next (model, &iter);
else else
@ -235,10 +235,10 @@ gtk_app_chooser_combo_box_changed (GtkComboBox *object)
return; return;
gtk_tree_model_get (GTK_TREE_MODEL (self->priv->store), &iter, gtk_tree_model_get (GTK_TREE_MODEL (self->priv->store), &iter,
COLUMN_CUSTOM, &custom, COLUMN_CUSTOM, &custom,
COLUMN_SEPARATOR, &separator, COLUMN_SEPARATOR, &separator,
COLUMN_CALLBACK, &custom_data, COLUMN_CALLBACK, &custom_data,
-1); -1);
if (custom && !separator && if (custom && !separator &&
custom_data != NULL && custom_data->func != NULL) custom_data != NULL && custom_data->func != NULL)
@ -265,8 +265,8 @@ gtk_app_chooser_combo_box_get_app_info (GtkAppChooser *object)
return NULL; return NULL;
gtk_tree_model_get (GTK_TREE_MODEL (self->priv->store), &iter, gtk_tree_model_get (GTK_TREE_MODEL (self->priv->store), &iter,
COLUMN_APP_INFO, &info, COLUMN_APP_INFO, &info,
-1); -1);
return info; return info;
} }
@ -285,10 +285,10 @@ gtk_app_chooser_combo_box_constructed (GObject *obj)
} }
static void static void
gtk_app_chooser_combo_box_set_property (GObject *obj, gtk_app_chooser_combo_box_set_property (GObject *obj,
guint property_id, guint property_id,
const GValue *value, const GValue *value,
GParamSpec *pspec) GParamSpec *pspec)
{ {
GtkAppChooserComboBox *self = GTK_APP_CHOOSER_COMBO_BOX (obj); GtkAppChooserComboBox *self = GTK_APP_CHOOSER_COMBO_BOX (obj);
@ -304,10 +304,10 @@ gtk_app_chooser_combo_box_set_property (GObject *obj,
} }
static void static void
gtk_app_chooser_combo_box_get_property (GObject *obj, gtk_app_chooser_combo_box_get_property (GObject *obj,
guint property_id, guint property_id,
GValue *value, GValue *value,
GParamSpec *pspec) GParamSpec *pspec)
{ {
GtkAppChooserComboBox *self = GTK_APP_CHOOSER_COMBO_BOX (obj); GtkAppChooserComboBox *self = GTK_APP_CHOOSER_COMBO_BOX (obj);
@ -360,21 +360,40 @@ gtk_app_chooser_combo_box_class_init (GtkAppChooserComboBoxClass *klass)
static void static void
gtk_app_chooser_combo_box_init (GtkAppChooserComboBox *self) gtk_app_chooser_combo_box_init (GtkAppChooserComboBox *self)
{ {
self->priv = self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GTK_TYPE_APP_CHOOSER_COMBO_BOX,
G_TYPE_INSTANCE_GET_PRIVATE (self, GTK_TYPE_APP_CHOOSER_COMBO_BOX, GtkAppChooserComboBoxPrivate);
GtkAppChooserComboBoxPrivate);
} }
/**
* gtk_app_chooser_combo_box_new:
* @content_type: the content type to show applications for
*
* Creates a new #GtkAppChooserComboBox for applications
* that can handle content of the given type.
*
* Returns: a newly created #GtkAppChooserComboBox
*
* Since: 3.0
*/
GtkWidget * GtkWidget *
gtk_app_chooser_combo_box_new (const gchar *content_type) gtk_app_chooser_combo_box_new (const gchar *content_type)
{ {
g_return_val_if_fail (content_type != NULL, NULL); g_return_val_if_fail (content_type != NULL, NULL);
return g_object_new (GTK_TYPE_APP_CHOOSER_COMBO_BOX, return g_object_new (GTK_TYPE_APP_CHOOSER_COMBO_BOX,
"content-type", content_type, "content-type", content_type,
NULL); NULL);
} }
/**
* gtk_app_chooser_combo_box_append_separator:
* @self: a #GtkAppChooserComboBox
*
* Appends a separator to the list of applications that is shown
* in the popup.
*
* Since: 3.0
*/
void void
gtk_app_chooser_combo_box_append_separator (GtkAppChooserComboBox *self) gtk_app_chooser_combo_box_append_separator (GtkAppChooserComboBox *self)
{ {
@ -384,17 +403,30 @@ gtk_app_chooser_combo_box_append_separator (GtkAppChooserComboBox *self)
gtk_list_store_append (self->priv->store, &iter); gtk_list_store_append (self->priv->store, &iter);
gtk_list_store_set (self->priv->store, &iter, gtk_list_store_set (self->priv->store, &iter,
COLUMN_CUSTOM, TRUE, COLUMN_CUSTOM, TRUE,
COLUMN_SEPARATOR, TRUE, COLUMN_SEPARATOR, TRUE,
-1); -1);
} }
/**
* gtk_app_chooser_combo_box_append_custom_item:
* @self: a #GtkAppChooserComboBox
* @label: the label for the custom item
* @icon: the icon for the custom item
* @func: callback to call if the item is activated
* @user_data: user data for @func
*
* Appends a custom item to the list of applications that is shown
* in the popup. See also gtk_app_chooser_combo_box_append_separator().
*
* Since: 3.0
*/
void void
gtk_app_chooser_combo_box_append_custom_item (GtkAppChooserComboBox *self, gtk_app_chooser_combo_box_append_custom_item (GtkAppChooserComboBox *self,
const gchar *label, const gchar *label,
GIcon *icon, GIcon *icon,
GtkAppChooserComboBoxItemFunc func, GtkAppChooserComboBoxItemFunc func,
gpointer user_data) gpointer user_data)
{ {
GtkTreeIter iter; GtkTreeIter iter;
CustomAppComboData *data; CustomAppComboData *data;
@ -405,10 +437,10 @@ gtk_app_chooser_combo_box_append_custom_item (GtkAppChooserComboBox *self,
gtk_list_store_append (self->priv->store, &iter); gtk_list_store_append (self->priv->store, &iter);
gtk_list_store_set (self->priv->store, &iter, gtk_list_store_set (self->priv->store, &iter,
COLUMN_NAME, label, COLUMN_NAME, label,
COLUMN_ICON, icon, COLUMN_ICON, icon,
COLUMN_CALLBACK, data, COLUMN_CALLBACK, data,
COLUMN_CUSTOM, TRUE, COLUMN_CUSTOM, TRUE,
COLUMN_SEPARATOR, FALSE, COLUMN_SEPARATOR, FALSE,
-1); -1);
} }

View File

@ -31,25 +31,19 @@
#include <gtk/gtkcombobox.h> #include <gtk/gtkcombobox.h>
#include <gio/gio.h> #include <gio/gio.h>
#define GTK_TYPE_APP_CHOOSER_COMBO_BOX\ #define GTK_TYPE_APP_CHOOSER_COMBO_BOX (gtk_app_chooser_combo_box_get_type ())
(gtk_app_chooser_combo_box_get_type ()) #define GTK_APP_CHOOSER_COMBO_BOX(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_COMBO_BOX, GtkAppChooserComboBox))
#define GTK_APP_CHOOSER_COMBO_BOX(obj)\ #define GTK_APP_CHOOSER_COMBO_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_COMBO_BOX, GtkAppChooserComboBoxClass))
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_COMBO_BOX, GtkAppChooserComboBox)) #define GTK_IS_APP_CHOOSER_COMBO_BOX(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_COMBO_BOX))
#define GTK_APP_CHOOSER_COMBO_BOX_CLASS(klass)\ #define GTK_IS_APP_CHOOSER_COMBO_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_COMBO_BOX))
(G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_COMBO_BOX, GtkAppChooserComboBoxClass)) #define GTK_APP_CHOOSER_COMBO_BOX_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_COMBO_BOX, GtkAppChooserComboBoxClass))
#define GTK_IS_APP_CHOOSER_COMBO_BOX(obj)\
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_COMBO_BOX))
#define GTK_IS_APP_CHOOSER_COMBO_BOX_CLASS(klass)\
(G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_COMBO_BOX))
#define GTK_APP_CHOOSER_COMBO_BOX_GET_CLASS(obj)\
(G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_COMBO_BOX, GtkAppChooserComboBoxClass))
typedef struct _GtkAppChooserComboBox GtkAppChooserComboBox; typedef struct _GtkAppChooserComboBox GtkAppChooserComboBox;
typedef struct _GtkAppChooserComboBoxClass GtkAppChooserComboBoxClass; typedef struct _GtkAppChooserComboBoxClass GtkAppChooserComboBoxClass;
typedef struct _GtkAppChooserComboBoxPrivate GtkAppChooserComboBoxPrivate; typedef struct _GtkAppChooserComboBoxPrivate GtkAppChooserComboBoxPrivate;
typedef void (* GtkAppChooserComboBoxItemFunc) (GtkAppChooserComboBox *self, typedef void (* GtkAppChooserComboBoxItemFunc) (GtkAppChooserComboBox *self,
gpointer user_data); gpointer user_data);
struct _GtkAppChooserComboBox { struct _GtkAppChooserComboBox {
GtkComboBox parent; GtkComboBox parent;
@ -65,15 +59,15 @@ struct _GtkAppChooserComboBoxClass {
gpointer padding[16]; gpointer padding[16];
}; };
GType gtk_app_chooser_combo_box_get_type (void) G_GNUC_CONST; GType gtk_app_chooser_combo_box_get_type (void) G_GNUC_CONST;
GtkWidget * gtk_app_chooser_combo_box_new (const gchar *content_type); GtkWidget * gtk_app_chooser_combo_box_new (const gchar *content_type);
void gtk_app_chooser_combo_box_append_separator (GtkAppChooserComboBox *self); void gtk_app_chooser_combo_box_append_separator (GtkAppChooserComboBox *self);
void gtk_app_chooser_combo_box_append_custom_item (GtkAppChooserComboBox *self, void gtk_app_chooser_combo_box_append_custom_item (GtkAppChooserComboBox *self,
const gchar *label, const gchar *label,
GIcon *icon, GIcon *icon,
GtkAppChooserComboBoxItemFunc func, GtkAppChooserComboBoxItemFunc func,
gpointer user_data); gpointer user_data);
#endif /* __GTK_APP_CHOOSER_COMBO_BOX_H__ */ #endif /* __GTK_APP_CHOOSER_COMBO_BOX_H__ */

View File

@ -24,7 +24,7 @@
* Cosimo Cecchi <ccecchi@redhat.com> * Cosimo Cecchi <ccecchi@redhat.com>
*/ */
#include <config.h> #include "config.h"
#include "gtkappchooserdialog.h" #include "gtkappchooserdialog.h"
@ -32,10 +32,17 @@
#include "gtkappchooser.h" #include "gtkappchooser.h"
#include "gtkappchooseronline.h" #include "gtkappchooseronline.h"
#include "gtkappchooserprivate.h" #include "gtkappchooserprivate.h"
#include "gtkappchooserprivate.h"
#include "gtkmessagedialog.h"
#include "gtklabel.h"
#include "gtkbbox.h"
#include "gtkbutton.h"
#include "gtkmenuitem.h"
#include "gtkstock.h"
#include <string.h> #include <string.h>
#include <glib/gi18n-lib.h> #include <glib/gi18n-lib.h>
#include <gtk/gtk.h>
#include <gio/gio.h> #include <gio/gio.h>
#define sure_string(s) ((const char *) ((s) != NULL ? (s) : "")) #define sure_string(s) ((const char *) ((s) != NULL ? (s) : ""))
@ -64,36 +71,36 @@ enum {
static void gtk_app_chooser_dialog_iface_init (GtkAppChooserIface *iface); static void gtk_app_chooser_dialog_iface_init (GtkAppChooserIface *iface);
G_DEFINE_TYPE_WITH_CODE (GtkAppChooserDialog, gtk_app_chooser_dialog, GTK_TYPE_DIALOG, G_DEFINE_TYPE_WITH_CODE (GtkAppChooserDialog, gtk_app_chooser_dialog, GTK_TYPE_DIALOG,
G_IMPLEMENT_INTERFACE (GTK_TYPE_APP_CHOOSER, G_IMPLEMENT_INTERFACE (GTK_TYPE_APP_CHOOSER,
gtk_app_chooser_dialog_iface_init)); gtk_app_chooser_dialog_iface_init));
static void static void
show_error_dialog (const gchar *primary, show_error_dialog (const gchar *primary,
const gchar *secondary, const gchar *secondary,
GtkWindow *parent) GtkWindow *parent)
{ {
GtkWidget *message_dialog; GtkWidget *message_dialog;
message_dialog = gtk_message_dialog_new (parent, 0, message_dialog = gtk_message_dialog_new (parent, 0,
GTK_MESSAGE_ERROR, GTK_MESSAGE_ERROR,
GTK_BUTTONS_OK, GTK_BUTTONS_OK,
NULL); NULL);
g_object_set (message_dialog, g_object_set (message_dialog,
"text", primary, "text", primary,
"secondary-text", secondary, "secondary-text", secondary,
NULL); NULL);
gtk_dialog_set_default_response (GTK_DIALOG (message_dialog), GTK_RESPONSE_OK); gtk_dialog_set_default_response (GTK_DIALOG (message_dialog), GTK_RESPONSE_OK);
gtk_widget_show (message_dialog); gtk_widget_show (message_dialog);
g_signal_connect (message_dialog, "response", g_signal_connect (message_dialog, "response",
G_CALLBACK (gtk_widget_destroy), NULL); G_CALLBACK (gtk_widget_destroy), NULL);
} }
static void static void
search_for_mimetype_ready_cb (GObject *source, search_for_mimetype_ready_cb (GObject *source,
GAsyncResult *res, GAsyncResult *res,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserOnline *online = GTK_APP_CHOOSER_ONLINE (source); GtkAppChooserOnline *online = GTK_APP_CHOOSER_ONLINE (source);
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
@ -104,7 +111,7 @@ search_for_mimetype_ready_cb (GObject *source,
if (error != NULL) if (error != NULL)
{ {
show_error_dialog (_("Failed to look for applications online"), show_error_dialog (_("Failed to look for applications online"),
error->message, GTK_WINDOW (self)); error->message, GTK_WINDOW (self));
g_error_free (error); g_error_free (error);
} }
else else
@ -117,7 +124,7 @@ search_for_mimetype_ready_cb (GObject *source,
static void static void
online_button_clicked_cb (GtkButton *b, online_button_clicked_cb (GtkButton *b,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserOnline *online; GtkAppChooserOnline *online;
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
@ -125,10 +132,10 @@ online_button_clicked_cb (GtkButton *b,
online = gtk_app_chooser_online_get_default (); online = gtk_app_chooser_online_get_default ();
gtk_app_chooser_online_search_for_mimetype_async (online, gtk_app_chooser_online_search_for_mimetype_async (online,
self->priv->content_type, self->priv->content_type,
GTK_WINDOW (self), GTK_WINDOW (self),
search_for_mimetype_ready_cb, search_for_mimetype_ready_cb,
self); self);
} }
/* An application is valid if: /* An application is valid if:
@ -137,8 +144,8 @@ online_button_clicked_cb (GtkButton *b,
* 2) The user has permissions to run the file * 2) The user has permissions to run the file
*/ */
static gboolean static gboolean
check_application (GtkAppChooserDialog *self, check_application (GtkAppChooserDialog *self,
GAppInfo **app_out) GAppInfo **app_out)
{ {
const char *command; const char *command;
char *path = NULL; char *path = NULL;
@ -158,8 +165,8 @@ check_application (GtkAppChooserDialog *self,
if (error) if (error)
{ {
show_error_dialog (_("Could not run application"), show_error_dialog (_("Could not run application"),
error->message, error->message,
GTK_WINDOW (self)); GTK_WINDOW (self));
g_error_free (error); g_error_free (error);
retval = FALSE; retval = FALSE;
goto cleanup; goto cleanup;
@ -171,11 +178,11 @@ check_application (GtkAppChooserDialog *self,
char *error_message; char *error_message;
error_message = g_strdup_printf (_("Could not find '%s'"), error_message = g_strdup_printf (_("Could not find '%s'"),
argv[0]); argv[0]);
show_error_dialog (_("Could not find application"), show_error_dialog (_("Could not find application"),
error_message, error_message,
GTK_WINDOW (self)); GTK_WINDOW (self));
g_free (error_message); g_free (error_message);
retval = FALSE; retval = FALSE;
goto cleanup; goto cleanup;
@ -199,16 +206,16 @@ add_or_find_application (GtkAppChooserDialog *self)
/* we don't care about reporting errors here */ /* we don't care about reporting errors here */
g_app_info_add_supports_type (app, g_app_info_add_supports_type (app,
self->priv->content_type, self->priv->content_type,
NULL); NULL);
g_object_unref (app); g_object_unref (app);
} }
static void static void
gtk_app_chooser_dialog_response (GtkDialog *dialog, gtk_app_chooser_dialog_response (GtkDialog *dialog,
gint response_id, gint response_id,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (dialog); GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (dialog);
@ -224,8 +231,8 @@ gtk_app_chooser_dialog_response (GtkDialog *dialog,
static void static void
widget_application_selected_cb (GtkAppChooserWidget *widget, widget_application_selected_cb (GtkAppChooserWidget *widget,
GAppInfo *app_info, GAppInfo *app_info,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
@ -234,8 +241,8 @@ widget_application_selected_cb (GtkAppChooserWidget *widget,
static void static void
widget_application_activated_cb (GtkAppChooserWidget *widget, widget_application_activated_cb (GtkAppChooserWidget *widget,
GAppInfo *app_info, GAppInfo *app_info,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
@ -258,7 +265,12 @@ get_extension (const char *basename)
static void static void
set_dialog_properties (GtkAppChooserDialog *self) set_dialog_properties (GtkAppChooserDialog *self)
{ {
char *label, *name, *extension, *description, *default_text, *string; gchar *label;
gchar *name;
gchar *extension;
gchar *description;
gchar *default_text;
gchar *string;
PangoFontDescription *font_desc; PangoFontDescription *font_desc;
name = NULL; name = NULL;
@ -280,17 +292,17 @@ set_dialog_properties (GtkAppChooserDialog *self)
/* Translators: %s is a filename */ /* Translators: %s is a filename */
label = g_strdup_printf (_("Select an application to open \"%s\""), name); label = g_strdup_printf (_("Select an application to open \"%s\""), name);
string = g_strdup_printf (_("No applications available to open \"%s\""), string = g_strdup_printf (_("No applications available to open \"%s\""),
name); name);
} }
else else
{ {
/* Translators: %s is a file type description */ /* Translators: %s is a file type description */
label = g_strdup_printf (_("Select an application for \"%s\" files"), label = g_strdup_printf (_("Select an application for \"%s\" files"),
g_content_type_is_unknown (self->priv->content_type) ? g_content_type_is_unknown (self->priv->content_type) ?
self->priv->content_type : description); self->priv->content_type : description);
string = g_strdup_printf (_("No applications available to open \"%s\" files"), string = g_strdup_printf (_("No applications available to open \"%s\" files"),
g_content_type_is_unknown (self->priv->content_type) ? g_content_type_is_unknown (self->priv->content_type) ?
self->priv->content_type : description); self->priv->content_type : description);
} }
font_desc = pango_font_description_new (); font_desc = pango_font_description_new ();
@ -301,12 +313,12 @@ set_dialog_properties (GtkAppChooserDialog *self)
gtk_label_set_markup (GTK_LABEL (self->priv->label), label); gtk_label_set_markup (GTK_LABEL (self->priv->label), label);
default_text = g_strdup_printf ("<big><b>%s</b></big>\n%s", default_text = g_strdup_printf ("<big><b>%s</b></big>\n%s",
string, string,
_("Click \"Show other applications\", for more options, or " _("Click \"Show other applications\", for more options, or "
"\"Find applications online\" to install a new application")); "\"Find applications online\" to install a new application"));
gtk_app_chooser_widget_set_default_text (GTK_APP_CHOOSER_WIDGET (self->priv->app_chooser_widget), gtk_app_chooser_widget_set_default_text (GTK_APP_CHOOSER_WIDGET (self->priv->app_chooser_widget),
default_text); default_text);
g_free (label); g_free (label);
g_free (name); g_free (name);
@ -318,24 +330,24 @@ set_dialog_properties (GtkAppChooserDialog *self)
static void static void
show_more_button_clicked_cb (GtkButton *button, show_more_button_clicked_cb (GtkButton *button,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
g_object_set (self->priv->app_chooser_widget, g_object_set (self->priv->app_chooser_widget,
"show-recommended", TRUE, "show-recommended", TRUE,
"show-fallback", TRUE, "show-fallback", TRUE,
"show-other", TRUE, "show-other", TRUE,
NULL); NULL);
gtk_widget_hide (self->priv->show_more_button); gtk_widget_hide (self->priv->show_more_button);
self->priv->show_more_clicked = TRUE; self->priv->show_more_clicked = TRUE;
} }
static void static void
widget_notify_for_button_cb (GObject *source, widget_notify_for_button_cb (GObject *source,
GParamSpec *pspec, GParamSpec *pspec,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
GtkAppChooserWidget *widget = GTK_APP_CHOOSER_WIDGET (source); GtkAppChooserWidget *widget = GTK_APP_CHOOSER_WIDGET (source);
@ -350,7 +362,7 @@ widget_notify_for_button_cb (GObject *source,
static void static void
forget_menu_item_activate_cb (GtkMenuItem *item, forget_menu_item_activate_cb (GtkMenuItem *item,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
GAppInfo *info; GAppInfo *info;
@ -359,8 +371,7 @@ forget_menu_item_activate_cb (GtkMenuItem *item,
if (info != NULL) if (info != NULL)
{ {
g_app_info_remove_supports_type (info, self->priv->content_type, g_app_info_remove_supports_type (info, self->priv->content_type, NULL);
NULL);
gtk_app_chooser_refresh (GTK_APP_CHOOSER (self)); gtk_app_chooser_refresh (GTK_APP_CHOOSER (self));
@ -377,16 +388,16 @@ build_forget_menu_item (GtkAppChooserDialog *self)
gtk_widget_show (retval); gtk_widget_show (retval);
g_signal_connect (retval, "activate", g_signal_connect (retval, "activate",
G_CALLBACK (forget_menu_item_activate_cb), self); G_CALLBACK (forget_menu_item_activate_cb), self);
return retval; return retval;
} }
static void static void
widget_populate_popup_cb (GtkAppChooserWidget *widget, widget_populate_popup_cb (GtkAppChooserWidget *widget,
GtkMenu *menu, GtkMenu *menu,
GAppInfo *info, GAppInfo *info,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserDialog *self = user_data; GtkAppChooserDialog *self = user_data;
GtkWidget *menu_item; GtkWidget *menu_item;
@ -412,7 +423,7 @@ build_dialog_ui (GtkAppChooserDialog *self)
gtk_container_set_border_width (GTK_CONTAINER (vbox), 5); gtk_container_set_border_width (GTK_CONTAINER (vbox), 5);
gtk_box_pack_start (GTK_BOX (gtk_dialog_get_content_area (GTK_DIALOG (self))), vbox, TRUE, TRUE, 0); gtk_box_pack_start (GTK_BOX (gtk_dialog_get_content_area (GTK_DIALOG (self))), vbox, TRUE, TRUE, 0);
gtk_widget_show (vbox); gtk_widget_show (vbox);
vbox2 = gtk_box_new (GTK_ORIENTATION_VERTICAL, 6); vbox2 = gtk_box_new (GTK_ORIENTATION_VERTICAL, 6);
gtk_box_pack_start (GTK_BOX (vbox), vbox2, TRUE, TRUE, 0); gtk_box_pack_start (GTK_BOX (vbox), vbox2, TRUE, TRUE, 0);
gtk_widget_show (vbox2); gtk_widget_show (vbox2);
@ -421,7 +432,7 @@ build_dialog_ui (GtkAppChooserDialog *self)
gtk_misc_set_alignment (GTK_MISC (self->priv->label), 0, 0.5); gtk_misc_set_alignment (GTK_MISC (self->priv->label), 0, 0.5);
gtk_label_set_line_wrap (GTK_LABEL (self->priv->label), TRUE); gtk_label_set_line_wrap (GTK_LABEL (self->priv->label), TRUE);
gtk_box_pack_start (GTK_BOX (vbox2), self->priv->label, gtk_box_pack_start (GTK_BOX (vbox2), self->priv->label,
FALSE, FALSE, 0); FALSE, FALSE, 0);
gtk_widget_show (self->priv->label); gtk_widget_show (self->priv->label);
self->priv->app_chooser_widget = self->priv->app_chooser_widget =
@ -430,28 +441,28 @@ build_dialog_ui (GtkAppChooserDialog *self)
gtk_widget_show (self->priv->app_chooser_widget); gtk_widget_show (self->priv->app_chooser_widget);
g_signal_connect (self->priv->app_chooser_widget, "application-selected", g_signal_connect (self->priv->app_chooser_widget, "application-selected",
G_CALLBACK (widget_application_selected_cb), self); G_CALLBACK (widget_application_selected_cb), self);
g_signal_connect (self->priv->app_chooser_widget, "application-activated", g_signal_connect (self->priv->app_chooser_widget, "application-activated",
G_CALLBACK (widget_application_activated_cb), self); G_CALLBACK (widget_application_activated_cb), self);
g_signal_connect (self->priv->app_chooser_widget, "notify::show-all", g_signal_connect (self->priv->app_chooser_widget, "notify::show-all",
G_CALLBACK (widget_notify_for_button_cb), self); G_CALLBACK (widget_notify_for_button_cb), self);
g_signal_connect (self->priv->app_chooser_widget, "populate-popup", g_signal_connect (self->priv->app_chooser_widget, "populate-popup",
G_CALLBACK (widget_populate_popup_cb), self); G_CALLBACK (widget_populate_popup_cb), self);
button = gtk_button_new_with_label (_("Show other applications")); button = gtk_button_new_with_label (_("Show other applications"));
self->priv->show_more_button = button; self->priv->show_more_button = button;
w = gtk_image_new_from_stock (GTK_STOCK_ADD, w = gtk_image_new_from_stock (GTK_STOCK_ADD,
GTK_ICON_SIZE_BUTTON); GTK_ICON_SIZE_BUTTON);
gtk_button_set_image (GTK_BUTTON (button), w); gtk_button_set_image (GTK_BUTTON (button), w);
gtk_box_pack_start (GTK_BOX (self->priv->app_chooser_widget), button, FALSE, FALSE, 6); gtk_box_pack_start (GTK_BOX (self->priv->app_chooser_widget), button, FALSE, FALSE, 6);
gtk_widget_show_all (button); gtk_widget_show_all (button);
g_signal_connect (button, "clicked", g_signal_connect (button, "clicked",
G_CALLBACK (show_more_button_clicked_cb), self); G_CALLBACK (show_more_button_clicked_cb), self);
gtk_dialog_add_button (GTK_DIALOG (self), gtk_dialog_add_button (GTK_DIALOG (self),
GTK_STOCK_CANCEL, GTK_STOCK_CANCEL,
GTK_RESPONSE_CANCEL); GTK_RESPONSE_CANCEL);
/* Create a custom stock icon */ /* Create a custom stock icon */
self->priv->button = gtk_button_new (); self->priv->button = gtk_button_new ();
@ -463,31 +474,31 @@ build_dialog_ui (GtkAppChooserDialog *self)
self->priv->open_label = label; self->priv->open_label = label;
gtk_container_add (GTK_CONTAINER (self->priv->button), gtk_container_add (GTK_CONTAINER (self->priv->button),
self->priv->open_label); self->priv->open_label);
gtk_widget_show (self->priv->button); gtk_widget_show (self->priv->button);
gtk_widget_set_can_default (self->priv->button, TRUE); gtk_widget_set_can_default (self->priv->button, TRUE);
gtk_dialog_add_action_widget (GTK_DIALOG (self), gtk_dialog_add_action_widget (GTK_DIALOG (self),
self->priv->button, GTK_RESPONSE_OK); self->priv->button, GTK_RESPONSE_OK);
action_area = gtk_dialog_get_action_area (GTK_DIALOG (self)); action_area = gtk_dialog_get_action_area (GTK_DIALOG (self));
self->priv->online_button = gtk_button_new_with_label (_("Find applications online")); self->priv->online_button = gtk_button_new_with_label (_("Find applications online"));
gtk_box_pack_start (GTK_BOX (action_area), self->priv->online_button, gtk_box_pack_start (GTK_BOX (action_area), self->priv->online_button,
FALSE, FALSE, 0); FALSE, FALSE, 0);
gtk_button_box_set_child_secondary (GTK_BUTTON_BOX (action_area), self->priv->online_button, gtk_button_box_set_child_secondary (GTK_BUTTON_BOX (action_area), self->priv->online_button,
TRUE); TRUE);
gtk_widget_show (self->priv->online_button); gtk_widget_show (self->priv->online_button);
g_signal_connect (self->priv->online_button, "clicked", g_signal_connect (self->priv->online_button, "clicked",
G_CALLBACK (online_button_clicked_cb), self); G_CALLBACK (online_button_clicked_cb), self);
gtk_dialog_set_default_response (GTK_DIALOG (self), gtk_dialog_set_default_response (GTK_DIALOG (self),
GTK_RESPONSE_OK); GTK_RESPONSE_OK);
} }
static void static void
set_gfile_and_content_type (GtkAppChooserDialog *self, set_gfile_and_content_type (GtkAppChooserDialog *self,
GFile *file) GFile *file)
{ {
GFileInfo *info; GFileInfo *info;
@ -497,8 +508,8 @@ set_gfile_and_content_type (GtkAppChooserDialog *self,
self->priv->gfile = g_object_ref (file); self->priv->gfile = g_object_ref (file);
info = g_file_query_info (self->priv->gfile, info = g_file_query_info (self->priv->gfile,
G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE, G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE,
0, NULL, NULL); 0, NULL, NULL);
self->priv->content_type = g_strdup (g_file_info_get_content_type (info)); self->priv->content_type = g_strdup (g_file_info_get_content_type (info));
g_object_unref (info); g_object_unref (info);
@ -530,7 +541,7 @@ gtk_app_chooser_dialog_constructed (GObject *object)
GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (object); GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (object);
g_assert (self->priv->content_type != NULL || g_assert (self->priv->content_type != NULL ||
self->priv->gfile != NULL); self->priv->gfile != NULL);
if (G_OBJECT_CLASS (gtk_app_chooser_dialog_parent_class)->constructed != NULL) if (G_OBJECT_CLASS (gtk_app_chooser_dialog_parent_class)->constructed != NULL)
G_OBJECT_CLASS (gtk_app_chooser_dialog_parent_class)->constructed (object); G_OBJECT_CLASS (gtk_app_chooser_dialog_parent_class)->constructed (object);
@ -553,10 +564,10 @@ gtk_app_chooser_dialog_finalize (GObject *object)
} }
static void static void
gtk_app_chooser_dialog_set_property (GObject *object, gtk_app_chooser_dialog_set_property (GObject *object,
guint property_id, guint property_id,
const GValue *value, const GValue *value,
GParamSpec *pspec) GParamSpec *pspec)
{ {
GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (object); GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (object);
@ -568,7 +579,7 @@ gtk_app_chooser_dialog_set_property (GObject *object,
case PROP_CONTENT_TYPE: case PROP_CONTENT_TYPE:
/* don't try to override a value previously set with the GFile */ /* don't try to override a value previously set with the GFile */
if (self->priv->content_type == NULL) if (self->priv->content_type == NULL)
self->priv->content_type = g_value_dup_string (value); self->priv->content_type = g_value_dup_string (value);
break; break;
default: default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
@ -577,10 +588,10 @@ gtk_app_chooser_dialog_set_property (GObject *object,
} }
static void static void
gtk_app_chooser_dialog_get_property (GObject *object, gtk_app_chooser_dialog_get_property (GObject *object,
guint property_id, guint property_id,
GValue *value, GValue *value,
GParamSpec *pspec) GParamSpec *pspec)
{ {
GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (object); GtkAppChooserDialog *self = GTK_APP_CHOOSER_DIALOG (object);
@ -588,7 +599,7 @@ gtk_app_chooser_dialog_get_property (GObject *object,
{ {
case PROP_GFILE: case PROP_GFILE:
if (self->priv->gfile != NULL) if (self->priv->gfile != NULL)
g_value_set_object (value, self->priv->gfile); g_value_set_object (value, self->priv->gfile);
break; break;
case PROP_CONTENT_TYPE: case PROP_CONTENT_TYPE:
g_value_set_string (value, self->priv->content_type); g_value_set_string (value, self->priv->content_type);
@ -621,11 +632,11 @@ gtk_app_chooser_dialog_class_init (GtkAppChooserDialogClass *klass)
g_object_class_override_property (gobject_class, PROP_CONTENT_TYPE, "content-type"); g_object_class_override_property (gobject_class, PROP_CONTENT_TYPE, "content-type");
pspec = g_param_spec_object ("gfile", pspec = g_param_spec_object ("gfile",
P_("GFile"), P_("GFile"),
P_("The GFile used by the open with dialog"), P_("The GFile used by the open with dialog"),
G_TYPE_FILE, G_TYPE_FILE,
G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE |
G_PARAM_STATIC_STRINGS); G_PARAM_STATIC_STRINGS);
g_object_class_install_property (gobject_class, PROP_GFILE, pspec); g_object_class_install_property (gobject_class, PROP_GFILE, pspec);
g_type_class_add_private (klass, sizeof (GtkAppChooserDialogPrivate)); g_type_class_add_private (klass, sizeof (GtkAppChooserDialogPrivate));
@ -635,24 +646,23 @@ static void
gtk_app_chooser_dialog_init (GtkAppChooserDialog *self) gtk_app_chooser_dialog_init (GtkAppChooserDialog *self)
{ {
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GTK_TYPE_APP_CHOOSER_DIALOG, self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GTK_TYPE_APP_CHOOSER_DIALOG,
GtkAppChooserDialogPrivate); GtkAppChooserDialogPrivate);
/* we can't override the class signal handler here, as it's a RUN_LAST; /* we can't override the class signal handler here, as it's a RUN_LAST;
* we want our signal handler instead to be executed before any user code. * we want our signal handler instead to be executed before any user code.
*/ */
g_signal_connect (self, "response", g_signal_connect (self, "response",
G_CALLBACK (gtk_app_chooser_dialog_response), NULL); G_CALLBACK (gtk_app_chooser_dialog_response), NULL);
} }
static void static void
set_parent_and_flags (GtkWidget *dialog, set_parent_and_flags (GtkWidget *dialog,
GtkWindow *parent, GtkWindow *parent,
GtkDialogFlags flags) GtkDialogFlags flags)
{ {
if (parent != NULL) if (parent != NULL)
gtk_window_set_transient_for (GTK_WINDOW (dialog), gtk_window_set_transient_for (GTK_WINDOW (dialog), parent);
parent);
if (flags & GTK_DIALOG_MODAL) if (flags & GTK_DIALOG_MODAL)
gtk_window_set_modal (GTK_WINDOW (dialog), TRUE); gtk_window_set_modal (GTK_WINDOW (dialog), TRUE);
@ -666,25 +676,25 @@ set_parent_and_flags (GtkWidget *dialog,
* @flags: flags for this dialog * @flags: flags for this dialog
* @file: a #GFile * @file: a #GFile
* *
* Creates a new #GtkAppChooserDialog for the provided #GFile, to allow * Creates a new #GtkAppChooserDialog for the provided #GFile,
* the user to select an application for it. * to allow the user to select an application for it.
* *
* Returns: a newly created #GtkAppChooserDialog * Returns: a newly created #GtkAppChooserDialog
* *
* Since: 3.0 * Since: 3.0
**/ **/
GtkWidget * GtkWidget *
gtk_app_chooser_dialog_new (GtkWindow *parent, gtk_app_chooser_dialog_new (GtkWindow *parent,
GtkDialogFlags flags, GtkDialogFlags flags,
GFile *file) GFile *file)
{ {
GtkWidget *retval; GtkWidget *retval;
g_return_val_if_fail (G_IS_FILE (file), NULL); g_return_val_if_fail (G_IS_FILE (file), NULL);
retval = g_object_new (GTK_TYPE_APP_CHOOSER_DIALOG, retval = g_object_new (GTK_TYPE_APP_CHOOSER_DIALOG,
"gfile", file, "gfile", file,
NULL); NULL);
set_parent_and_flags (retval, parent, flags); set_parent_and_flags (retval, parent, flags);
@ -697,31 +707,41 @@ gtk_app_chooser_dialog_new (GtkWindow *parent,
* @flags: flags for this dialog * @flags: flags for this dialog
* @content_type: a content type string * @content_type: a content type string
* *
* Creates a new #GtkAppChooserDialog for the provided content type, to allow * Creates a new #GtkAppChooserDialog for the provided content type,
* the user to select an application for it. * to allow the user to select an application for it.
* *
* Returns: a newly created #GtkAppChooserDialog * Returns: a newly created #GtkAppChooserDialog
* *
* Since: 3.0 * Since: 3.0
**/ **/
GtkWidget * GtkWidget *
gtk_app_chooser_dialog_new_for_content_type (GtkWindow *parent, gtk_app_chooser_dialog_new_for_content_type (GtkWindow *parent,
GtkDialogFlags flags, GtkDialogFlags flags,
const gchar *content_type) const gchar *content_type)
{ {
GtkWidget *retval; GtkWidget *retval;
g_return_val_if_fail (content_type != NULL, NULL); g_return_val_if_fail (content_type != NULL, NULL);
retval = g_object_new (GTK_TYPE_APP_CHOOSER_DIALOG, retval = g_object_new (GTK_TYPE_APP_CHOOSER_DIALOG,
"content-type", content_type, "content-type", content_type,
NULL); NULL);
set_parent_and_flags (retval, parent, flags); set_parent_and_flags (retval, parent, flags);
return retval; return retval;
} }
/**
* gtk_app_chooser_dialog_get_widget:
* @self: a #GtkAppChooserDialog
*
* Returns the #GtkAppChooserWidget of this dialog.
*
* Returns: the #GtkAppChooserWidget of @self
*
* Since: 3.0
*/
GtkWidget * GtkWidget *
gtk_app_chooser_dialog_get_widget (GtkAppChooserDialog *self) gtk_app_chooser_dialog_get_widget (GtkAppChooserDialog *self)
{ {

View File

@ -34,18 +34,12 @@
#include <gtk/gtkdialog.h> #include <gtk/gtkdialog.h>
#include <gio/gio.h> #include <gio/gio.h>
#define GTK_TYPE_APP_CHOOSER_DIALOG\ #define GTK_TYPE_APP_CHOOSER_DIALOG (gtk_app_chooser_dialog_get_type ())
(gtk_app_chooser_dialog_get_type ()) #define GTK_APP_CHOOSER_DIALOG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_DIALOG, GtkAppChooserDialog))
#define GTK_APP_CHOOSER_DIALOG(obj)\ #define GTK_APP_CHOOSER_DIALOG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_DIALOG, GtkAppChooserDialogClass))
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_DIALOG, GtkAppChooserDialog)) #define GTK_IS_APP_CHOOSER_DIALOG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_DIALOG))
#define GTK_APP_CHOOSER_DIALOG_CLASS(klass)\ #define GTK_IS_APP_CHOOSER_DIALOG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_DIALOG))
(G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_DIALOG, GtkAppChooserDialogClass)) #define GTK_APP_CHOOSER_DIALOG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_DIALOG, GtkAppChooserDialogClass))
#define GTK_IS_APP_CHOOSER_DIALOG(obj)\
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_DIALOG))
#define GTK_IS_APP_CHOOSER_DIALOG_CLASS(klass)\
(G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_DIALOG))
#define GTK_APP_CHOOSER_DIALOG_GET_CLASS(obj)\
(G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_DIALOG, GtkAppChooserDialogClass))
typedef struct _GtkAppChooserDialog GtkAppChooserDialog; typedef struct _GtkAppChooserDialog GtkAppChooserDialog;
typedef struct _GtkAppChooserDialogClass GtkAppChooserDialogClass; typedef struct _GtkAppChooserDialogClass GtkAppChooserDialogClass;
@ -65,15 +59,15 @@ struct _GtkAppChooserDialogClass {
gpointer padding[16]; gpointer padding[16];
}; };
GType gtk_app_chooser_dialog_get_type (void) G_GNUC_CONST; GType gtk_app_chooser_dialog_get_type (void) G_GNUC_CONST;
GtkWidget * gtk_app_chooser_dialog_new (GtkWindow *parent, GtkWidget * gtk_app_chooser_dialog_new (GtkWindow *parent,
GtkDialogFlags flags, GtkDialogFlags flags,
GFile *file); GFile *file);
GtkWidget * gtk_app_chooser_dialog_new_for_content_type (GtkWindow *parent, GtkWidget * gtk_app_chooser_dialog_new_for_content_type (GtkWindow *parent,
GtkDialogFlags flags, GtkDialogFlags flags,
const gchar *content_type); const gchar *content_type);
GtkWidget * gtk_app_chooser_dialog_get_widget (GtkAppChooserDialog *self); GtkWidget * gtk_app_chooser_dialog_get_widget (GtkAppChooserDialog *self);
#endif /* __GTK_APP_CHOOSER_DIALOG_H__ */ #endif /* __GTK_APP_CHOOSER_DIALOG_H__ */

View File

@ -21,7 +21,7 @@
* Authors: Cosimo Cecchi <ccecchi@redhat.com> * Authors: Cosimo Cecchi <ccecchi@redhat.com>
*/ */
#include <config.h> #include "config.h"
#include "gtkappchoosermodule.h" #include "gtkappchoosermodule.h"
@ -45,7 +45,7 @@ _gtk_app_chooser_module_ensure (void)
G_LOCK (registered_ep); G_LOCK (registered_ep);
if (!registered_ep) if (!registered_ep)
{ {
registered_ep = TRUE; registered_ep = TRUE;
ep = g_io_extension_point_register ("gtkappchooser-online"); ep = g_io_extension_point_register ("gtkappchooser-online");

View File

@ -21,7 +21,7 @@
* Authors: Cosimo Cecchi <ccecchi@redhat.com> * Authors: Cosimo Cecchi <ccecchi@redhat.com>
*/ */
#include <config.h> #include "config.h"
#include "gtkappchooseronline.h" #include "gtkappchooseronline.h"
@ -55,13 +55,11 @@ gtk_app_chooser_online_get_default (void)
{ {
/* pick the first */ /* pick the first */
extension = extensions->data; extension = extensions->data;
retval = g_object_new (g_io_extension_get_type (extension), retval = g_object_new (g_io_extension_get_type (extension), NULL);
NULL);
} }
else else
{ {
retval = g_object_new (GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, retval = g_object_new (GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, NULL);
NULL);
} }
return retval; return retval;
@ -69,10 +67,10 @@ gtk_app_chooser_online_get_default (void)
void void
gtk_app_chooser_online_search_for_mimetype_async (GtkAppChooserOnline *self, gtk_app_chooser_online_search_for_mimetype_async (GtkAppChooserOnline *self,
const gchar *content_type, const gchar *content_type,
GtkWindow *parent, GtkWindow *parent,
GAsyncReadyCallback callback, GAsyncReadyCallback callback,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserOnlineInterface *iface; GtkAppChooserOnlineInterface *iface;
@ -84,9 +82,9 @@ gtk_app_chooser_online_search_for_mimetype_async (GtkAppChooserOnline *self,
} }
gboolean gboolean
gtk_app_chooser_online_search_for_mimetype_finish (GtkAppChooserOnline *self, gtk_app_chooser_online_search_for_mimetype_finish (GtkAppChooserOnline *self,
GAsyncResult *res, GAsyncResult *res,
GError **error) GError **error)
{ {
GtkAppChooserOnlineInterface *iface; GtkAppChooserOnlineInterface *iface;

View File

@ -31,14 +31,10 @@
G_BEGIN_DECLS G_BEGIN_DECLS
#define GTK_TYPE_APP_CHOOSER_ONLINE\ #define GTK_TYPE_APP_CHOOSER_ONLINE (gtk_app_chooser_online_get_type ())
(gtk_app_chooser_online_get_type ()) #define GTK_APP_CHOOSER_ONLINE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GTK_TYPE_APP_CHOOSER_ONLINE, GtkAppChooserOnline))
#define GTK_APP_CHOOSER_ONLINE(o)\ #define GTK_IS_APP_CHOOSER_ONLINE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GTK_TYPE_APP_CHOOSER_ONLINE))
(G_TYPE_CHECK_INSTANCE_CAST ((o), GTK_TYPE_APP_CHOOSER_ONLINE, GtkAppChooserOnline)) #define GTK_APP_CHOOSER_ONLINE_GET_IFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GTK_TYPE_APP_CHOOSER_ONLINE, GtkAppChooserOnlineInterface))
#define GTK_IS_APP_CHOOSER_ONLINE(o)\
(G_TYPE_CHECK_INSTANCE_TYPE ((o), GTK_TYPE_APP_CHOOSER_ONLINE))
#define GTK_APP_CHOOSER_ONLINE_GET_IFACE(obj)\
(G_TYPE_INSTANCE_GET_INTERFACE ((obj), GTK_TYPE_APP_CHOOSER_ONLINE, GtkAppChooserOnlineInterface))
typedef struct _GtkAppChooserOnline GtkAppChooserOnline; typedef struct _GtkAppChooserOnline GtkAppChooserOnline;
typedef struct _GtkAppChooserOnlineInterface GtkAppChooserOnlineInterface; typedef struct _GtkAppChooserOnlineInterface GtkAppChooserOnlineInterface;
@ -47,27 +43,27 @@ struct _GtkAppChooserOnlineInterface {
GTypeInterface g_iface; GTypeInterface g_iface;
/* Methods */ /* Methods */
void (*search_for_mimetype_async) (GtkAppChooserOnline *self, void (*search_for_mimetype_async) (GtkAppChooserOnline *self,
const gchar *content_type, const gchar *content_type,
GtkWindow *parent, GtkWindow *parent,
GAsyncReadyCallback callback, GAsyncReadyCallback callback,
gpointer user_data); gpointer user_data);
gboolean (*search_for_mimetype_finish) (GtkAppChooserOnline *self, gboolean (*search_for_mimetype_finish) (GtkAppChooserOnline *self,
GAsyncResult *res, GAsyncResult *res,
GError **error); GError **error);
}; };
GType gtk_app_chooser_online_get_type (void) G_GNUC_CONST; GType gtk_app_chooser_online_get_type (void) G_GNUC_CONST;
void gtk_app_chooser_online_search_for_mimetype_async (GtkAppChooserOnline *self, void gtk_app_chooser_online_search_for_mimetype_async (GtkAppChooserOnline *self,
const gchar *content_type, const gchar *content_type,
GtkWindow *parent, GtkWindow *parent,
GAsyncReadyCallback callback, GAsyncReadyCallback callback,
gpointer user_data); gpointer user_data);
gboolean gtk_app_chooser_online_search_for_mimetype_finish (GtkAppChooserOnline *self, gboolean gtk_app_chooser_online_search_for_mimetype_finish (GtkAppChooserOnline *self,
GAsyncResult *res, GAsyncResult *res,
GError **error); GError **error);
GtkAppChooserOnline * gtk_app_chooser_online_get_default (void); GtkAppChooserOnline * gtk_app_chooser_online_get_default (void);
#endif /* __GTK_APP_CHOOSER_ONLINE_H__ */ #endif /* __GTK_APP_CHOOSER_ONLINE_H__ */

View File

@ -27,18 +27,12 @@
#include <gtk/gtkappchooseronline.h> #include <gtk/gtkappchooseronline.h>
#include <glib.h> #include <glib.h>
#define GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY\ #define GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY (_gtk_app_chooser_online_dummy_get_type ())
(_gtk_app_chooser_online_dummy_get_type ()) #define GTK_APP_CHOOSER_ONLINE_DUMMY(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, GtkAppChooserOnlineDummy))
#define GTK_APP_CHOOSER_ONLINE_DUMMY(obj)\ #define GTK_APP_CHOOSER_ONLINE_DUMMY_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, GtkAppChooserOnlineDummyClass))
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, GtkAppChooserOnlineDummy)) #define GTK_IS_APP_CHOOSER_ONLINE_DUMMY(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY))
#define GTK_APP_CHOOSER_ONLINE_DUMMY_CLASS(klass)\ #define GTK_IS_APP_CHOOSER_ONLINE_DUMMY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY))
(G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, GtkAppChooserOnlineDummyClass)) #define GTK_APP_CHOOSER_ONLINE_DUMMY_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, GtkAppChooserOnlineDummyClass))
#define GTK_IS_APP_CHOOSER_ONLINE_DUMMY(obj)\
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY))
#define GTK_IS_APP_CHOOSER_ONLINE_DUMMY_CLASS(klass)\
(G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY))
#define GTK_APP_CHOOSER_ONLINE_DUMMY_GET_CLASS(obj)\
(G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_DUMMY, GtkAppChooserOnlineDummyClass))
typedef struct _GtkAppChooserOnlineDummy GtkAppChooserOnlineDummy; typedef struct _GtkAppChooserOnlineDummy GtkAppChooserOnlineDummy;
typedef struct _GtkAppChooserOnlineDummyClass GtkAppChooserOnlineDummyClass; typedef struct _GtkAppChooserOnlineDummyClass GtkAppChooserOnlineDummyClass;

View File

@ -21,12 +21,14 @@
* Authors: Cosimo Cecchi <ccecchi@redhat.com> * Authors: Cosimo Cecchi <ccecchi@redhat.com>
*/ */
#include <config.h> #include "config.h"
#include "gtkappchooseronlinepk.h" #include "gtkappchooseronlinepk.h"
#include "gtkappchooseronline.h" #include "gtkappchooseronline.h"
#ifdef GDK_WINDOWING_X11
#include "x11/gdkx.h" #include "x11/gdkx.h"
#endif
#include <gio/gio.h> #include <gio/gio.h>
@ -34,12 +36,12 @@
static void app_chooser_online_iface_init (GtkAppChooserOnlineInterface *iface); static void app_chooser_online_iface_init (GtkAppChooserOnlineInterface *iface);
G_DEFINE_TYPE_WITH_CODE (GtkAppChooserOnlinePk, gtk_app_chooser_online_pk, G_DEFINE_TYPE_WITH_CODE (GtkAppChooserOnlinePk, gtk_app_chooser_online_pk,
G_TYPE_OBJECT, G_TYPE_OBJECT,
G_IMPLEMENT_INTERFACE (GTK_TYPE_APP_CHOOSER_ONLINE, G_IMPLEMENT_INTERFACE (GTK_TYPE_APP_CHOOSER_ONLINE,
app_chooser_online_iface_init) app_chooser_online_iface_init)
g_io_extension_point_implement ("gtkappchooser-online", g_io_extension_point_implement ("gtkappchooser-online",
g_define_type_id, g_define_type_id,
"packagekit", 10)); "packagekit", 10));
struct _GtkAppChooserOnlinePkPrivate { struct _GtkAppChooserOnlinePkPrivate {
GSimpleAsyncResult *result; GSimpleAsyncResult *result;
@ -72,13 +74,13 @@ static void
gtk_app_chooser_online_pk_init (GtkAppChooserOnlinePk *self) gtk_app_chooser_online_pk_init (GtkAppChooserOnlinePk *self)
{ {
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GTK_TYPE_APP_CHOOSER_ONLINE_PK, self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GTK_TYPE_APP_CHOOSER_ONLINE_PK,
GtkAppChooserOnlinePkPrivate); GtkAppChooserOnlinePkPrivate);
} }
static gboolean static gboolean
pk_search_mime_finish (GtkAppChooserOnline *obj, pk_search_mime_finish (GtkAppChooserOnline *obj,
GAsyncResult *res, GAsyncResult *res,
GError **error) GError **error)
{ {
GSimpleAsyncResult *simple = G_SIMPLE_ASYNC_RESULT (res); GSimpleAsyncResult *simple = G_SIMPLE_ASYNC_RESULT (res);
@ -86,9 +88,9 @@ pk_search_mime_finish (GtkAppChooserOnline *obj,
} }
static void static void
install_mime_types_ready_cb (GObject *source, install_mime_types_ready_cb (GObject *source,
GAsyncResult *res, GAsyncResult *res,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserOnlinePk *self = user_data; GtkAppChooserOnlinePk *self = user_data;
GDBusProxy *proxy = G_DBUS_PROXY (source); GDBusProxy *proxy = G_DBUS_PROXY (source);
@ -97,24 +99,25 @@ install_mime_types_ready_cb (GObject *source,
variant = g_dbus_proxy_call_finish (proxy, res, &error); variant = g_dbus_proxy_call_finish (proxy, res, &error);
if (variant == NULL) { if (variant == NULL)
/* don't show errors if the user cancelled the installation explicitely {
* or if PK wasn't able to find any apps /* don't show errors if the user cancelled the installation explicitely
*/ * or if PK wasn't able to find any apps
if (g_strcmp0 (g_dbus_error_get_remote_error (error), "org.freedesktop.PackageKit.Modify.Cancelled") != 0 && */
g_strcmp0 (g_dbus_error_get_remote_error (error), "org.freedesktop.PackageKit.Modify.NoPackagesFound") != 0) if (g_strcmp0 (g_dbus_error_get_remote_error (error), "org.freedesktop.PackageKit.Modify.Cancelled") != 0 &&
g_simple_async_result_set_from_error (self->priv->result, error); g_strcmp0 (g_dbus_error_get_remote_error (error), "org.freedesktop.PackageKit.Modify.NoPackagesFound") != 0)
g_simple_async_result_set_from_error (self->priv->result, error);
g_error_free (error); g_error_free (error);
} }
g_simple_async_result_complete (self->priv->result); g_simple_async_result_complete (self->priv->result);
} }
static void static void
pk_proxy_appeared_cb (GObject *source, pk_proxy_appeared_cb (GObject *source,
GAsyncResult *res, GAsyncResult *res,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserOnlinePk *self = user_data; GtkAppChooserOnlinePk *self = user_data;
GDBusProxy *proxy; GDBusProxy *proxy;
@ -125,58 +128,63 @@ pk_proxy_appeared_cb (GObject *source,
proxy = g_dbus_proxy_new_for_bus_finish (res, &error); proxy = g_dbus_proxy_new_for_bus_finish (res, &error);
if (error != NULL) { if (error != NULL)
g_simple_async_result_set_from_error (self->priv->result, error); {
g_error_free (error); g_simple_async_result_set_from_error (self->priv->result, error);
g_error_free (error);
g_simple_async_result_complete (self->priv->result); g_simple_async_result_complete (self->priv->result);
return; return;
} }
#ifdef GDK_WINDOWING_X11
window = gtk_widget_get_window (GTK_WIDGET (self->priv->parent)); window = gtk_widget_get_window (GTK_WIDGET (self->priv->parent));
xid = GDK_WINDOW_XID (window); xid = GDK_WINDOW_XID (window);
#else
xid = 0;
#endif
mime_types[0] = self->priv->content_type; mime_types[0] = self->priv->content_type;
mime_types[1] = NULL; mime_types[1] = NULL;
g_dbus_proxy_call (proxy, g_dbus_proxy_call (proxy,
"InstallMimeTypes", "InstallMimeTypes",
g_variant_new ("(u^ass)", g_variant_new ("(u^ass)",
xid, xid,
mime_types, mime_types,
"hide-confirm-search"), "hide-confirm-search"),
G_DBUS_CALL_FLAGS_NONE, G_DBUS_CALL_FLAGS_NONE,
G_MAXINT, /* no timeout */ G_MAXINT, /* no timeout */
NULL, NULL,
install_mime_types_ready_cb, install_mime_types_ready_cb,
self); self);
} }
static void static void
pk_search_mime_async (GtkAppChooserOnline *obj, pk_search_mime_async (GtkAppChooserOnline *obj,
const gchar *content_type, const gchar *content_type,
GtkWindow *parent, GtkWindow *parent,
GAsyncReadyCallback callback, GAsyncReadyCallback callback,
gpointer user_data) gpointer user_data)
{ {
GtkAppChooserOnlinePk *self = GTK_APP_CHOOSER_ONLINE_PK (obj); GtkAppChooserOnlinePk *self = GTK_APP_CHOOSER_ONLINE_PK (obj);
self->priv->result = g_simple_async_result_new (G_OBJECT (self), self->priv->result = g_simple_async_result_new (G_OBJECT (self),
callback, user_data, callback, user_data,
gtk_app_chooser_online_search_for_mimetype_async); gtk_app_chooser_online_search_for_mimetype_async);
self->priv->parent = parent; self->priv->parent = parent;
self->priv->content_type = g_strdup (content_type); self->priv->content_type = g_strdup (content_type);
g_dbus_proxy_new_for_bus (G_BUS_TYPE_SESSION, g_dbus_proxy_new_for_bus (G_BUS_TYPE_SESSION,
G_DBUS_PROXY_FLAGS_NONE, G_DBUS_PROXY_FLAGS_NONE,
NULL, NULL,
"org.freedesktop.PackageKit", "org.freedesktop.PackageKit",
"/org/freedesktop/PackageKit", "/org/freedesktop/PackageKit",
"org.freedesktop.PackageKit.Modify", "org.freedesktop.PackageKit.Modify",
NULL, NULL,
pk_proxy_appeared_cb, pk_proxy_appeared_cb,
self); self);
} }
static void static void

View File

@ -27,18 +27,12 @@
#include <gtk/gtkappchooseronline.h> #include <gtk/gtkappchooseronline.h>
#include <glib.h> #include <glib.h>
#define GTK_TYPE_APP_CHOOSER_ONLINE_PK\ #define GTK_TYPE_APP_CHOOSER_ONLINE_PK (_gtk_app_chooser_online_pk_get_type ())
(_gtk_app_chooser_online_pk_get_type ()) #define GTK_APP_CHOOSER_ONLINE_PK(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_PK, GtkAppChooserOnlinePk))
#define GTK_APP_CHOOSER_ONLINE_PK(obj)\ #define GTK_APP_CHOOSER_ONLINE_PK_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_PK, GtkAppChooserOnlinePkClass))
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_PK, GtkAppChooserOnlinePk)) #define GTK_IS_APP_CHOOSER_ONLINE_PK(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_PK))
#define GTK_APP_CHOOSER_ONLINE_PK_CLASS(klass)\ #define GTK_IS_APP_CHOOSER_ONLINE_PK_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_PK))
(G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_PK, GtkAppChooserOnlinePkClass)) #define GTK_APP_CHOOSER_ONLINE_PK_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_PK, GtkAppChooserOnlinePkClass))
#define GTK_IS_APP_CHOOSER_ONLINE_PK(obj)\
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_PK))
#define GTK_IS_APP_CHOOSER_ONLINE_PK_CLASS(klass)\
(G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_ONLINE_PK))
#define GTK_APP_CHOOSER_ONLINE_PK_GET_CLASS(obj)\
(G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_ONLINE_PK, GtkAppChooserOnlinePkClass))
typedef struct _GtkAppChooserOnlinePk GtkAppChooserOnlinePk; typedef struct _GtkAppChooserOnlinePk GtkAppChooserOnlinePk;
typedef struct _GtkAppChooserOnlinePkClass GtkAppChooserOnlinePkClass; typedef struct _GtkAppChooserOnlinePkClass GtkAppChooserOnlinePkClass;

View File

@ -27,13 +27,13 @@
#include <glib.h> #include <glib.h>
#include <gio/gio.h> #include <gio/gio.h>
#include "gtkappchooser.h"
#include "gtkappchooserwidget.h" #include "gtkappchooserwidget.h"
typedef struct _GtkAppChooserIface GtkAppChooserIface; typedef struct _GtkAppChooserIface GtkAppChooserIface;
typedef GtkAppChooserIface GtkAppChooserInterface; typedef GtkAppChooserIface GtkAppChooserInterface;
#define GTK_APP_CHOOSER_GET_IFACE(inst)\ #define GTK_APP_CHOOSER_GET_IFACE(inst) (G_TYPE_INSTANCE_GET_INTERFACE ((inst), GTK_TYPE_APP_CHOOSER, GtkAppChooserIface))
(G_TYPE_INSTANCE_GET_INTERFACE ((inst), GTK_TYPE_APP_CHOOSER, GtkAppChooserIface))
struct _GtkAppChooserIface { struct _GtkAppChooserIface {
GTypeInterface base_iface; GTypeInterface base_iface;

File diff suppressed because it is too large Load Diff

View File

@ -35,18 +35,12 @@
#include <gtk/gtkmenu.h> #include <gtk/gtkmenu.h>
#include <gio/gio.h> #include <gio/gio.h>
#define GTK_TYPE_APP_CHOOSER_WIDGET\ #define GTK_TYPE_APP_CHOOSER_WIDGET (gtk_app_chooser_widget_get_type ())
(gtk_app_chooser_widget_get_type ()) #define GTK_APP_CHOOSER_WIDGET(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_WIDGET, GtkAppChooserWidget))
#define GTK_APP_CHOOSER_WIDGET(obj)\ #define GTK_APP_CHOOSER_WIDGET_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_WIDGET, GtkAppChooserWidgetClass))
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APP_CHOOSER_WIDGET, GtkAppChooserWidget)) #define GTK_IS_APP_CHOOSER_WIDGET(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_WIDGET))
#define GTK_APP_CHOOSER_WIDGET_CLASS(klass)\ #define GTK_IS_APP_CHOOSER_WIDGET_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_WIDGET))
(G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APP_CHOOSER_WIDGET, GtkAppChooserWidgetClass)) #define GTK_APP_CHOOSER_WIDGET_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_WIDGET, GtkAppChooserWidgetClass))
#define GTK_IS_APP_CHOOSER_WIDGET(obj)\
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APP_CHOOSER_WIDGET))
#define GTK_IS_APP_CHOOSER_WIDGET_CLASS(klass)\
(G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APP_CHOOSER_WIDGET))
#define GTK_APP_CHOOSER_WIDGET_GET_CLASS(obj)\
(G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APP_CHOOSER_WIDGET, GtkAppChooserWidgetClass))
typedef struct _GtkAppChooserWidget GtkAppChooserWidget; typedef struct _GtkAppChooserWidget GtkAppChooserWidget;
typedef struct _GtkAppChooserWidgetClass GtkAppChooserWidgetClass; typedef struct _GtkAppChooserWidgetClass GtkAppChooserWidgetClass;
@ -62,53 +56,46 @@ struct _GtkAppChooserWidget {
struct _GtkAppChooserWidgetClass { struct _GtkAppChooserWidgetClass {
GtkBoxClass parent_class; GtkBoxClass parent_class;
void (* application_selected) (GtkAppChooserWidget *self, void (* application_selected) (GtkAppChooserWidget *self,
GAppInfo *app_info); GAppInfo *app_info);
void (* application_activated) (GtkAppChooserWidget *self, void (* application_activated) (GtkAppChooserWidget *self,
GAppInfo *app_info); GAppInfo *app_info);
void (* populate_popup) (GtkAppChooserWidget *self, void (* populate_popup) (GtkAppChooserWidget *self,
GtkMenu *menu, GtkMenu *menu,
GAppInfo *app_info); GAppInfo *app_info);
/* padding for future class expansion */ /* padding for future class expansion */
gpointer padding[16]; gpointer padding[16];
}; };
typedef enum { GType gtk_app_chooser_widget_get_type (void) G_GNUC_CONST;
GTK_APP_CHOOSER_WIDGET_SHOW_RECOMMENDED = 1 << 0,
GTK_APP_CHOOSER_WIDGET_SHOW_FALLBACK = 1 << 1,
GTK_APP_CHOOSER_WIDGET_SHOW_OTHER = 1 << 2,
GTK_APP_CHOOSER_WIDGET_SHOW_ALL = 1 << 3,
} GtkAppChooserWidgetShowFlags;
GType gtk_app_chooser_widget_get_type (void) G_GNUC_CONST; GtkWidget * gtk_app_chooser_widget_new (const gchar *content_type);
GtkWidget * gtk_app_chooser_widget_new (const gchar *content_type); void gtk_app_chooser_widget_set_show_default (GtkAppChooserWidget *self,
gboolean setting);
gboolean gtk_app_chooser_widget_get_show_default (GtkAppChooserWidget *self);
void gtk_app_chooser_widget_set_show_default (GtkAppChooserWidget *self, void gtk_app_chooser_widget_set_show_recommended (GtkAppChooserWidget *self,
gboolean setting); gboolean setting);
gboolean gtk_app_chooser_widget_get_show_default (GtkAppChooserWidget *self); gboolean gtk_app_chooser_widget_get_show_recommended (GtkAppChooserWidget *self);
void gtk_app_chooser_widget_set_show_recommended (GtkAppChooserWidget *self, void gtk_app_chooser_widget_set_show_fallback (GtkAppChooserWidget *self,
gboolean setting); gboolean setting);
gboolean gtk_app_chooser_widget_get_show_recommended (GtkAppChooserWidget *self); gboolean gtk_app_chooser_widget_get_show_fallback (GtkAppChooserWidget *self);
void gtk_app_chooser_widget_set_show_fallback (GtkAppChooserWidget *self, void gtk_app_chooser_widget_set_show_other (GtkAppChooserWidget *self,
gboolean setting); gboolean setting);
gboolean gtk_app_chooser_widget_get_show_fallback (GtkAppChooserWidget *self); gboolean gtk_app_chooser_widget_get_show_other (GtkAppChooserWidget *self);
void gtk_app_chooser_widget_set_show_other (GtkAppChooserWidget *self, void gtk_app_chooser_widget_set_show_all (GtkAppChooserWidget *self,
gboolean setting); gboolean show_all);
gboolean gtk_app_chooser_widget_get_show_other (GtkAppChooserWidget *self); gboolean gtk_app_chooser_widget_get_show_all (GtkAppChooserWidget *self);
void gtk_app_chooser_widget_set_show_all (GtkAppChooserWidget *self, void gtk_app_chooser_widget_set_default_text (GtkAppChooserWidget *self,
gboolean show_all); const gchar *text);
gboolean gtk_app_chooser_widget_get_show_all (GtkAppChooserWidget *self); const gchar * gtk_app_chooser_widget_get_default_text (GtkAppChooserWidget *self);
void gtk_app_chooser_widget_set_default_text (GtkAppChooserWidget *self,
const gchar *text);
const gchar * gtk_app_chooser_widget_get_default_text (GtkAppChooserWidget *self);
#endif /* __GTK_APP_CHOOSER_WIDGET_H__ */ #endif /* __GTK_APP_CHOOSER_WIDGET_H__ */

View File

@ -81,8 +81,7 @@ prepare_dialog (void)
if (use_file) if (use_file)
{ {
dialog = gtk_app_chooser_dialog_new (GTK_WINDOW (toplevel), dialog = gtk_app_chooser_dialog_new (GTK_WINDOW (toplevel), 0, file);
0, file);
} }
else else
{ {

View File

@ -18,7 +18,6 @@
* Boston, MA 02111-1307, USA. * Boston, MA 02111-1307, USA.
*/ */
#include <config.h>
#include <stdlib.h> #include <stdlib.h>
#include <gtk/gtk.h> #include <gtk/gtk.h>
@ -28,7 +27,7 @@ static GtkWidget *sel_image, *sel_name;
static void static void
combo_changed_cb (GtkComboBox *cb, combo_changed_cb (GtkComboBox *cb,
gpointer user_data) gpointer user_data)
{ {
GAppInfo *app_info; GAppInfo *app_info;
@ -38,7 +37,7 @@ combo_changed_cb (GtkComboBox *cb,
return; return;
gtk_image_set_from_gicon (GTK_IMAGE (sel_image), g_app_info_get_icon (app_info), gtk_image_set_from_gicon (GTK_IMAGE (sel_image), g_app_info_get_icon (app_info),
GTK_ICON_SIZE_DIALOG); GTK_ICON_SIZE_DIALOG);
gtk_label_set_text (GTK_LABEL (sel_name), g_app_info_get_display_name (app_info)); gtk_label_set_text (GTK_LABEL (sel_name), g_app_info_get_display_name (app_info));
g_object_unref (app_info); g_object_unref (app_info);
@ -46,11 +45,11 @@ combo_changed_cb (GtkComboBox *cb,
static void static void
special_item_activated_cb (GtkAppChooserComboBox *cb, special_item_activated_cb (GtkAppChooserComboBox *cb,
gpointer user_data) gpointer user_data)
{ {
gtk_image_set_from_gicon (GTK_IMAGE (sel_image), g_themed_icon_new ("face-smile"), gtk_image_set_from_gicon (GTK_IMAGE (sel_image), g_themed_icon_new ("face-smile"),
GTK_ICON_SIZE_DIALOG); GTK_ICON_SIZE_DIALOG);
gtk_label_set_text (GTK_LABEL (sel_name), "Special Item"); gtk_label_set_text (GTK_LABEL (sel_name), "Special Item");
} }
int int
@ -72,7 +71,7 @@ main (int argc,
gtk_box_pack_start (GTK_BOX (box), combobox, TRUE, TRUE, 0); gtk_box_pack_start (GTK_BOX (box), combobox, TRUE, TRUE, 0);
g_signal_connect (combobox, "changed", g_signal_connect (combobox, "changed",
G_CALLBACK (combo_changed_cb), NULL); G_CALLBACK (combo_changed_cb), NULL);
w = gtk_label_new (NULL); w = gtk_label_new (NULL);
gtk_label_set_markup (GTK_LABEL (w), "<b>Selected app info</b>"); gtk_label_set_markup (GTK_LABEL (w), "<b>Selected app info</b>");
@ -88,10 +87,10 @@ main (int argc,
gtk_app_chooser_combo_box_append_separator (GTK_APP_CHOOSER_COMBO_BOX (combobox)); gtk_app_chooser_combo_box_append_separator (GTK_APP_CHOOSER_COMBO_BOX (combobox));
gtk_app_chooser_combo_box_append_custom_item (GTK_APP_CHOOSER_COMBO_BOX (combobox), gtk_app_chooser_combo_box_append_custom_item (GTK_APP_CHOOSER_COMBO_BOX (combobox),
"Hey, I'm special!", "Hey, I'm special!",
g_themed_icon_new ("face-smile"), g_themed_icon_new ("face-smile"),
special_item_activated_cb, special_item_activated_cb,
NULL); NULL);
/* test refresh on a combo */ /* test refresh on a combo */
gtk_app_chooser_refresh (GTK_APP_CHOOSER (combobox)); gtk_app_chooser_refresh (GTK_APP_CHOOSER (combobox));
@ -99,7 +98,7 @@ main (int argc,
gtk_widget_show_all (toplevel); gtk_widget_show_all (toplevel);
g_signal_connect (toplevel, "delete-event", g_signal_connect (toplevel, "delete-event",
G_CALLBACK (gtk_main_quit), NULL); G_CALLBACK (gtk_main_quit), NULL);
gtk_main (); gtk_main ();