Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Open sidebar
emacs
emacs
Commits
cf907d69
Commit
cf907d69
authored
Apr 09, 2008
by
Jason Rumney
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(w32_compute_glyph_string_overhangs): Compute overhangs
for new font backend and composite cases.
parent
418fddf5
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
2 deletions
+34
-2
src/ChangeLog
src/ChangeLog
+7
-1
src/w32term.c
src/w32term.c
+27
-1
No files found.
src/ChangeLog
View file @
cf907d69
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.
...
...
src/w32term.c
View file @
cf907d69
...
...
@@ -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,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment