summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJason Rumney <jasonr@gnu.org>2008-04-09 12:14:52 +0000
committerJason Rumney <jasonr@gnu.org>2008-04-09 12:14:52 +0000
commitcf907d69ddd44c09dc5b5c12230b40e4cc9779d7 (patch)
tree3b2ab3ad1c36e9461df127733c943a1eb378e982 /src
parent418fddf54bc687634693875991a1491290a7f98d (diff)
downloademacs-cf907d69ddd44c09dc5b5c12230b40e4cc9779d7.tar.gz
(w32_compute_glyph_string_overhangs): Compute overhangs
for new font backend and composite cases.
Diffstat (limited to 'src')
-rw-r--r--src/ChangeLog8
-rw-r--r--src/w32term.c28
2 files changed, 34 insertions, 2 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index 179fcadfc21..a9ba878737e 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,3 +1,8 @@
+2008-04-09 Jason Rumney <jasonr@gnu.org>
+
+ * w32term.c (w32_compute_glyph_string_overhangs): Compute overhangs
+ for new font backend and composite cases.
+
2008-04-09 Jan Djärv <jan.h.d@swipnet.se>
* atimer.c (alarm_signal_handler): Call run_timers if not SYNC_INPUT.
@@ -5,7 +10,8 @@
(do_pending_atimers): Call run_timers.
(run_timers): New function.
- * sysdep.c (emacs_write): If SYNC_INPUT and pending_atimers, run atimers.
+ * sysdep.c (emacs_write): If SYNC_INPUT and pending_atimers,
+ run atimers.
* process.c (wait_reading_process_output): The same as above.
diff --git a/src/w32term.c b/src/w32term.c
index 944c0f9fa43..a40fe2edc48 100644
--- a/src/w32term.c
+++ b/src/w32term.c
@@ -1763,9 +1763,35 @@ static void
w32_compute_glyph_string_overhangs (s)
struct glyph_string *s;
{
+ if (s->cmp == NULL
+ && s->first_glyph->type == CHAR_GLYPH)
+ {
+#ifdef USE_FONT_BACKEND
+ if (enable_font_backend)
+ {
+ unsigned *code = alloca (sizeof (unsigned) * s->nchars);
+ struct font *font = (struct font *) s->font_info;
+ struct font_metrics metrics;
+ int i;
+
+ for (i = 0; i < s->nchars; i++)
+ code[i] = s->char2b[i];
+ font->driver->text_extents (font, code, s->nchars, &metrics);
+ s->right_overhang = (metrics.rbearing > metrics.width
+ ? metrics.rbearing - metrics.width : 0);
+ s->left_overhang = metrics.lbearing < 0 ? -metrics.lbearing : 0;
+ }
+#else
/* TODO: Windows does not appear to have a method for
getting this info without getting the ABC widths for each
individual character and working it out manually. */
+#endif
+ }
+ else if (s->cmp)
+ {
+ s->right_overhang = s->cmp->rbearing - s->cmp->pixel_width;
+ s->left_overhang = -s->cmp->lbearing;
+ }
}
@@ -6892,7 +6918,7 @@ static struct redisplay_interface w32_redisplay_interface =
w32_destroy_fringe_bitmap,
w32_per_char_metric,
w32_encode_char,
- NULL, /* w32_compute_glyph_string_overhangs */
+ w32_compute_glyph_string_overhangs,
x_draw_glyph_string,
w32_define_frame_cursor,
w32_clear_frame_area,