Mercurial > emacs
changeset 89848:3edfa038a435
(detect_coding_emacs_mule): Fix counting of encoded
byte sequence.
(detect_coding_ccl): Fix setting of the variable valids.
author | Kenichi Handa <handa@m17n.org> |
---|---|
date | Mon, 08 Mar 2004 23:15:42 +0000 (2004-03-08) |
parents | 5caa5e061a07 |
children | 85a6eb05dc8f |
files | src/coding.c |
diffstat | 1 files changed, 12 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/src/coding.c Thu Mar 04 23:33:44 2004 +0000 +++ b/src/coding.c Mon Mar 08 23:15:42 2004 +0000 @@ -1808,14 +1808,19 @@ } else { - const unsigned char *src_base = src - 1; - - do + int more_bytes = emacs_mule_bytes[*src_base] - 1; + + while (more_bytes > 0) { ONE_MORE_BYTE (c); + if (c < 0xA0) + { + src--; /* Unread the last byte. */ + break; + } + more_bytes--; } - while (c >= 0xA0); - if (src - src_base != emacs_mule_bytes[*src_base]) + if (more_bytes != 0) break; found = CATEGORY_MASK_EMACS_MULE; } @@ -4354,13 +4359,14 @@ int multibytep = coding->src_multibyte; int consumed_chars = 0; int found = 0; - unsigned char *valids = CODING_CCL_VALIDS (coding); + unsigned char *valids; int head_ascii = coding->head_ascii; Lisp_Object attrs; detect_info->checked |= CATEGORY_MASK_CCL; coding = &coding_categories[coding_category_ccl]; + valids = CODING_CCL_VALIDS (coding); attrs = CODING_ID_ATTRS (coding->id); if (! NILP (CODING_ATTR_ASCII_COMPAT (attrs))) src += head_ascii;