1
0
mirror of https://github.com/m00natic/vlfi.git synced 2025-01-18 12:05:31 +00:00

Optimize unconditional chunk loading and prefer it in more cases of

overlapping batch moves.
This commit is contained in:
Andrey Kotlarski 2014-12-13 18:46:57 +02:00
parent f4526a1492
commit 0fa624837a

View File

@ -140,8 +140,11 @@ bytes added to the end."
(if (consp hexl-undo-list) (if (consp hexl-undo-list)
(setq hexl-undo-list nil)) (setq hexl-undo-list nil))
(vlf-move-to-chunk-2 start end))) (vlf-move-to-chunk-2 start end)))
((or (and (<= start vlf-start-pos) (<= edit-end end)) ((and (not modified)
(not modified) (not (consp buffer-undo-list)))
(vlf-move-to-chunk-2 start end))
((or (not modified)
(and (<= start vlf-start-pos) (<= edit-end end))
(y-or-n-p "Chunk modified, are you sure? ")) (y-or-n-p "Chunk modified, are you sure? "))
(run-hooks 'vlf-before-chunk-update) (run-hooks 'vlf-before-chunk-update)
(when (and hexl (not restore-hexl)) (when (and hexl (not restore-hexl))
@ -224,29 +227,40 @@ bytes added to the end."
Return number of bytes moved back for proper decoding and number of Return number of bytes moved back for proper decoding and number of
bytes added to the end." bytes added to the end."
(run-hooks 'vlf-before-chunk-update) (run-hooks 'vlf-before-chunk-update)
(vlf-verify-size t) (let ((adjust-start t)
(setq vlf-start-pos (max 0 start) (adjust-end t)
vlf-end-pos (min end vlf-file-size)) (is-hexl (derived-mode-p 'hexl-mode)))
(let ((shifts '(0 . 0))) (and (not is-hexl)
(let ((inhibit-read-only t) (verify-visited-file-modtime (current-buffer))
(pos (position-bytes (point)))) (setq adjust-start (and (/= start vlf-start-pos)
(vlf-with-undo-disabled (/= start vlf-end-pos))
(erase-buffer) adjust-end (and (/= end vlf-start-pos)
(if (derived-mode-p 'hexl-mode) (/= end vlf-end-pos))))
(progn (vlf-tune-insert-file-contents-literally (vlf-verify-size t)
vlf-start-pos vlf-end-pos) (setq vlf-start-pos (max 0 start)
(vlf-tune-hexlify)) vlf-end-pos (min end vlf-file-size))
(setq shifts (vlf-insert-file-contents vlf-start-pos (let ((shifts '(0 . 0)))
vlf-end-pos t t) (let ((inhibit-read-only t)
vlf-start-pos (- vlf-start-pos (car shifts)) (pos (position-bytes (point))))
vlf-end-pos (+ vlf-end-pos (cdr shifts))))) (vlf-with-undo-disabled
(goto-char (or (byte-to-position (+ pos (car shifts))) (erase-buffer)
(point-max)))) (if is-hexl
(set-buffer-modified-p nil) (progn (vlf-tune-insert-file-contents-literally
(or (eq buffer-undo-list t) vlf-start-pos vlf-end-pos)
(setq buffer-undo-list nil)) (vlf-tune-hexlify))
(run-hooks 'vlf-after-chunk-update) (setq shifts (vlf-insert-file-contents vlf-start-pos
shifts)) vlf-end-pos
adjust-start
adjust-end)
vlf-start-pos (- vlf-start-pos (car shifts))
vlf-end-pos (+ vlf-end-pos (cdr shifts)))))
(goto-char (or (byte-to-position (+ pos (car shifts)))
(point-max))))
(set-buffer-modified-p nil)
(or (eq buffer-undo-list t)
(setq buffer-undo-list nil))
(run-hooks 'vlf-after-chunk-update)
shifts)))
(defun vlf-insert-file-contents (start end adjust-start adjust-end (defun vlf-insert-file-contents (start end adjust-start adjust-end
&optional position) &optional position)
@ -257,7 +271,7 @@ Use buffer POSITION as start if given.
Return number of bytes moved back for proper decoding and number of Return number of bytes moved back for proper decoding and number of
bytes added to the end." bytes added to the end."
(setq adjust-start (and adjust-start (not (zerop start))) (setq adjust-start (and adjust-start (not (zerop start)))
adjust-end (and adjust-end (< end vlf-file-size)) adjust-end (and adjust-end (/= end vlf-file-size))
position (or position (point-min))) position (or position (point-min)))
(goto-char position) (goto-char position)
(let ((shift-start 0) (let ((shift-start 0)