From 862b479030730c1ddb60d9a6dc55e1f8a12e59eb Mon Sep 17 00:00:00 2001 From: Gerd Moellmann Date: Fri, 6 Aug 1999 15:05:27 +0000 Subject: [PATCH] (set_window_cursor_after_update): Correct cursor position if cursor_in_echo_area: --- src/dispnew.c | 41 +++++++++++++++++++++++++---------------- 1 file changed, 25 insertions(+), 16 deletions(-) diff --git a/src/dispnew.c b/src/dispnew.c index cac7a051767..4875f736b99 100644 --- a/src/dispnew.c +++ b/src/dispnew.c @@ -4028,28 +4028,37 @@ set_window_cursor_after_update (w) line that has any text on it. Note: either all lines are enabled or none. Otherwise we wouldn't be able to determine Y. */ - struct glyph_row *row = MATRIX_ROW (w->current_matrix, 0); - int vpos, last_row_vpos; - struct glyph_row *last_row = NULL; + struct glyph_row *row, *last_row; + struct glyph *glyph; + int yb = window_text_bottom_y (w); - vpos = 0; - while (vpos < w->current_matrix->nrows) + last_row = NULL; + for (row = MATRIX_ROW (w->current_matrix, 0);; ++row) { - if (row->enabled_p && row->used[TEXT_AREA]) - { - last_row = row; - last_row_vpos = vpos; - } - ++row; - ++vpos; - } + if (row->used[TEXT_AREA] + && row->glyphs[TEXT_AREA][0].charpos >= 0) + last_row = row; + if (MATRIX_ROW_BOTTOM_Y (row) >= yb) + break; + } + if (last_row) { - cx = last_row->pixel_width; - hpos = last_row->used[TEXT_AREA]; + struct glyph *start = row->glyphs[TEXT_AREA]; + struct glyph *last = start + row->used[TEXT_AREA]; + + while (last > start && (last - 1)->charpos < 0) + --last; + + for (glyph = start; glyph < last; ++glyph) + { + cx += glyph->pixel_width; + ++hpos; + } + cy = last_row->y; - vpos = last_row_vpos; + vpos = MATRIX_ROW_VPOS (last_row, w->current_matrix); } } } -- 2.39.5