summaryrefslogtreecommitdiff
path: root/lisp/arc-mode.el
diff options
context:
space:
mode:
authorChong Yidong <cyd@stupidchicken.com>2007-04-19 23:53:02 +0000
committerChong Yidong <cyd@stupidchicken.com>2007-04-19 23:53:02 +0000
commitfcb006c4ee97e3413a794c543367b771f0237495 (patch)
tree98d323db419ea791ea6fb9a8b74f466202189c43 /lisp/arc-mode.el
parent9cd04e16395bafbb8801e67ee082ce0a0bf42370 (diff)
downloademacs-fcb006c4ee97e3413a794c543367b771f0237495.tar.gz
(archive-find-type): lzh-exe for lzh self-extracting exe.
(archive-lzh-summarize): Add optional start arg for where to start looking at the archive. (archive-lzh-exe-summarize, archive-lzh-exe-extract): New functions.
Diffstat (limited to 'lisp/arc-mode.el')
-rw-r--r--lisp/arc-mode.el36
1 files changed, 34 insertions, 2 deletions
diff --git a/lisp/arc-mode.el b/lisp/arc-mode.el
index 8630d3e8b06..1a22ac628e6 100644
--- a/lisp/arc-mode.el
+++ b/lisp/arc-mode.el
@@ -700,6 +700,10 @@ archive.
(string-match "\\.[aA][rR][cC]$"
(or buffer-file-name (buffer-name))))
'arc)
+ ;; This pattern modelled on the BSD/GNU+Linux `file' command.
+ ;; Have seen capital "LHA's", and file has lower case "LHa's" too.
+ ;; Note this regexp is also in archive-exe-p.
+ ((looking-at "MZ\\(.\\|\n\\)\\{34\\}LH[aA]'s SFX ") 'lzh-exe)
(t (error "Buffer format not recognized")))))
;; -------------------------------------------------------------------------
(defun archive-summarize (&optional shut-up)
@@ -1398,8 +1402,8 @@ This doesn't recover lost files, it just undoes changes in the buffer itself."
;; -------------------------------------------------------------------------
;; Section: Lzh Archives
-(defun archive-lzh-summarize ()
- (let ((p 1)
+(defun archive-lzh-summarize (&optional start)
+ (let ((p (or start 1)) ;; 1 for .lzh, something further on for .exe
(totalsize 0)
(maxlen 8)
files
@@ -1621,6 +1625,34 @@ This doesn't recover lost files, it just undoes changes in the buffer itself."
;; This should work even though newmode will be dynamically accessed.
(lambda (old) (archive-calc-mode old newmode t))
files "a unix-style mode" 8))
+
+;; -------------------------------------------------------------------------
+;; Section: Lzh Self-Extracting .exe Archives
+;;
+;; No support for modifying these files. It looks like the lha for unix
+;; program (as of version 1.14i) can't create or retain the DOS exe part.
+;; If you do an "lha a" on a .exe for instance it renames and writes to a
+;; plain .lzh.
+
+(defun archive-lzh-exe-summarize ()
+ "Summarize the contents of an LZH self-extracting exe, for `archive-mode'."
+
+ ;; Skip the initial executable code part and apply archive-lzh-summarize
+ ;; to the archive part proper. The "-lh5-" etc regexp here for the start
+ ;; is the same as in archive-find-type.
+ ;;
+ ;; The lha program (version 1.14i) does this in skip_msdos_sfx1_code() by
+ ;; a similar scan. It looks for "..-l..-" plus for level 0 or 1 a test of
+ ;; the header checksum, or level 2 a test of the "attribute" and size.
+ ;;
+ (re-search-forward "..-l[hz][0-9ds]-" nil)
+ (archive-lzh-summarize (match-beginning 0)))
+
+;; `archive-lzh-extract' runs "lha pq", and that works for .exe as well as
+;; .lzh files
+(defalias 'archive-lzh-exe-extract 'archive-lzh-extract
+ "Extract a member from an LZH self-extracting exe, for `archive-mode'.")
+
;; -------------------------------------------------------------------------
;; Section: Zip Archives