summaryrefslogtreecommitdiffstats
path: root/src/svg-view-widget.cpp
diff options
context:
space:
mode:
authorAlex Valavanis <valavanisalex@gmail.com>2012-04-17 11:21:44 +0000
committerAlex Valavanis <valavanisalex@gmail.com>2012-04-17 11:21:44 +0000
commite48a286477d5b8d1d0f9188262e8252d5f77380b (patch)
treef255b920768d807c134c973649c50d5788c922f0 /src/svg-view-widget.cpp
parentFix for 169888 : HIG Style frame (diff)
downloadinkscape-e48a286477d5b8d1d0f9188262e8252d5f77380b.tar.gz
inkscape-e48a286477d5b8d1d0f9188262e8252d5f77380b.zip
Work around for some missing glibmm headers in gtkmm (should be fixed in gtkmm 3.4)
(bzr r11261)
Diffstat (limited to 'src/svg-view-widget.cpp')
-rw-r--r--src/svg-view-widget.cpp27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/svg-view-widget.cpp b/src/svg-view-widget.cpp
index 0e962a711..f0e366505 100644
--- a/src/svg-view-widget.cpp
+++ b/src/svg-view-widget.cpp
@@ -29,6 +29,14 @@ static void sp_svg_view_widget_destroy (GtkObject *object);
static void sp_svg_view_widget_size_allocate (GtkWidget *widget, GtkAllocation *allocation);
static void sp_svg_view_widget_size_request (GtkWidget *widget, GtkRequisition *req);
+static void sp_svg_view_widget_get_preferred_width(GtkWidget *widget,
+ gint *minimal_width,
+ gint *natural_width);
+
+static void sp_svg_view_widget_get_preferred_height(GtkWidget *widget,
+ gint *minimal_height,
+ gint *natural_height);
+
static void sp_svg_view_widget_view_resized (SPViewWidget *vw, Inkscape::UI::View::View *view, gdouble width, gdouble height);
static SPViewWidgetClass *widget_parent_class;
@@ -68,7 +76,12 @@ static void sp_svg_view_widget_class_init(SPSVGSPViewWidgetClass *klass)
object_class->destroy = sp_svg_view_widget_destroy;
widget_class->size_allocate = sp_svg_view_widget_size_allocate;
+#if GTK_CHECK_VERSION(3,0,0)
+ widget_class->get_preferred_width = sp_svg_view_widget_get_preferred_width;
+ widget_class->get_preferred_height = sp_svg_view_widget_get_preferred_height;
+#else
widget_class->size_request = sp_svg_view_widget_size_request;
+#endif
vw_class->view_resized = sp_svg_view_widget_view_resized;
}
@@ -164,6 +177,20 @@ static void sp_svg_view_widget_size_request(GtkWidget *widget, GtkRequisition *r
}
}
+static void sp_svg_view_widget_get_preferred_width(GtkWidget *widget, gint *minimal_width, gint *natural_width)
+{
+ GtkRequisition requisition;
+ sp_svg_view_widget_size_request(widget, &requisition);
+ *minimal_width = *natural_width = requisition.width;
+}
+
+static void sp_svg_view_widget_get_preferred_height(GtkWidget *widget, gint *minimal_height, gint *natural_height)
+{
+ GtkRequisition requisition;
+ sp_svg_view_widget_size_request(widget, &requisition);
+ *minimal_height = *natural_height = requisition.height;
+}
+
/**
* Callback connected with size_allocate signal.
*/