diff options
author | Jason Rumney <jasonr@gnu.org> | 2008-04-09 12:14:52 +0000 |
---|---|---|
committer | Jason Rumney <jasonr@gnu.org> | 2008-04-09 12:14:52 +0000 |
commit | cf907d69ddd44c09dc5b5c12230b40e4cc9779d7 (patch) | |
tree | 3b2ab3ad1c36e9461df127733c943a1eb378e982 /src | |
parent | 418fddf54bc687634693875991a1491290a7f98d (diff) | |
download | emacs-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/ChangeLog | 8 | ||||
-rw-r--r-- | src/w32term.c | 28 |
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, |