coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
This commit is contained in:
parent
35cd7cd68e
commit
fbdc17211b
2 changed files with 15 additions and 7 deletions
|
@ -1,3 +1,8 @@
|
|||
2010-03-16 Kenichi Handa <handa@m17n.org>
|
||||
|
||||
* coding.c (decode_coding_ccl): Fix previous change for the
|
||||
multibyte case.
|
||||
|
||||
2010-03-15 Andreas Politz <politza@fh-trier.de> (tiny change)
|
||||
|
||||
* editfns.c (Fformat): Account for string precision when computing
|
||||
|
|
17
src/coding.c
17
src/coding.c
|
@ -5245,7 +5245,7 @@ decode_coding_ccl (coding)
|
|||
int multibytep = coding->src_multibyte;
|
||||
struct ccl_program *ccl = &coding->spec.ccl->ccl;
|
||||
int source_charbuf[1024];
|
||||
int source_byteidx[1024];
|
||||
int source_byteidx[1025];
|
||||
Lisp_Object attrs, charset_list;
|
||||
|
||||
CODING_GET_INFO (coding, attrs, charset_list);
|
||||
|
@ -5256,11 +5256,14 @@ decode_coding_ccl (coding)
|
|||
int i = 0;
|
||||
|
||||
if (multibytep)
|
||||
while (i < 1024 && p < src_end)
|
||||
{
|
||||
source_byteidx[i] = p - src;
|
||||
source_charbuf[i++] = STRING_CHAR_ADVANCE (p);
|
||||
}
|
||||
{
|
||||
while (i < 1024 && p < src_end)
|
||||
{
|
||||
source_byteidx[i] = p - src;
|
||||
source_charbuf[i++] = STRING_CHAR_ADVANCE (p);
|
||||
}
|
||||
source_byteidx[i] = p - src;
|
||||
}
|
||||
else
|
||||
while (i < 1024 && p < src_end)
|
||||
source_charbuf[i++] = *p++;
|
||||
|
@ -5270,7 +5273,7 @@ decode_coding_ccl (coding)
|
|||
ccl_driver (ccl, source_charbuf, charbuf, i, charbuf_end - charbuf,
|
||||
charset_list);
|
||||
charbuf += ccl->produced;
|
||||
if (multibytep && ccl->consumed < i)
|
||||
if (multibytep)
|
||||
src += source_byteidx[ccl->consumed];
|
||||
else
|
||||
src += ccl->consumed;
|
||||
|
|
Loading…
Add table
Reference in a new issue