summaryrefslogtreecommitdiff
path: root/gtk/gtktextlayout.c
diff options
context:
space:
mode:
authorSebastien Lafargue <slafargue@gnome.org>2014-12-18 20:52:58 +0100
committerSebastien Lafargue <slafargue@gnome.org>2014-12-18 20:52:58 +0100
commit73c8f3092820c51058f188313c3249685be42a38 (patch)
treef9b21384aa0aee355813b1dead50faa108fac3e6 /gtk/gtktextlayout.c
parented1fb8d2afa1d7c3bbdd9284a0db09a44bc48327 (diff)
downloadgtk+-73c8f3092820c51058f188313c3249685be42a38.tar.gz
gtktextlayout: fix for right margin with RTL text
When a RTL paragraph is not set to wrap, the right margin is not respected because of the margins counted twice so we replace display->width by PIXEL_BOUND (extents.width), the same quantity without the margins. https://bugzilla.gnome.org/show_bug.cgi?id=741702
Diffstat (limited to 'gtk/gtktextlayout.c')
-rw-r--r--gtk/gtktextlayout.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/gtk/gtktextlayout.c b/gtk/gtktextlayout.c
index 44b87bbd99..55a0e1254b 100644
--- a/gtk/gtktextlayout.c
+++ b/gtk/gtktextlayout.c
@@ -2147,6 +2147,7 @@ gtk_text_layout_get_line_display (GtkTextLayout *layout,
GtkTextIter iter;
GtkTextAttributes *style;
gchar *text;
+ gint text_pixel_width;
PangoAttrList *attrs;
gint text_allocated, layout_byte_offset, buffer_byte_offset;
PangoRectangle extents;
@@ -2465,7 +2466,8 @@ gtk_text_layout_get_line_display (GtkTextLayout *layout,
pango_layout_get_extents (display->layout, NULL, &extents);
- display->width = PIXEL_BOUND (extents.width) + display->left_margin + display->right_margin;
+ text_pixel_width = PIXEL_BOUND (extents.width);
+ display->width = text_pixel_width + display->left_margin + display->right_margin;
display->height += PANGO_PIXELS (extents.height);
/* If we aren't wrapping, we need to do the alignment of each
@@ -2473,7 +2475,7 @@ gtk_text_layout_get_line_display (GtkTextLayout *layout,
*/
if (pango_layout_get_width (display->layout) < 0)
{
- gint excess = display->total_width - display->width;
+ gint excess = display->total_width - text_pixel_width;
switch (pango_layout_get_alignment (display->layout))
{