summaryrefslogtreecommitdiffstats
path: root/src/widgets/icon.cpp
diff options
context:
space:
mode:
authorDenis Declara <declara91@gmail.com>2012-04-26 11:14:34 +0000
committerDenis Declara <declara91@gmail.com>2012-04-26 11:14:34 +0000
commit95a8ad7bfec98f7cede15c4e8856ce547aaf4aa4 (patch)
tree506de5a8437cb39917a66d74b68d78692d10a993 /src/widgets/icon.cpp
parentAdded first support for elliptical arrangements (diff)
parentpowerstroke: cautious fix. (diff)
downloadinkscape-95a8ad7bfec98f7cede15c4e8856ce547aaf4aa4.tar.gz
inkscape-95a8ad7bfec98f7cede15c4e8856ce547aaf4aa4.zip
Trunk merge
(bzr r11073.1.20)
Diffstat (limited to 'src/widgets/icon.cpp')
-rw-r--r--src/widgets/icon.cpp28
1 files changed, 28 insertions, 0 deletions
diff --git a/src/widgets/icon.cpp b/src/widgets/icon.cpp
index 7f027870d..a58645015 100644
--- a/src/widgets/icon.cpp
+++ b/src/widgets/icon.cpp
@@ -61,6 +61,15 @@ struct IconImpl {
static void clear(SPIcon *icon);
static void sizeRequest(GtkWidget *widget, GtkRequisition *requisition);
+
+ static void getPreferredWidth(GtkWidget *widget,
+ gint *minimal_width,
+ gint *natural_width);
+
+ static void getPreferredHeight(GtkWidget *widget,
+ gint *minimal_height,
+ gint *natural_height);
+
static void sizeAllocate(GtkWidget *widget, GtkAllocation *allocation);
static int expose(GtkWidget *widget, GdkEventExpose *event);
@@ -172,7 +181,12 @@ void IconImpl::classInit(SPIconClass *klass)
object_class->dispose = IconImpl::dispose;
+#if GTK_CHECK_VERSION(3,0,0)
+ widget_class->get_preferred_width = IconImpl::getPreferredWidth;
+ widget_class->get_preferred_height = IconImpl::getPreferredHeight;
+#else
widget_class->size_request = IconImpl::sizeRequest;
+#endif
widget_class->size_allocate = IconImpl::sizeAllocate;
widget_class->expose_event = IconImpl::expose;
widget_class->screen_changed = IconImpl::screenChanged;
@@ -225,6 +239,20 @@ void IconImpl::sizeRequest(GtkWidget *widget, GtkRequisition *requisition)
requisition->height = size;
}
+void IconImpl::getPreferredWidth(GtkWidget *widget, gint *minimal_width, gint *natural_width)
+{
+ GtkRequisition requisition;
+ sizeRequest(widget, &requisition);
+ *minimal_width = *natural_width = requisition.width;
+}
+
+void IconImpl::getPreferredHeight(GtkWidget *widget, gint *minimal_height, gint *natural_height)
+{
+ GtkRequisition requisition;
+ sizeRequest(widget, &requisition);
+ *minimal_height = *natural_height = requisition.height;
+}
+
void IconImpl::sizeAllocate(GtkWidget *widget, GtkAllocation *allocation)
{
gtk_widget_set_allocation(widget, allocation);