summaryrefslogtreecommitdiff
path: root/src/insdel.c
diff options
context:
space:
mode:
authorKenichi Handa <handa@gnu.org>2013-03-10 23:36:35 +0900
committerKenichi Handa <handa@gnu.org>2013-03-10 23:36:35 +0900
commitc230dd7d89730f565df77046d0666d2082e386ee (patch)
tree9f63b2d8ba43f9ab3d244e252aaf9f26fea12daa /src/insdel.c
parent27a98a62d1c46b057428cc3ed964743b69628299 (diff)
On file insertion, skip decoding if all bytes are ASCII.
Diffstat (limited to 'src/insdel.c')
-rw-r--r--src/insdel.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/insdel.c b/src/insdel.c
index fc5a4576dc..992cebb04b 100644
--- a/src/insdel.c
+++ b/src/insdel.c
@@ -1162,14 +1162,16 @@ insert_from_buffer_1 (struct buffer *buf,
/* Record undo information and adjust markers and position keepers for
a replacement of a text PREV_TEXT at FROM to a new text of LEN
- chars (LEN_BYTE bytes) which resides in the gap just after
- GPT_ADDR.
+ chars (LEN_BYTE bytes). If TEXT_AT_GAP_TAIL is zero, the new text
+ resides in the gap just after GPT_BYTE. Otherwise, the text
+ resides at the gap tail; i.e. at (GAP_END_ADDR - LEN_BNYTE).
PREV_TEXT nil means the new text was just inserted. */
-static void
+void
adjust_after_replace (ptrdiff_t from, ptrdiff_t from_byte,
- Lisp_Object prev_text, ptrdiff_t len, ptrdiff_t len_byte)
+ Lisp_Object prev_text, ptrdiff_t len, ptrdiff_t len_byte,
+ int text_at_gap_tail)
{
ptrdiff_t nchars_del = 0, nbytes_del = 0;
@@ -1189,8 +1191,11 @@ adjust_after_replace (ptrdiff_t from, ptrdiff_t from_byte,
GAP_SIZE -= len_byte;
ZV += len; Z+= len;
ZV_BYTE += len_byte; Z_BYTE += len_byte;
- GPT += len; GPT_BYTE += len_byte;
- if (GAP_SIZE > 0) *(GPT_ADDR) = 0; /* Put an anchor. */
+ if (! text_at_gap_tail)
+ {
+ GPT += len; GPT_BYTE += len_byte;
+ if (GAP_SIZE > 0) *(GPT_ADDR) = 0; /* Put an anchor. */
+ }
if (nchars_del > 0)
adjust_markers_for_replace (from, from_byte, nchars_del, nbytes_del,
@@ -1245,7 +1250,7 @@ adjust_after_insert (ptrdiff_t from, ptrdiff_t from_byte,
GPT -= len; GPT_BYTE -= len_byte;
ZV -= len; ZV_BYTE -= len_byte;
Z -= len; Z_BYTE -= len_byte;
- adjust_after_replace (from, from_byte, Qnil, newlen, len_byte);
+ adjust_after_replace (from, from_byte, Qnil, newlen, len_byte, 0);
}
/* Replace the text from character positions FROM to TO with NEW,