aboutsummaryrefslogtreecommitdiffstats
path: root/src/coding.c
diff options
context:
space:
mode:
authorRichard M. Stallman2013-07-19 12:15:51 -0400
committerRichard M. Stallman2013-07-19 12:15:51 -0400
commita1aeeffedd3b05a33bdd73737651debbda00cf5f (patch)
tree2f1688d0640a0cc9f620175d3d633bb3879a6df1 /src/coding.c
parent8ba8eec59b955466c7080b268709a6d195fb69ee (diff)
downloademacs-a1aeeffedd3b05a33bdd73737651debbda00cf5f.tar.gz
emacs-a1aeeffedd3b05a33bdd73737651debbda00cf5f.zip
(decode_coding_utf_8): Add simple loop for fast processing of ASCII characters.
Diffstat (limited to 'src/coding.c')
-rw-r--r--src/coding.c39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/coding.c b/src/coding.c
index e779197bbde..385a22a188d 100644
--- a/src/coding.c
+++ b/src/coding.c
@@ -1363,6 +1363,45 @@ decode_coding_utf_8 (struct coding_system *coding)
1363 break; 1363 break;
1364 } 1364 }
1365 1365
1366 /* In the simple case, rapidly handle ordinary characters */
1367 if (multibytep && ! eol_dos
1368 && charbuf < charbuf_end - 6 && src < src_end - 6)
1369 {
1370 while (charbuf < charbuf_end - 6 && src < src_end - 6)
1371 {
1372 c1 = *src;
1373 if (c1 & 0x80)
1374 break;
1375 src++;
1376 consumed_chars++;
1377 *charbuf++ = c1;
1378
1379 c1 = *src;
1380 if (c1 & 0x80)
1381 break;
1382 src++;
1383 consumed_chars++;
1384 *charbuf++ = c1;
1385
1386 c1 = *src;
1387 if (c1 & 0x80)
1388 break;
1389 src++;
1390 consumed_chars++;
1391 *charbuf++ = c1;
1392
1393 c1 = *src;
1394 if (c1 & 0x80)
1395 break;
1396 src++;
1397 consumed_chars++;
1398 *charbuf++ = c1;
1399 }
1400 /* If we handled at least one character, restart the main loop. */
1401 if (src != src_base)
1402 continue;
1403 }
1404
1366 if (byte_after_cr >= 0) 1405 if (byte_after_cr >= 0)
1367 c1 = byte_after_cr, byte_after_cr = -1; 1406 c1 = byte_after_cr, byte_after_cr = -1;
1368 else 1407 else