From: Eli Zaretskii Date: Sat, 11 May 2002 21:33:13 +0000 (+0000) Subject: (decode_coding) : If a lone CR X-Git-Tag: ttn-vms-21-2-B4~15100 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=9861e77766003a825f40d3da073f1dca566fe1d9;p=emacs.git (decode_coding) : If a lone CR characters is carried over from the previous block of text, adjust coding->produced to account for the extra character. --- diff --git a/src/ChangeLog b/src/ChangeLog index 570c82c9628..0f7ad163d55 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,9 @@ +2002-05-12 Eli Zaretskii + + * coding.c (decode_coding) : If a lone CR + characters is carried over from the previous block of text, adjust + coding->produced to account for the extra character. + 2002-05-11 Andreas Schwab * coding.c (intersection): Keep the elements of the returned list diff --git a/src/coding.c b/src/coding.c index baf6acf08af..be8051ef456 100644 --- a/src/coding.c +++ b/src/coding.c @@ -4590,7 +4590,7 @@ decode_eol_post_ccl (coding, ptr, bytes) { /* If the last character is CR, we can't handle it here because LF will be in the not-yet-decoded source text. - Recorded that the CR is not yet processed. */ + Record that the CR is not yet processed. */ coding->spec.ccl.cr_carryover = 1; coding->produced--; coding->produced_char--; @@ -4686,6 +4686,8 @@ decode_coding (coding, source, destination, src_bytes, dst_bytes) unsigned char *source, *destination; int src_bytes, dst_bytes; { + int extra = 0; + if (coding->type == coding_type_undecided) detect_coding (coding, source, src_bytes); @@ -4728,18 +4730,24 @@ decode_coding (coding, source, destination, src_bytes, dst_bytes) case coding_type_ccl: if (coding->spec.ccl.cr_carryover) { - /* Set the CR which is not processed by the previous call of - decode_eol_post_ccl in DESTINATION. */ + /* Put the CR which was not processed by the previous call + of decode_eol_post_ccl in DESTINATION. It will be + decoded together with the following LF by the call to + decode_eol_post_ccl below. */ *destination = '\r'; coding->produced++; coding->produced_char++; dst_bytes--; + extra = coding->spec.ccl.cr_carryover; } - ccl_coding_driver (coding, source, - destination + coding->spec.ccl.cr_carryover, + ccl_coding_driver (coding, source, destination + extra, src_bytes, dst_bytes, 0); if (coding->eol_type != CODING_EOL_LF) - decode_eol_post_ccl (coding, destination, coding->produced); + { + coding->produced += extra; + coding->produced_char += extra; + decode_eol_post_ccl (coding, destination, coding->produced); + } break; default: