235
|
1 ;;; package-info.el --- Generate information about an XEmacs package
|
|
2
|
|
3 ;; Copyright (C) 1998 by Free Software Foundation, Inc.
|
|
4
|
|
5 ;; Author: SL Baur <steve@altair.xemacs.org>
|
|
6 ;; Keywords: internal
|
|
7
|
|
8 ;; This file is part of XEmacs.
|
|
9
|
|
10 ;; XEmacs is free software; you can redistribute it and/or modify it
|
|
11 ;; under the terms of the GNU General Public License as published by
|
|
12 ;; the Free Software Foundation; either version 2, or (at your option)
|
|
13 ;; any later version.
|
|
14
|
|
15 ;; XEmacs is distributed in the hope that it will be useful, but
|
|
16 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
18 ;; General Public License for more details.
|
|
19
|
|
20 ;; You should have received a copy of the GNU General Public License
|
|
21 ;; along with XEmacs; see the file COPYING. If not, write to the Free
|
|
22 ;; Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
23 ;; 02111-1307, USA.
|
|
24
|
|
25 ;;; Synched up with: Not in FSF
|
|
26
|
|
27 ;;; Commentary:
|
|
28
|
|
29 ;; This file is used for building package distributions.
|
|
30
|
|
31 ;;; Change Log:
|
|
32
|
|
33 ;;; Code:
|
|
34
|
|
35 (defvar package-info "package-info"
|
|
36 "File used to write out Package info")
|
|
37
|
|
38 (defvar package-info-template "package-info.in"
|
|
39 "Template file for package-get info.")
|
|
40
|
|
41 ;; Loses with Mule
|
|
42 ;(defun pi-md5sum (file)
|
|
43 ; (let (result)
|
|
44 ; (with-temp-buffer
|
|
45 ; (let ((buffer-file-coding-system-for-read 'binary))
|
|
46 ; (insert-file-contents-literally file))
|
|
47 ; ;; (write-file "/tmp/x.x")
|
|
48 ; (setq result (md5 (current-buffer))))
|
|
49 ; result))
|
|
50
|
|
51 (defun pi-md5sum (file)
|
|
52 (with-temp-buffer
|
|
53 (call-process "md5sum" file t)
|
|
54 (goto-char (point-min))
|
|
55 (looking-at "[a-z0-9]+")
|
|
56 (buffer-substring (match-beginning 0) (match-end 0))))
|
|
57
|
|
58 (defun pi-update-key (key value)
|
|
59 (save-excursion
|
|
60 (goto-char (point-min))
|
|
61 (let ((case-fold-search nil))
|
|
62 (when (search-forward key)
|
|
63 (replace-match value t)))))
|
|
64
|
|
65 (defun batch-update-package-info ()
|
|
66 "Generate a package-info file for use by package-get.el.
|
|
67 Parameters are:
|
|
68 version -- Package version number
|
|
69 filename -- Filename of tarball to generate info for."
|
|
70 (unless noninteractive
|
|
71 (error "`batch-update-package-info' is to be used only with -batch"))
|
|
72 (let ((version (nth 0 command-line-args-left))
|
241
|
73 (filename (nth 1 command-line-args-left))
|
|
74 (requires (nth 2 command-line-args-left)))
|
|
75 (unless requires
|
|
76 (setq requires ""))
|
235
|
77 (find-file package-info)
|
|
78 (erase-buffer)
|
|
79 (insert-file-contents-literally package-info-template)
|
|
80 (goto-char (point-min))
|
237
|
81 (pi-update-key "VERSION" (format "\"%s\"" version))
|
235
|
82 (pi-update-key "MD5SUM" (format "\"%s\""
|
|
83 (pi-md5sum filename)))
|
|
84 (pi-update-key "FILENAME" (format "\"%s\""
|
|
85 (file-name-nondirectory filename)))
|
|
86 (pi-update-key "SIZE" (format "%d"
|
|
87 (nth 7 (file-attributes filename))))
|
241
|
88 (pi-update-key "REQUIRES" requires)
|
235
|
89 (save-buffers-kill-emacs 0)))
|
|
90
|
|
91 (provide 'package-info)
|
|
92
|
|
93 ;;; package-info.el ends here
|