[nautilus-ideviceinfo/gtk3: 3/5] Port code and ui to GTK3
- From: Martin Szulecki <mszulecki src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [nautilus-ideviceinfo/gtk3: 3/5] Port code and ui to GTK3
- Date: Mon, 1 Dec 2014 16:42:15 +0000 (UTC)
commit aba6293bbcdeef661186e1d9ccbf09a0a55e9b2e
Author: Martin Szulecki <m szulecki libimobiledevice org>
Date: Sun Nov 30 17:45:30 2014 +0100
Port code and ui to GTK3
configure.ac | 14 +-
src/ideviceinfo-property-page.c | 32 +++-
src/ideviceinfo-property-page.h | 4 +-
src/nautilus-afc2-warning-bar.c | 14 +-
src/nautilus-afc2-warning-bar.h | 4 +-
src/nautilus-ideviceinfo.ui | 78 ++++++++-
src/rb-segmented-bar.c | 362 +++++++++++++++++++++++++++++++-------
7 files changed, 406 insertions(+), 102 deletions(-)
---
diff --git a/configure.ac b/configure.ac
index 78ca3b1..355a308 100644
--- a/configure.ac
+++ b/configure.ac
@@ -14,21 +14,21 @@ AC_PROG_CC
AM_PROG_CC_C_O
AC_PROG_LIBTOOL
-LIBIMOBILE_REQS=0.9.7
-GLIB2_REQS=2.14.1
-LIBPLIST_REQS=0.15
-GTK2_REQS=2.16
+LIBIMOBILE_REQS=1.1.7
+GLIB2_REQS=2.38.0
+LIBPLIST_REQS=1.12
+GTK3_REQS=3.10.0
NAUTILUS_REQS=2.21.2
-LIBGPOD_REQS=0.7.90
+LIBGPOD_REQS=0.8.2
LIBXML_REQS=2.6.30
# Checks for libraries.
PKG_CHECK_MODULES(WIDGET, libimobiledevice-1.0 >= $LIBIMOBILE_REQS
glib-2.0 >= $GLIB2_REQS
libplist >= $LIBPLIST_REQS
- gtk+-2.0 >= $GTK2_REQS)
+ gtk+-3.0 >= $GTK3_REQS)
PKG_CHECK_MODULES(libnautilusextension, libnautilus-extension >= $NAUTILUS_REQS)
-PKG_CHECK_MODULES(libgpod, libgpod-1.0 >= $LIBGPOD_REQS, enable_libgpod=yes, enable_libgpod=no)
+PKG_CHECK_MODULES(libgpod, libgpod-1.0 >= $LIBGPOD_REQS, enable_libgpod=no, enable_libgpod=no)
PKG_CHECK_MODULES(libxml, libxml-2.0 >= $LIBXML_REQS)
PKG_CHECK_MODULES(providerinfo, mobile-broadband-provider-info, enable_carrier_lookup=yes,
enable_carrier_lookup=no)
diff --git a/src/ideviceinfo-property-page.c b/src/ideviceinfo-property-page.c
index d50d195..a9e6c09 100644
--- a/src/ideviceinfo-property-page.c
+++ b/src/ideviceinfo-property-page.c
@@ -31,6 +31,7 @@
#include <libnautilus-extension/nautilus-property-page-provider.h>
#include <libimobiledevice/libimobiledevice.h>
+#include <libimobiledevice/afc.h>
#include <libimobiledevice/lockdown.h>
#include <libimobiledevice/installation_proxy.h>
@@ -55,6 +56,9 @@
#include <libxml/tree.h>
#include <libxml/parser.h>
#include <libxml/xpath.h>
+#ifndef MOBILE_BROADBAND_PROVIDER_INFO
+#define MOBILE_BROADBAND_PROVIDER_INFO DATADIR"/mobile-broadband-provider-info/serviceproviders.xml"
+#endif
#endif
#include "rb-segmented-bar.h"
@@ -83,14 +87,14 @@ typedef struct {
gboolean has_afc2; /* Whether AFC2 is available */
} CompletedMessage;
-G_DEFINE_TYPE(NautilusIdeviceinfoPage, nautilus_ideviceinfo_page, GTK_TYPE_VBOX)
+G_DEFINE_TYPE(NautilusIdeviceinfoPage, nautilus_ideviceinfo_page, GTK_TYPE_BOX)
static const char UIFILE[] = NAUTILUS_EXTENSION_DIR "/nautilus-ideviceinfo.ui";
static gchar *value_formatter(gdouble percent, gpointer user_data)
{
gsize total_size = GPOINTER_TO_SIZE(user_data);
- return g_format_size_for_display (percent * total_size * 1048576);
+ return g_format_size (percent * total_size * 1048576);
}
#ifdef HAVE_MOBILE_PROVIDER_INFO
@@ -513,7 +517,7 @@ end_phone:
/* set disk usage information */
char *storage_formatted_size = NULL;
char *markup = NULL;
- storage_formatted_size = g_format_size_for_display (disk_total);
+ storage_formatted_size = g_format_size (disk_total);
markup = g_markup_printf_escaped ("<b>%s</b> (%s)", _("Storage"), storage_formatted_size);
gtk_label_set_markup(lbStorage, markup);
g_free(storage_formatted_size);
@@ -617,7 +621,7 @@ static gpointer ideviceinfo_load_data(gpointer data)
goto leave;
}
- if (LOCKDOWN_E_SUCCESS != lockdownd_client_new_with_handshake(dev, &client, "nautilus-ideviceinfo")) {
+ if (LOCKDOWN_E_SUCCESS != lockdownd_client_new_with_handshake(dev, &client, PACKAGE_NAME)) {
completed_message_free(msg);
client = NULL;
goto leave;
@@ -641,12 +645,12 @@ static gpointer ideviceinfo_load_data(gpointer data)
}
/* get number of applications */
- uint16_t iport = 0;
+ lockdownd_service_descriptor_t service = NULL;
- if ((lockdownd_start_service(client, "com.apple.mobile.installation_proxy", &iport) ==
LOCKDOWN_E_SUCCESS) && iport) {
+ if ((lockdownd_start_service(client, INSTPROXY_SERVICE_NAME, &service) == LOCKDOWN_E_SUCCESS) &&
service) {
CHECK_CANCELLED;
instproxy_client_t ipc = NULL;
- if (instproxy_client_new(dev, iport, &ipc) == INSTPROXY_E_SUCCESS) {
+ if (instproxy_client_new(dev, service, &ipc) == INSTPROXY_E_SUCCESS) {
plist_t opts = instproxy_client_options_new();
plist_t apps = NULL;
instproxy_client_options_add(opts, "ApplicationType", "User", NULL);
@@ -661,11 +665,21 @@ static gpointer ideviceinfo_load_data(gpointer data)
}
}
+ if (service) {
+ lockdownd_service_descriptor_free(service);
+ service = NULL;
+ }
+
/* Detect whether AFC2 is available */
- if ((lockdownd_start_service(client, "com.apple.afc2", &iport) == LOCKDOWN_E_SUCCESS) && iport) {
+ if ((lockdownd_start_service(client, AFC_SERVICE_NAME"2", &service) == LOCKDOWN_E_SUCCESS) &&
service) {
msg->has_afc2 = TRUE;
}
+ if (service) {
+ lockdownd_service_descriptor_free(service);
+ service = NULL;
+ }
+
g_idle_add((GSourceFunc) update_ui, msg);
leave:
@@ -762,7 +776,7 @@ GtkWidget *nautilus_ideviceinfo_page_new(const char *uuid, const char *mount_pat
GtkLabel *lbUUIDText = GTK_LABEL(gtk_builder_get_object (di->priv->builder, "lbUUIDText"));
gtk_label_set_text(lbUUIDText, di->priv->uuid);
- di->priv->thread = g_thread_create(ideviceinfo_load_data, di, TRUE, NULL);
+ di->priv->thread = g_thread_new("ideviceinfo-load", ideviceinfo_load_data, di);
return GTK_WIDGET (di);
}
diff --git a/src/ideviceinfo-property-page.h b/src/ideviceinfo-property-page.h
index 74b8e5d..6f0c691 100644
--- a/src/ideviceinfo-property-page.h
+++ b/src/ideviceinfo-property-page.h
@@ -36,12 +36,12 @@ typedef struct NautilusIdeviceinfoPageClass NautilusIdeviceinfoPageClass;
typedef struct NautilusIdeviceinfoPagePrivate NautilusIdeviceinfoPagePrivate;
struct NautilusIdeviceinfoPage {
- GtkVBox parent;
+ GtkBox parent;
NautilusIdeviceinfoPagePrivate *priv;
};
struct NautilusIdeviceinfoPageClass {
- GtkVBoxClass parent_class;
+ GtkBoxClass parent_class;
};
GType nautilus_ideviceinfo_page_get_type(void);
diff --git a/src/nautilus-afc2-warning-bar.c b/src/nautilus-afc2-warning-bar.c
index abdfb54..96e85e7 100644
--- a/src/nautilus-afc2-warning-bar.c
+++ b/src/nautilus-afc2-warning-bar.c
@@ -42,7 +42,7 @@ enum {
LAST_SIGNAL
};
-G_DEFINE_TYPE (NautilusAfc2WarningBar, nautilus_afc2_warning_bar, GTK_TYPE_HBOX)
+G_DEFINE_TYPE (NautilusAfc2WarningBar, nautilus_afc2_warning_bar, GTK_TYPE_BOX)
static void
nautilus_afc2_warning_bar_class_init (NautilusAfc2WarningBarClass *klass)
@@ -57,7 +57,7 @@ nautilus_afc2_warning_bar_class_init (NautilusAfc2WarningBarClass *klass)
static void
nautilus_afc2_warning_bar_init (NautilusAfc2WarningBar *bar)
{
- GtkWidget *label;
+ GtkWidget *label;
GtkWidget *hbox;
GtkWidget *vbox;
GtkWidget *image;
@@ -69,16 +69,17 @@ nautilus_afc2_warning_bar_init (NautilusAfc2WarningBar *bar)
gtk_box_set_spacing (GTK_BOX (bar), 6);
gtk_widget_show (hbox);
- image = gtk_image_new_from_stock (GTK_STOCK_DIALOG_WARNING, GTK_ICON_SIZE_DIALOG);
+ image = gtk_image_new_from_icon_name ("dialog-warning", GTK_ICON_SIZE_DIALOG);
gtk_widget_show (image);
gtk_box_pack_start (GTK_BOX (hbox), image, FALSE, TRUE, 4);
- vbox = gtk_vbox_new (FALSE, 6);
+ vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 6);
gtk_widget_show (vbox);
gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
label = gtk_label_new (_("Jailbroken filesystem browsing is unsupported"));
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_widget_set_halign (label, GTK_ALIGN_START);
+ gtk_widget_set_valign (label, GTK_ALIGN_CENTER);
gtk_widget_show (label);
gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0);
@@ -86,7 +87,8 @@ nautilus_afc2_warning_bar_init (NautilusAfc2WarningBar *bar)
hint = g_strdup_printf ("<i>%s</i>", _("Accessing the root filesystem of the device can cause
damage. If problems occur, a restore will be necessary."));
gtk_label_set_markup (GTK_LABEL (label), hint);
g_free (hint);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_widget_set_halign (label, GTK_ALIGN_START);
+ gtk_widget_set_valign (label, GTK_ALIGN_CENTER);
gtk_widget_show (label);
gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0);
}
diff --git a/src/nautilus-afc2-warning-bar.h b/src/nautilus-afc2-warning-bar.h
index c1a9613..b279441 100644
--- a/src/nautilus-afc2-warning-bar.h
+++ b/src/nautilus-afc2-warning-bar.h
@@ -38,14 +38,14 @@ typedef struct NautilusAfc2WarningBarPrivate NautilusAfc2WarningBarPrivate;
typedef struct
{
- GtkHBox box;
+ GtkBox box;
NautilusAfc2WarningBarPrivate *priv;
} NautilusAfc2WarningBar;
typedef struct
{
- GtkHBoxClass parent_class;
+ GtkBoxClass parent_class;
} NautilusAfc2WarningBarClass;
GType nautilus_afc2_warning_bar_get_type (void);
diff --git a/src/nautilus-ideviceinfo.ui b/src/nautilus-ideviceinfo.ui
index a73cf51..e49c6bb 100644
--- a/src/nautilus-ideviceinfo.ui
+++ b/src/nautilus-ideviceinfo.ui
@@ -1,19 +1,22 @@
-<?xml version="1.0"?>
+<?xml version="1.0" encoding="UTF-8"?>
+<!-- Generated with glade 3.18.2 -->
<interface>
- <requires lib="gtk+" version="2.16"/>
- <!-- interface-naming-policy project-wide -->
- <object class="GtkVBox" id="ideviceinfo">
+ <requires lib="gtk+" version="3.0"/>
+ <object class="GtkBox" id="ideviceinfo">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="border_width">12</property>
<property name="orientation">vertical</property>
<property name="spacing">12</property>
<child>
- <object class="GtkVBox" id="vbGeneral">
+ <object class="GtkBox" id="vbGeneral">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="orientation">vertical</property>
<child>
<object class="GtkLabel" id="label1">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="label" translatable="yes">General</property>
<attributes>
@@ -29,12 +32,14 @@
<child>
<object class="GtkAlignment" id="alignment1">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="top_padding">8</property>
<property name="left_padding">12</property>
<property name="right_padding">8</property>
<child>
<object class="GtkTable" id="table1">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="n_rows">3</property>
<property name="n_columns">4</property>
<property name="column_spacing">4</property>
@@ -43,6 +48,7 @@
<object class="GtkLabel" id="lbDeviceName">
<property name="width_request">60</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -53,6 +59,7 @@
<object class="GtkLabel" id="lbDeviceVersion">
<property name="width_request">120</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -67,6 +74,7 @@
<object class="GtkLabel" id="lbDeviceModel">
<property name="width_request">60</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -81,6 +89,7 @@
<object class="GtkLabel" id="lbDeviceSerial">
<property name="width_request">120</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -97,6 +106,7 @@
<object class="GtkLabel" id="lbUUID">
<property name="width_request">59</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -110,6 +120,7 @@
<child>
<object class="GtkLabel" id="lbDeviceNameText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -123,6 +134,7 @@
<child>
<object class="GtkLabel" id="lbDeviceModelText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -138,6 +150,7 @@
<child>
<object class="GtkLabel" id="lbDeviceVersionText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -151,6 +164,7 @@
<child>
<object class="GtkLabel" id="lbDeviceSerialText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -166,6 +180,7 @@
<child>
<object class="GtkLabel" id="lbUUIDText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -183,22 +198,26 @@
</object>
<packing>
<property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
</object>
<packing>
<property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">0</property>
</packing>
</child>
<child>
- <object class="GtkVBox" id="vbPhone">
+ <object class="GtkBox" id="vbPhone">
+ <property name="can_focus">False</property>
<property name="no_show_all">True</property>
<property name="orientation">vertical</property>
<child>
<object class="GtkLabel" id="label2">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="yalign">0</property>
<property name="label" translatable="yes">Phone</property>
@@ -215,12 +234,14 @@
<child>
<object class="GtkAlignment" id="alignment2">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="top_padding">8</property>
<property name="left_padding">12</property>
<property name="right_padding">8</property>
<child>
<object class="GtkTable" id="table2">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="n_rows">3</property>
<property name="n_columns">4</property>
<property name="column_spacing">4</property>
@@ -229,6 +250,7 @@
<object class="GtkLabel" id="lbTelNo">
<property name="width_request">120</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="yalign">0</property>
<property name="xpad">1</property>
@@ -243,6 +265,7 @@
<object class="GtkLabel" id="lbCarrier">
<property name="width_request">110</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="yalign">0</property>
<property name="xpad">1</property>
@@ -259,6 +282,7 @@
<object class="GtkLabel" id="lbIMEI">
<property name="width_request">120</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -274,6 +298,7 @@
<object class="GtkLabel" id="lbIMSI">
<property name="width_request">110</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -291,6 +316,7 @@
<object class="GtkLabel" id="lbModemFw">
<property name="width_request">120</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="yalign">0</property>
<property name="xpad">1</property>
@@ -307,6 +333,7 @@
<object class="GtkLabel" id="lbICCID">
<property name="width_request">110</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -323,6 +350,7 @@
<child>
<object class="GtkLabel" id="lbTelNoText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -336,6 +364,7 @@
<child>
<object class="GtkLabel" id="lbIMEIText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -351,6 +380,7 @@
<child>
<object class="GtkLabel" id="lbModemFwText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="yalign">0</property>
<property name="xpad">1</property>
@@ -367,6 +397,7 @@
<child>
<object class="GtkLabel" id="lbICCIDText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -382,6 +413,7 @@
<child>
<object class="GtkLabel" id="lbIMSIText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -397,6 +429,7 @@
<child>
<object class="GtkLabel" id="lbCarrierText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="selectable">True</property>
</object>
@@ -409,22 +442,27 @@
</child>
</object>
<packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
</object>
<packing>
<property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
<child>
- <object class="GtkVBox" id="vbNetwork">
+ <object class="GtkBox" id="vbNetwork">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="orientation">vertical</property>
<child>
<object class="GtkLabel" id="label3">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="label" translatable="yes">Network</property>
<attributes>
@@ -440,12 +478,14 @@
<child>
<object class="GtkAlignment" id="alignment3">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="top_padding">8</property>
<property name="left_padding">12</property>
<property name="right_padding">8</property>
<child>
<object class="GtkTable" id="table3">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="n_rows">2</property>
<property name="n_columns">2</property>
<property name="column_spacing">4</property>
@@ -454,6 +494,7 @@
<object class="GtkLabel" id="lbBTMac">
<property name="width_request">130</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -467,6 +508,7 @@
<object class="GtkLabel" id="lbWiFiMac">
<property name="width_request">130</property>
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -481,6 +523,7 @@
<child>
<object class="GtkLabel" id="lbBTMacText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -494,6 +537,7 @@
<child>
<object class="GtkLabel" id="lbWiFiMacText">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="xpad">1</property>
<property name="ypad">1</property>
@@ -510,23 +554,28 @@
</child>
</object>
<packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
</object>
<packing>
<property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">2</property>
</packing>
</child>
<child>
- <object class="GtkVBox" id="vbStorage">
+ <object class="GtkBox" id="vbStorage">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="orientation">vertical</property>
<property name="spacing">4</property>
<child>
<object class="GtkLabel" id="label4">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="xalign">0</property>
<property name="label" translatable="yes">Storage</property>
</object>
@@ -539,29 +588,37 @@
<child>
<object class="GtkAlignment" id="alignment4">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="top_padding">8</property>
<property name="left_padding">8</property>
<property name="right_padding">8</property>
<child>
- <object class="GtkVBox" id="vbox8">
+ <object class="GtkBox" id="vbox8">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<property name="orientation">vertical</property>
<child>
<object class="GtkAlignment" id="disk_usage">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
<child>
<placeholder/>
</child>
</object>
<packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">0</property>
</packing>
</child>
<child>
<object class="GtkLabel" id="lbiPodInfo">
<property name="visible">True</property>
+ <property name="can_focus">False</property>
</object>
<packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
@@ -569,12 +626,15 @@
</child>
</object>
<packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
</object>
<packing>
<property name="expand">False</property>
+ <property name="fill">True</property>
<property name="position">3</property>
</packing>
</child>
diff --git a/src/rb-segmented-bar.c b/src/rb-segmented-bar.c
index 542e753..1210c0a 100644
--- a/src/rb-segmented-bar.c
+++ b/src/rb-segmented-bar.c
@@ -31,6 +31,7 @@
#include "config.h"
#endif
#include <math.h>
+#include <locale.h>
#include <cairo/cairo.h>
#include <gtk/gtk.h>
#include "rb-segmented-bar.h"
@@ -38,12 +39,9 @@
#define MINIMUM_HEIGHT 26
static void rb_segmented_bar_finalize (GObject *object);
-static void rb_segmented_bar_size_request (GtkWidget *widget,
- GtkRequisition *requisition);
static void rb_segmented_bar_size_allocate(GtkWidget *widget,
GtkAllocation *allocation);
-static gboolean rb_segmented_bar_expose (GtkWidget *widget,
- GdkEventExpose *event);
+static gboolean rb_segmented_bar_draw (GtkWidget *widget, cairo_t *context);
static void rb_segmented_bar_get_property (GObject *object, guint param_id,
GValue *value, GParamSpec *pspec);
static void rb_segmented_bar_set_property (GObject *object, guint param_id,
@@ -51,9 +49,17 @@ static void rb_segmented_bar_set_property (GObject *object, guint param_id,
static gchar *rb_segmented_bar_default_value_formatter (gdouble percent,
gpointer data);
+static void rb_segmented_bar_get_preferred_height (GtkWidget *widget,
+ int *minimum_height,
+ int *natural_height);
+static void rb_segmented_bar_get_preferred_width (GtkWidget *widget,
+ int *minimum_width,
+ int *natural_width);
static void compute_layout_size (RBSegmentedBar *bar);
+static AtkObject * rb_segmented_bar_get_accessible (GtkWidget *widget);
+
enum
{
PROP_0,
@@ -79,6 +85,9 @@ struct _RBSegmentedBarPrivate {
RBSegmentedBarValueFormatter value_formatter;
gpointer value_formatter_data;
+
+ char *a11y_description;
+ char *a11y_locale;
};
G_DEFINE_TYPE (RBSegmentedBar, rb_segmented_bar, GTK_TYPE_WIDGET)
@@ -135,7 +144,7 @@ rb_segmented_bar_init (RBSegmentedBar *bar)
priv->segment_box_size = 12;
priv->segment_box_spacing = 6;
priv->value_formatter = rb_segmented_bar_default_value_formatter;
- GTK_WIDGET_SET_FLAGS (GTK_WIDGET (bar), GTK_NO_WINDOW);
+ gtk_widget_set_has_window (GTK_WIDGET (bar), FALSE);
}
static void
@@ -148,9 +157,11 @@ rb_segmented_bar_class_init (RBSegmentedBarClass *klass)
object_class->get_property = rb_segmented_bar_get_property;
object_class->set_property = rb_segmented_bar_set_property;
- widget_class->expose_event = rb_segmented_bar_expose;
- widget_class->size_request = rb_segmented_bar_size_request;
+ widget_class->draw = rb_segmented_bar_draw;
+ widget_class->get_preferred_width = rb_segmented_bar_get_preferred_width;
+ widget_class->get_preferred_height = rb_segmented_bar_get_preferred_height;
widget_class->size_allocate = rb_segmented_bar_size_allocate;
+ widget_class->get_accessible = rb_segmented_bar_get_accessible;
/**
* RBSegmentedBar::show-reflection
@@ -263,29 +274,45 @@ rb_segmented_bar_default_value_formatter (gdouble percent,
}
static void
-rb_segmented_bar_size_request (GtkWidget *widget,
- GtkRequisition *requisition)
+rb_segmented_bar_get_preferred_height (GtkWidget *widget, int *minimum_height, int *natural_height)
{
RBSegmentedBarPrivate *priv;
- guint real_height;
+ unsigned int height;
- g_return_if_fail (requisition != NULL);
priv = RB_SEGMENTED_BAR_GET_PRIVATE (RB_SEGMENTED_BAR (widget));
-
if (priv->reflect) {
- real_height = MINIMUM_HEIGHT*1.75;
+ height = MINIMUM_HEIGHT * 1.75;
} else {
- real_height = MINIMUM_HEIGHT;
+ height = MINIMUM_HEIGHT;
}
+
if (priv->show_labels) {
compute_layout_size (RB_SEGMENTED_BAR (widget));
- requisition->height = MAX (MINIMUM_HEIGHT + priv->bar_label_spacing + priv->layout_height,
- real_height);
- } else {
- requisition->height = real_height;
+ height = MAX (MINIMUM_HEIGHT + priv->bar_label_spacing + priv->layout_height, height);
}
- requisition->width = MAX (priv->layout_width, 200);
+
+ if (minimum_height)
+ *minimum_height = height;
+ if (natural_height)
+ *natural_height = height;
+}
+
+static void
+rb_segmented_bar_get_preferred_width (GtkWidget *widget, int *minimum_width, int *natural_width)
+{
+ RBSegmentedBarPrivate *priv;
+ int width;
+
+ priv = RB_SEGMENTED_BAR_GET_PRIVATE (RB_SEGMENTED_BAR (widget));
+
+ compute_layout_size (RB_SEGMENTED_BAR (widget));
+ width = MAX (priv->layout_width, 200);
+
+ if (minimum_width)
+ *minimum_width = width;
+ if (natural_width)
+ *natural_width = width;
}
static PangoLayout *create_adapt_layout (GtkWidget *widget, PangoLayout *layout,
@@ -389,6 +416,7 @@ rb_segmented_bar_size_allocate(GtkWidget *widget, GtkAllocation *allocation)
{
guint real_height;
RBSegmentedBarPrivate *priv = RB_SEGMENTED_BAR_GET_PRIVATE (widget);
+ GtkAllocation new_allocation;
g_return_if_fail(RB_IS_SEGMENTED_BAR(widget));
g_return_if_fail(allocation != NULL);
@@ -398,16 +426,17 @@ rb_segmented_bar_size_allocate(GtkWidget *widget, GtkAllocation *allocation)
} else {
real_height = priv->bar_height;
}
- widget->allocation = *allocation;
+ gtk_widget_set_allocation (widget, allocation);
if (priv->show_labels) {
compute_layout_size (RB_SEGMENTED_BAR (widget));
- widget->allocation.height = MAX (priv->bar_height + priv->bar_label_spacing +
priv->layout_height,
- real_height);
+ new_allocation.height = MAX (priv->bar_height + priv->bar_label_spacing + priv->layout_height,
+ real_height);
} else {
- widget->allocation.height = real_height;
+ new_allocation.height = real_height;
}
- widget->allocation.width = priv->layout_width + 2*(priv->h_padding);
- GTK_WIDGET_CLASS(rb_segmented_bar_parent_class)->size_allocate(widget, allocation);
+ new_allocation.width = priv->layout_width + 2*(priv->h_padding);
+ gtk_widget_set_allocation (widget, &new_allocation);
+ GTK_WIDGET_CLASS(rb_segmented_bar_parent_class)->size_allocate(widget, allocation);
}
@@ -422,6 +451,10 @@ guint rb_segmented_bar_add_segment (RBSegmentedBar *bar,
Segment *segment = rb_segment_new (title, percent, &color);
priv->segments = g_list_append (priv->segments, segment);
index = g_list_index (priv->segments, segment);
+
+ g_free (priv->a11y_description);
+ priv->a11y_description = NULL;
+
gtk_widget_queue_draw (GTK_WIDGET (bar));
gtk_widget_queue_resize (GTK_WIDGET (bar));
@@ -443,6 +476,9 @@ void rb_segmented_bar_update_segment (RBSegmentedBar *bar,
Segment *segment = g_list_nth_data (priv->segments, segment_index);
if (segment != NULL) {
segment->percent = percent;
+ g_free (priv->a11y_description);
+ priv->a11y_description = NULL;
+
gtk_widget_queue_draw (GTK_WIDGET (bar));
}
}
@@ -647,25 +683,30 @@ static void rb_segmented_bar_render_labels (RBSegmentedBar *bar,
RBSegmentedBarPrivate *priv;
PangoLayout *layout;
Color text_color;
- GdkColor *gdk_color;
+ GdkRGBA gdk_color;
+ gboolean ltr = TRUE;
int x = 0;
GList *it;
- gboolean is_rtl = (gtk_widget_get_direction(GTK_WIDGET(bar)) == GTK_TEXT_DIR_RTL);
priv = RB_SEGMENTED_BAR_GET_PRIVATE (RB_SEGMENTED_BAR (bar));
if (priv->segments == NULL) {
return;
}
- gdk_color = >K_WIDGET (bar)->style->fg[GTK_WIDGET_STATE (GTK_WIDGET (bar))];
- text_color.red = gdk_color->red / 65535.0;
- text_color.green = gdk_color->green / 65535.0;
- text_color.blue = gdk_color->blue / 65535.0;
+ gtk_style_context_get_color (gtk_widget_get_style_context (GTK_WIDGET (bar)),
+ gtk_widget_get_state_flags (GTK_WIDGET (bar)),
+ &gdk_color);
+
+ if (gtk_widget_get_direction (GTK_WIDGET (bar)) == GTK_TEXT_DIR_RTL) {
+ ltr = FALSE;
+ x = priv->layout_width;
+ }
+
+ text_color.red = gdk_color.red;
+ text_color.green = gdk_color.green;
+ text_color.blue = gdk_color.blue;
text_color.alpha = 1.0;
layout = NULL;
- if (is_rtl) {
- x = priv->layout_width - priv->segment_box_size;
- }
for (it = priv->segments; it != NULL; it = it->next) {
cairo_pattern_t *grad;
int layout_width;
@@ -673,6 +714,10 @@ static void rb_segmented_bar_render_labels (RBSegmentedBar *bar,
gchar *value_str;
Segment *segment;
+ if (ltr == FALSE) {
+ x -= priv->segment_box_size + priv->segment_box_spacing;
+ }
+
segment = (Segment *)it->data;
cairo_set_line_width (context, 1);
cairo_rectangle (context, x + 0.5, 2 + 0.5,
@@ -689,18 +734,20 @@ static void rb_segmented_bar_render_labels (RBSegmentedBar *bar,
cairo_stroke (context);
cairo_pattern_destroy (grad);
- if (is_rtl)
- x -= (segment->layout_width + priv->segment_box_spacing);
- else
+ if (ltr) {
x += priv->segment_box_size + priv->segment_box_spacing;
+ }
layout = create_adapt_layout (GTK_WIDGET (bar), layout,
FALSE, TRUE);
pango_layout_set_text (layout, segment->label, -1);
pango_layout_get_pixel_size (layout,
&layout_width, &layout_height);
+ if (ltr == FALSE) {
+ x -= priv->segment_box_spacing + layout_width;
+ }
- cairo_move_to (context, (is_rtl) ? x+((int)segment->layout_width - (int)layout_width) : x, 0);
+ cairo_move_to (context, x, 0);
cairo_set_source_rgba (context,
text_color.red, text_color.green,
text_color.blue, 0.9);
@@ -715,62 +762,56 @@ static void rb_segmented_bar_render_labels (RBSegmentedBar *bar,
pango_layout_set_text (layout, value_str, -1);
g_free (value_str);
- if (is_rtl && ((int)layout_width >= (int)segment->layout_width)) {
- int value_layout_width = layout_width;
- int value_layout_height = layout_height;
- pango_layout_get_pixel_size (layout,
- &value_layout_width, &value_layout_height);
- cairo_move_to (context, x+(segment->layout_width-value_layout_width), layout_height);
- } else {
- cairo_move_to (context, x, layout_height);
- }
+ cairo_move_to (context, x, layout_height);
cairo_set_source_rgba (context,
text_color.red, text_color.green,
text_color.blue, 0.75);
pango_cairo_show_layout (context, layout);
cairo_fill (context);
- if (is_rtl)
- x -= (priv->segment_box_size + priv->segment_label_spacing);
- else
+ if (ltr) {
x += segment->layout_width + priv->segment_label_spacing;
+ } else {
+ x -= segment->layout_width - layout_width;
+ }
}
g_object_unref (G_OBJECT (layout));
}
static gboolean
-rb_segmented_bar_expose (GtkWidget *widget,
- GdkEventExpose *event)
+rb_segmented_bar_draw (GtkWidget *widget, cairo_t *context)
{
RBSegmentedBar *bar;
RBSegmentedBarPrivate *priv;
- cairo_t *context;
cairo_pattern_t *bar_pattern;
+ GtkAllocation allocation;
g_return_val_if_fail (RB_IS_SEGMENTED_BAR (widget), FALSE);
- if (GTK_WIDGET_DRAWABLE (widget) == FALSE) {
- return FALSE;
- }
bar = RB_SEGMENTED_BAR (widget);
priv = RB_SEGMENTED_BAR_GET_PRIVATE (bar);
- context = gdk_cairo_create (GDK_DRAWABLE (widget->window));
-
if (priv->reflect) {
cairo_push_group (context);
}
cairo_set_operator (context, CAIRO_OPERATOR_OVER);
- cairo_translate (context, widget->allocation.x + priv->h_padding,
- widget->allocation.y);
+ gtk_widget_get_allocation (widget, &allocation);
+ if (gtk_widget_get_direction (GTK_WIDGET (widget)) == GTK_TEXT_DIR_LTR) {
+ cairo_translate (context, allocation.x + priv->h_padding, allocation.y);
+ } else {
+ cairo_translate (context,
+ allocation.x + allocation.width - priv->h_padding,
+ allocation.y);
+ cairo_scale (context, -1.0, 1.0);
+ }
cairo_rectangle (context, 0, 0,
- widget->allocation.width - priv->h_padding,
+ allocation.width - priv->h_padding,
MAX (2*priv->bar_height, priv->bar_height + priv->bar_label_spacing +
priv->layout_height));
cairo_clip (context);
bar_pattern = rb_segmented_bar_render (bar,
- widget->allocation.width - 2*priv->h_padding,
+ allocation.width - 2*priv->h_padding,
priv->bar_height);
cairo_save (context);
@@ -785,7 +826,7 @@ rb_segmented_bar_expose (GtkWidget *widget,
cairo_save (context);
cairo_rectangle (context, 0, priv->bar_height,
- widget->allocation.width - priv->h_padding,
+ allocation.width - priv->h_padding,
priv->bar_height);
cairo_clip (context);
cairo_matrix_init_scale (&matrix, 1, -1);
@@ -812,17 +853,16 @@ rb_segmented_bar_expose (GtkWidget *widget,
if (priv->show_labels) {
if (priv->reflect) {
cairo_translate (context,
- widget->allocation.x + (widget->allocation.width -
priv->layout_width)/2,
- widget->allocation.y + priv->bar_height + priv->bar_label_spacing);
+ allocation.x + (allocation.width - priv->layout_width)/2,
+ allocation.y + priv->bar_height + priv->bar_label_spacing);
} else {
cairo_translate (context,
- -priv->h_padding + (widget->allocation.width - priv->layout_width)/2,
+ -priv->h_padding + (allocation.width - priv->layout_width)/2,
priv->bar_height + priv->bar_label_spacing);
}
rb_segmented_bar_render_labels (bar, context);
}
cairo_pattern_destroy (bar_pattern);
- cairo_destroy (context);
return TRUE;
}
@@ -843,3 +883,191 @@ void rb_segmented_bar_set_value_formatter (RBSegmentedBar *bar,
priv->value_formatter = formatter;
priv->value_formatter_data = data;
}
+
+static const char *
+get_a11y_description (RBSegmentedBar *bar)
+{
+ RBSegmentedBarPrivate *priv;
+
+ priv = RB_SEGMENTED_BAR_GET_PRIVATE (bar);
+ if (priv->a11y_description == NULL) {
+ GList *i;
+ GString *desc = g_string_new ("");
+
+ for (i = priv->segments; i != NULL; i = i->next) {
+ Segment *segment;
+ char *value_str;
+
+ segment = (Segment *)i->data;
+
+ g_assert (priv->value_formatter != NULL);
+ value_str = priv->value_formatter (segment->percent,
+ priv->value_formatter_data);
+
+ g_string_append_printf (desc, "%s: %s\n", segment->label, value_str);
+ g_free (value_str);
+ }
+
+ priv->a11y_description = g_string_free (desc, FALSE);
+ }
+ return priv->a11y_description;
+}
+
+static const char *
+get_a11y_locale (RBSegmentedBar *bar)
+{
+ RBSegmentedBarPrivate *priv;
+
+ priv = RB_SEGMENTED_BAR_GET_PRIVATE (bar);
+ if (priv->a11y_locale == NULL) {
+ priv->a11y_locale = setlocale (LC_MESSAGES, "");
+ }
+ return priv->a11y_locale;
+}
+
+/* A11y type hack copied from nautilus/eel/eel-accessibility.c */
+
+static GType
+create_a11y_derived_type (const char *type_name, GType existing_type, GClassInitFunc class_init)
+{
+ GType type;
+ GType parent_atk_type;
+ GTypeQuery query;
+ AtkObjectFactory *factory;
+ GTypeInfo typeinfo = {0,};
+
+ type = g_type_from_name (type_name);
+ if (type != G_TYPE_INVALID) {
+ return type;
+ }
+
+ factory = atk_registry_get_factory (atk_get_default_registry (), existing_type);
+ parent_atk_type = atk_object_factory_get_accessible_type (factory);
+ if (parent_atk_type == G_TYPE_INVALID) {
+ return G_TYPE_INVALID;
+ }
+
+ g_type_query (parent_atk_type, &query);
+ if (class_init) {
+ typeinfo.class_init = class_init;
+ }
+ typeinfo.class_size = query.class_size;
+ typeinfo.instance_size = query.instance_size;
+
+ type = g_type_register_static (parent_atk_type, type_name, &typeinfo, 0);
+ return type;
+}
+
+/* AtkObject implementation */
+
+static gint
+a11y_impl_get_n_children (AtkObject *obj)
+{
+ return 0;
+}
+
+static AtkObject *
+a11y_impl_ref_child (AtkObject *obj, gint i)
+{
+ return NULL;
+}
+
+/* AtkImage */
+
+static void
+a11y_impl_get_image_position (AtkImage *image, gint *x, gint *y, AtkCoordType coord_type)
+{
+ atk_component_get_extents (ATK_COMPONENT (image), x, y, NULL, NULL, coord_type);
+}
+
+static const char *
+a11y_impl_get_image_description (AtkImage *image)
+{
+ RBSegmentedBar *bar;
+ bar = RB_SEGMENTED_BAR (g_object_get_data (G_OBJECT (image), "rb-atk-widget"));
+ return get_a11y_description (bar);
+}
+
+static void
+a11y_impl_get_image_size (AtkImage *image, gint *width, gint *height)
+{
+ GtkAllocation alloc;
+ GtkWidget *widget;
+
+ widget = GTK_WIDGET (g_object_get_data (G_OBJECT (image), "rb-atk-widget"));
+
+ gtk_widget_get_allocation (widget, &alloc);
+ *width = alloc.width;
+ *height = alloc.height;
+}
+
+static const char *
+a11y_impl_get_image_locale (AtkImage *image)
+{
+ RBSegmentedBar *bar;
+ bar = RB_SEGMENTED_BAR (g_object_get_data (G_OBJECT (image), "rb-atk-widget"));
+ return get_a11y_locale (bar);
+}
+
+static void
+rb_segmented_bar_a11y_class_init (AtkObjectClass *klass)
+{
+ AtkObjectClass *atkobject_class = ATK_OBJECT_CLASS (klass);
+
+ atkobject_class->get_n_children = a11y_impl_get_n_children;
+ atkobject_class->ref_child = a11y_impl_ref_child;
+}
+
+static void
+rb_segmented_bar_a11y_image_init (AtkImageIface *iface)
+{
+ iface->get_image_position = a11y_impl_get_image_position;
+ iface->get_image_description = a11y_impl_get_image_description;
+ iface->get_image_size = a11y_impl_get_image_size;
+ iface->get_image_locale = a11y_impl_get_image_locale;
+ /* don't need set_image_description, do we? */
+}
+
+static void
+destroy_accessible (gpointer data, GObject *obj)
+{
+ atk_object_notify_state_change (ATK_OBJECT (data), ATK_STATE_DEFUNCT, TRUE);
+}
+
+static AtkObject *
+rb_segmented_bar_get_accessible (GtkWidget *widget)
+{
+ static GType a11ytype = G_TYPE_INVALID;
+ AtkObject *accessible;
+ accessible = g_object_get_data (G_OBJECT (widget), "rb-atk-object");
+ if (accessible != NULL) {
+ return accessible;
+ }
+
+ if (a11ytype == G_TYPE_INVALID) {
+ const GInterfaceInfo atk_image_info = {
+ (GInterfaceInitFunc) rb_segmented_bar_a11y_image_init,
+ (GInterfaceFinalizeFunc) NULL,
+ NULL
+ };
+
+ a11ytype = create_a11y_derived_type ("RBSegmentedBarA11y",
+ GTK_TYPE_WIDGET,
+ (GClassInitFunc) rb_segmented_bar_a11y_class_init);
+ if (a11ytype == G_TYPE_INVALID) {
+ g_warning ("unable to create a11y type for segmented bar");
+ return NULL;
+ }
+
+ g_type_add_interface_static (a11ytype, ATK_TYPE_IMAGE, &atk_image_info);
+ }
+
+ accessible = g_object_new (a11ytype, NULL);
+ atk_object_set_role (accessible, ATK_ROLE_IMAGE);
+ atk_object_initialize (accessible, widget);
+
+ g_object_set_data_full (G_OBJECT (widget), "rb-atk-object", accessible, (GDestroyNotify)
destroy_accessible);
+ g_object_set_data (G_OBJECT (accessible), "rb-atk-widget", widget);
+
+ return accessible;
+}
\ No newline at end of file
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]