From: Stefan Monnier Date: Sun, 25 May 2008 13:48:22 +0000 (+0000) Subject: (tar-summarize-buffer): Handle GNU Tar @LongLink format. X-Git-Tag: emacs-pretest-22.2.90~121 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=a0fefe5742d09595da6b2e839f6da20e815890b8;p=emacs.git (tar-summarize-buffer): Handle GNU Tar @LongLink format. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index ce047a0036e..28a7eac3616 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,7 @@ +2008-05-25 Stefan Monnier + + * tar-mode.el (tar-summarize-buffer): Handle GNU Tar @LongLink format. + 2008-05-24 Alan Mackenzie * progmodes/cc-mode.el (c-postprocess-file-styles): Throw an error diff --git a/lisp/tar-mode.el b/lisp/tar-mode.el index 41476f4250b..04ce5dc83a9 100644 --- a/lisp/tar-mode.el +++ b/lisp/tar-mode.el @@ -421,6 +421,16 @@ is visible (and the real data of the buffer is hidden)." (tar-header-block-tokenize (buffer-substring pos (+ pos 512))))))) (setq pos (+ pos 512)) + (when (equal (tar-header-name tokens) "././@LongLink") + ;; This is a GNU Tar long-file-name header. + (let* ((size (tar-header-size tokens)) + ;; -1 so as to strip the terminating 0 byte. + (name (buffer-substring pos (+ pos size -1)))) + (setq pos (+ pos (ash (ash (+ 511 size) -9) 9))) + (setq tokens (tar-header-block-tokenize + (buffer-substring pos (+ pos 512)))) + (tar-setf (tar-header-name tokens) name) + (setq pos (+ pos 512)))) (progress-reporter-update progress-reporter pos) (if (memq (tar-header-link-type tokens) '(20 55)) ;; Foo. There's an extra empty block after these. @@ -429,20 +439,18 @@ is visible (and the real data of the buffer is hidden)." (if (< size 0) (error "%s has size %s - corrupted" (tar-header-name tokens) size)) - ; - ; This is just too slow. Don't really need it anyway.... - ;(tar-header-block-check-checksum - ; hblock (tar-header-block-checksum hblock) - ; (tar-header-name tokens)) + ;; + ;; This is just too slow. Don't really need it anyway.... + ;;(tar-header-block-check-checksum + ;; hblock (tar-header-block-checksum hblock) + ;; (tar-header-name tokens)) (push (make-tar-desc pos tokens) result) (and (null (tar-header-link-type tokens)) (> size 0) - (setq pos - (+ pos 512 (ash (ash (1- size) -9) 9)) ; this works - ;(+ pos (+ size (- 512 (rem (1- size) 512)))) ; this doesn't - )))) + ;; Round up to a multiple of 512. + (setq pos (+ pos (ash (ash (+ 511 size) -9) 9)))))) (make-local-variable 'tar-parse-info) (setq tar-parse-info (nreverse result)) ;; A tar file should end with a block or two of nulls,