From f8449323058067b822415b4821e2eb66effe0ecb Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Fri, 6 Mar 1998 21:57:04 +0000 Subject: [PATCH] (advance_to_char_boundary): Handle the case the code 0240..0377 is not a constituent of a multibyte sequence. --- src/buffer.c | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/src/buffer.c b/src/buffer.c index 9879e8520b..9fcae96e8b 100644 --- a/src/buffer.c +++ b/src/buffer.c @@ -1683,12 +1683,22 @@ static int advance_to_char_boundary (byte_pos) int byte_pos; { - int c = FETCH_BYTE (byte_pos); + int c; - while (! CHAR_HEAD_P (c)) + if (byte_pos == BEG) + /* Beginning of buffer is always a character boundary. */ + return 1; + + c = FETCH_BYTE (byte_pos); + if (! CHAR_HEAD_P (c)) { - byte_pos++; - c = FETCH_BYTE (byte_pos); + /* We should advance BYTE_POS only when C is a constituen of a + multibyte sequence. */ + DEC_POS (byte_pos); + INC_POS (byte_pos); + /* If C is a constituent of a multibyte sequence, BYTE_POS was + surely advance to the correct character boundary. If C is + not, BYTE_POS was unchanged. */ } return byte_pos; -- 2.20.1