Avoid rare crashes while producing line numbers
* src/xdisp.c (maybe_produce_line_number): Prevent freeing of realized faces for as long as we are using lnum_face_id and current_lnum_face_id for producing glyphs. (Bug#44111)
This commit is contained in:
parent
18c0e20bea
commit
e29cace60a
1 changed files with 7 additions and 0 deletions
|
@ -22793,6 +22793,10 @@ maybe_produce_line_number (struct it *it)
|
|||
int lnum_face_id = merge_faces (it->w, Qline_number, 0, DEFAULT_FACE_ID);
|
||||
int current_lnum_face_id
|
||||
= merge_faces (it->w, Qline_number_current_line, 0, DEFAULT_FACE_ID);
|
||||
/* From here onwards, we must prevent freeing realized faces, because
|
||||
we are using the above 2 face IDs for the glyphs we produce. */
|
||||
bool save_free_realized_faces = inhibit_free_realized_faces;
|
||||
inhibit_free_realized_faces = true;
|
||||
/* Compute point's line number if needed. */
|
||||
if ((EQ (Vdisplay_line_numbers, Qrelative)
|
||||
|| EQ (Vdisplay_line_numbers, Qvisual)
|
||||
|
@ -22922,10 +22926,13 @@ maybe_produce_line_number (struct it *it)
|
|||
it->lnum_width = 0;
|
||||
it->lnum_pixel_width = 0;
|
||||
bidi_unshelve_cache (itdata, false);
|
||||
inhibit_free_realized_faces = save_free_realized_faces;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
inhibit_free_realized_faces = save_free_realized_faces;
|
||||
|
||||
/* Record the width in pixels we need for the line number display. */
|
||||
it->lnum_pixel_width = tem_it.current_x;
|
||||
/* Copy the produced glyphs into IT's glyph_row. */
|
||||
|
|
Loading…
Add table
Reference in a new issue