annotate lisp/package-get.el @ 5750:66d2f63df75f

Correct some spelling and formatting in behavior.el. Mentioned in tracker issue 826, the third thing mentioned there (the file name at the bottom of the file) had already been fixed. lisp/ChangeLog addition: 2013-08-05 Aidan Kehoe <kehoea@parhasard.net> * behavior.el: (override-behavior): Correct some spelling and formatting here, thank you Steven Mitchell in tracker issue 826.
author Aidan Kehoe <kehoea@parhasard.net>
date Mon, 05 Aug 2013 10:05:32 +0100
parents 4dee0387b9de
children bbe4146603db
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1 ;;; package-get.el --- Retrieve XEmacs package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
3 ;; Copyright (C) 1998 by Pete Ware
793
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
4 ;; Copyright (C) 2002 Ben Wing.
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
5 ;; Copyright (C) 2003, Steve Youngs
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
6
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
7 ;; Author: Pete Ware <ware@cis.ohio-state.edu>
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
8 ;; Heavy-Modifications: Greg Klanderman <greg@alphatech.com>
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
9 ;; Jan Vroonhof <vroonhof@math.ethz.ch>
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
10 ;; Steve Youngs <youngs@xemacs.org>
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
11 ;; Keywords: internal
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
12
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
13 ;; This file is part of XEmacs.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
14
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
15 ;; XEmacs is free software: you can redistribute it and/or modify it
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
16 ;; under the terms of the GNU General Public License as published by the
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
17 ;; Free Software Foundation, either version 3 of the License, or (at your
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
18 ;; option) any later version.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
19
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
20 ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
21 ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
22 ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
23 ;; for more details.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
24
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
25 ;; You should have received a copy of the GNU General Public License
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4787
diff changeset
26 ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
27
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
28 ;;; Synched up with: Not in FSF
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
29
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
30 ;;; Commentary:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
31
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
32 ;; package-get -
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
33 ;; Retrieve a package and any other required packages from an archive
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
34 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
35 ;;
440
8de8e3f6228a Import from CVS: tag r21-2-28
cvs
parents: 434
diff changeset
36 ;; Note (JV): Most of this no longer applies!
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
37 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
38 ;; The idea:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
39 ;; A new XEmacs lisp-only release is generated with the following steps:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
40 ;; 1. The maintainer runs some yet to be written program that
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
41 ;; generates all the dependency information. This should
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
42 ;; determine all the require and provide statements and associate
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
43 ;; them with a package.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
44 ;; 2. All the packages are then bundled into their own tar balls
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
45 ;; (or whatever format)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
46 ;; 3. Maintainer automatically generates a new `package-get-base'
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
47 ;; data structure which contains information such as the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
48 ;; package name, the file to be retrieved, an md5 checksum,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
49 ;; etc (see `package-get-base').
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
50 ;; 4. The maintainer posts an announcement with the new version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
51 ;; of `package-get-base'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
52 ;; 5. A user/system manager saves this posting and runs
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
53 ;; `package-get-update' which uses the previously saved list
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
54 ;; of packages, `package-get-here' that the user/site
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
55 ;; wants to determine what new versions to download and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
56 ;; install.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
57 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
58 ;; A user/site manager can generate a new `package-get-here' structure
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
59 ;; by using `package-get-setup' which generates a customize like
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
60 ;; interface to the list of packages. The buffer looks something
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
61 ;; like:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
62 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
63 ;; gnus - a mail and news reader
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
64 ;; [] Always install
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
65 ;; [] Needs updating
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
66 ;; [] Required by other [packages]
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
67 ;; version: 2.0
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
68 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
69 ;; vm - a mail reader
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
70 ;; [] Always install
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
71 ;; [] Needs updating
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
72 ;; [] Required by other [packages]
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
73 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
74 ;; Where `[]' indicates a toggle box
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
75 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
76 ;; - Clicking on "Always install" puts this into
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
77 ;; `package-get-here' list. "Needs updating" indicates a new
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
78 ;; version is available. Anything already in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
79 ;; `package-get-here' has this enabled.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
80 ;; - "Required by other" means some other packages are going to force
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
81 ;; this to be installed. Clicking on [packages] gives a list
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
82 ;; of packages that require this.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
83 ;;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
84 ;; The `package-get-base' should be installed in a file in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
85 ;; `data-directory'. The `package-get-here' should be installed in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
86 ;; site-lisp. Both are then read at run time.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
87 ;;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
88 ;; TODO:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
89 ;; - Implement `package-get-setup'
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
90 ;; - Actually put `package-get-base' and `package-get-here' into
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
91 ;; files that are read.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
92 ;; - Allow users to have their own packages that they want installed
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
93 ;; in ~/.xemacs/.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
94 ;; - SOMEONE needs to write the programs that generate the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
95 ;; provides/requires database and makes it into a lisp data
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
96 ;; structure suitable for `package-get-base'
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
97 ;; - Handle errors such as no package providing a required symbol.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
98 ;; - Tie this into the `require' function to download packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
99 ;; transparently.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
100
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
101 ;;; Change Log
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
102
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
103 ;;; Code:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
104
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
105 (require 'package-admin)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
106 ;; (require 'package-get-base)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
107
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
108 (defgroup package-tools nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
109 "Tools to manipulate packages."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
110 :group 'emacs)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
111
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
112 (defgroup package-get nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
113 "Automatic Package Fetcher and Installer."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
114 :prefix "package-get"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
115 :group 'package-tools)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
116
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
117 ;;;###autoload
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
118 (defvar package-get-base nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
119 "List of packages that are installed at this site.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
120 For each element in the alist, car is the package name and the cdr is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
121 a plist containing information about the package. Typical fields
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
122 kept in the plist are:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
123
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
124 version - version of this package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
125 provides - list of symbols provided
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
126 requires - list of symbols that are required.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
127 These in turn are provided by other packages.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
128 filename - name of the file.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
129 size - size of the file (aka the bundled package)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
130 md5sum - computed md5 checksum
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
131 description - What this package is for.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
132 type - Whether this is a 'binary (default) or 'single file package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
133
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
134 More fields may be added as needed. An example:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
135
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
136 '(
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
137 (name
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
138 (version \"<version 2>\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
139 file \"filename\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
140 description \"what this package is about.\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
141 provides (<list>)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
142 requires (<list>)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
143 size <integer-bytes>
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
144 md5sum \"<checksum\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
145 type single
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
146 )
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
147 (version \"<version 1>\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
148 file \"filename\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
149 description \"what this package is about.\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
150 provides (<list>)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
151 requires (<list>)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
152 size <integer-bytes>
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
153 md5sum \"<checksum\"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
154 type single
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
155 )
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
156 ...
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
157 ))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
158
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
159 For version information, it is assumed things are listed in most
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
160 recent to least recent -- in other words, the version names don't have to
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
161 be lexically ordered. It is debatable if it makes sense to have more than
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
162 one version of a package available.")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
163
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
164 (defcustom package-get-dir (temp-directory)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
165 "*Where to store temporary files for staging."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
166 :tag "Temporary directory"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
167 :type 'directory
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
168 :group 'package-get)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
169
1378
69a674f5861f [xemacs-hg @ 2003-03-24 16:30:55 by youngs]
youngs
parents: 1374
diff changeset
170 ;;;###autoload
1483
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
171 (defcustom package-get-package-index-file-location
3179
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
172 (cond
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
173 ;; historical backage
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
174 ((getenv "EMACSPACKAGEPATH")
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
175 (split-path (getenv "EMACSPACKAGEPATH")))
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
176 ((getenv "EMACSEARLYPACKAGES")
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
177 (split-path (getenv "EMACSEARLYPACKAGES")))
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
178 (configure-early-package-directories
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
179 (car configure-early-package-directories))
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
180 (t
15139dbf89f4 [xemacs-hg @ 2005-12-27 18:50:47 by michaels]
michaels
parents: 3141
diff changeset
181 user-init-directory))
1483
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
182 "*The directory where the package-index file can be found."
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
183 :type 'directory
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
184 :group 'package-get)
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
185
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
186 ;;;###autoload
1378
69a674f5861f [xemacs-hg @ 2003-03-24 16:30:55 by youngs]
youngs
parents: 1374
diff changeset
187 (defcustom package-get-install-to-user-init-directory nil
69a674f5861f [xemacs-hg @ 2003-03-24 16:30:55 by youngs]
youngs
parents: 1374
diff changeset
188 "*If non-nil install packages under `user-init-directory'."
69a674f5861f [xemacs-hg @ 2003-03-24 16:30:55 by youngs]
youngs
parents: 1374
diff changeset
189 :type 'boolean
69a674f5861f [xemacs-hg @ 2003-03-24 16:30:55 by youngs]
youngs
parents: 1374
diff changeset
190 :group 'package-get)
69a674f5861f [xemacs-hg @ 2003-03-24 16:30:55 by youngs]
youngs
parents: 1374
diff changeset
191
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
192 (define-widget 'host-name 'string
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
193 "A Host name."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
194 :tag "Host")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
195
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
196 (defcustom package-get-remote nil
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
197 "*The remote site to contact for downloading packages.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
198 Format is '(site-name directory-on-site). As a special case, `site-name'
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
199 can be `nil', in which case `directory-on-site' is treated as a local
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
200 directory."
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
201 :tag "Package repository"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
202 :type '(set (choice (const :tag "None" nil)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
203 (list :tag "Local" (const :tag "Local" nil) directory)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
204 (list :tag "Remote" host-name directory)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
205 :group 'package-get)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
206
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
207 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
208 (defcustom package-get-download-sites
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
209 '(
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
210 ;; Main XEmacs Site (ftp.xemacs.org)
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
211 ("US (Main XEmacs Site)"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
212 "ftp.xemacs.org" "pub/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
213 ;; In alphabetical order of Country, our mirrors...
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
214 ("Argentina (xmundo.net)" "xemacs.xmundo.net" "pub/mirrors/xemacs/packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
215 ("Australia (aarnet.edu.au)" "mirror.aarnet.edu.au" "pub/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
216 ("Australia (au.xemacs.org)" "ftp.au.xemacs.org" "pub/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
217 ("Austria (at.xemacs.org)" "ftp.at.xemacs.org" "editors/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
218 ("Belgium (be.xemacs.org)" "ftp.be.xemacs.org" "xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
219 ("Brazil (br.xemacs.org)" "ftp.br.xemacs.org" "pub/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
220 ("Canada (ca.xemacs.org)" "ftp.ca.xemacs.org" "pub/Mirror/xemacs/packages")
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
221 ("Canada (nrc.ca)" "ftp.nrc.ca" "pub/packages/editors/xemacs/packages")
4120
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
222 ;; no anonymous ftp available, uncomment when updating website
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
223 ;; with
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
224 ;; xemacs-builds/adrian/website/package-get-2-download-sites.el
4082
232b07b6d09c [xemacs-hg @ 2007-07-27 22:25:20 by adrian]
adrian
parents: 4034
diff changeset
225 ; ("Chile (cl.xemacs.org)" "ftp.cl.xemacs.org" "packages")
4188
436ab23a7a3c [xemacs-hg @ 2007-09-26 20:50:07 by adrian]
adrian
parents: 4184
diff changeset
226 ("China (ftp.cn.xemacs.org)" "ftp.cn.xemacs.org" "pub/xemacs/packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
227 ("Czech Republic (cz.xemacs.org)" "ftp.cz.xemacs.org" "MIRRORS/ftp.xemacs.org/pub/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
228 ("Finland (fi.xemacs.org)" "ftp.fi.xemacs.org" "pub/mirrors/ftp.xemacs.org/pub/tux/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
229 ("France (fr.xemacs.org)" "ftp.fr.xemacs.org" "pub/xemacs/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
230 ("France (mirror.cict.fr)" "mirror.cict.fr" "xemacs/packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
231 ("France (pasteur.fr)" "ftp.pasteur.fr" "pub/computing/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
232 ("Germany (de.xemacs.org)" "ftp.de.xemacs.org" "pub/ftp.xemacs.org/tux/xemacs/packages")
4034
f18ecb4232e3 [xemacs-hg @ 2007-06-22 23:17:46 by adrian]
adrian
parents: 4009
diff changeset
233 ("Greece (gr.xemacs.org)" "ftp.gr.xemacs.org" "mirrors/XEmacs/ftp/packages")
3141
66c42fc5d26b [xemacs-hg @ 2005-12-16 23:52:22 by adrian]
adrian
parents: 3116
diff changeset
234 ("Hong Kong (hk.xemacs.org)" "ftp.hk.xemacs.org" "pub/xemacsftp/packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
235 ("Ireland (ie.xemacs.org)" "ftp.ie.xemacs.org" "mirrors/ftp.xemacs.org/pub/xemacs/packages")
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
236 ("Ireland (heanet.ie)" "ftp.heanet.ie" "mirrors/ftp.xemacs.org/packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
237 ("Italy (it.xemacs.org)" "ftp.it.xemacs.org" "unix/packages/XEMACS/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
238 ("Japan (dti.ad.jp)" "ftp.dti.ad.jp" "pub/unix/editor/xemacs/packages")
3116
ffbb20e35ed9 [xemacs-hg @ 2005-11-29 21:00:29 by adrian]
adrian
parents: 3021
diff changeset
239 ; ("Japan (jaist.ac.jp)" "ftp.jaist.ac.jp" "pub/GNU/xemacs/packages")
4132
ebc64fb494fe [xemacs-hg @ 2007-08-20 22:29:29 by adrian]
adrian
parents: 4127
diff changeset
240 ("Japan (jp.xemacs.org)" "ftp.jp.xemacs.org" "pub/text/xemacs/packages")
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
241 ; ("Japan (nucba.ac.jp)" "mirror.nucba.ac.jp" "mirror/xemacs/packages")
1374
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
242 ("Korea (kr.xemacs.org)" "ftp.kr.xemacs.org" "pub/tools/emacs/xemacs/packages")
3438
14fbcab7c67b [xemacs-hg @ 2006-06-02 22:18:05 by adrian]
adrian
parents: 3193
diff changeset
243 ("Netherlands (nl.xemacs.org)" "ftp.nl.xemacs.org" "pub/xemacs/ftp/packages")
4184
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
244 ;; no anonymous ftp available, uncomment when updating website
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
245 ;; with
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
246 ;; xemacs-builds/adrian/website/package-get-2-download-sites.el
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
247 ; ("Netherlands (xemacsftp.digimirror.nl)" "xemacsftp.digimirror.nl" "packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
248 ("Norway (no.xemacs.org)" "ftp.no.xemacs.org" "pub/xemacs/packages")
3193
65264c66457b [xemacs-hg @ 2006-01-06 12:24:19 by adrian]
adrian
parents: 3179
diff changeset
249 ("Portugal (pt.xemacs.org)" "ftp.pt.xemacs.org" "pub/MIRRORS/ftp.xemacs.org/packages")
3116
ffbb20e35ed9 [xemacs-hg @ 2005-11-29 21:00:29 by adrian]
adrian
parents: 3021
diff changeset
250 ("Russia (ru.xemacs.org)" "ftp.ru.xemacs.org" "pub/emacs/xemacs/packages")
4009
7147a4dabc02 [xemacs-hg @ 2007-06-12 10:32:15 by adrian]
adrian
parents: 3438
diff changeset
251 ("Saudi Arabia (sa.xemacs.org)" "ftp.sa.xemacs.org" "pub/xemacs.org/packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
252 ("Sweden (se.xemacs.org)" "ftp.se.xemacs.org" "pub/gnu/xemacs/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
253 ("Switzerland (ch.xemacs.org)" "ftp.ch.xemacs.org" "mirror/xemacs/packages")
3021
285d258fdeb6 [xemacs-hg @ 2005-10-24 22:40:20 by adrian]
adrian
parents: 3013
diff changeset
254 ("Taiwan (ftp.tw.xemacs.org)" "ftp.tw.xemacs.org" "Unix/Editors/XEmacs/packages")
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
255 ("UK (uk.xemacs.org)" "ftp.uk.xemacs.org" "sites/ftp.xemacs.org/pub/xemacs/packages")
3021
285d258fdeb6 [xemacs-hg @ 2005-10-24 22:40:20 by adrian]
adrian
parents: 3013
diff changeset
256 ("US (ibiblio.org)" "mirrors.ibiblio.org" "pub/mirrors/xemacs/packages")
4120
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
257 ("US (us.xemacs.org)" "ftp.us.xemacs.org" "pub/mirrors/xemacs/packages")
3116
ffbb20e35ed9 [xemacs-hg @ 2005-11-29 21:00:29 by adrian]
adrian
parents: 3021
diff changeset
258 )
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
259 "*List of remote sites available for downloading packages.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
260 List format is '(site-description site-name directory-on-site).
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
261 SITE-DESCRIPTION is a textual description of the site. SITE-NAME
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
262 is the internet address of the download site. DIRECTORY-ON-SITE
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
263 is the directory on the site in which packages may be found.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
264 This variable is used to initialize `package-get-remote', the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
265 variable actually used to specify package download sites."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
266 :tag "Package download sites"
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
267 :type '(repeat (list (string :tag "Name") host-name directory))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
268 :group 'package-get)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
269
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
270 ;;;###autoload
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
271 (defcustom package-get-pre-release-download-sites
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
272 '(
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
273 ;; Main XEmacs Site (ftp.xemacs.org)
3116
ffbb20e35ed9 [xemacs-hg @ 2005-11-29 21:00:29 by adrian]
adrian
parents: 3021
diff changeset
274 ("US Pre-Releases (Main XEmacs Site)" "ftp.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
275 "pub/xemacs/beta/experimental/packages")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
276 ;; In alphabetical order of Country, our mirrors...
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
277 ("Argentina Pre-Releases (xmundo.net)" "xemacs.xmundo.net"
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
278 "pub/mirrors/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
279 ("Australia Pre-Releases (aarnet.edu.au)" "mirror.aarnet.edu.au"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
280 "pub/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
281 ("Australia Pre-Releases (au.xemacs.org)" "ftp.au.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
282 "pub/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
283 ("Austria Pre-Releases (at.xemacs.org)" "ftp.at.xemacs.org"
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
284 "editors/xemacs/beta/experimental/packages")
4184
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
285 ("Belgium Pre-Releases (be.xemacs.org)" "ftp.be.xemacs.org"
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
286 "xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
287 ("Brazil Pre-Releases (br.xemacs.org)" "ftp.br.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
288 "pub/xemacs/xemacs-21.5/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
289 ("Canada Pre-Releases (ca.xemacs.org)" "ftp.ca.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
290 "pub/Mirror/xemacs/beta/experimental/packages")
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
291 ("Canada Pre-Releases (nrc.ca)" "ftp.nrc.ca"
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
292 "pub/packages/editors/xemacs/beta/experimental/packages")
4120
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
293 ;; no anonymous ftp available, uncomment when updating website
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
294 ;; with
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
295 ;; xemacs-builds/adrian/website/package-get-2-download-sites.el
4082
232b07b6d09c [xemacs-hg @ 2007-07-27 22:25:20 by adrian]
adrian
parents: 4034
diff changeset
296 ; ("Chile Pre-Releases (cl.xemacs.org)" "ftp.cl.xemacs.org"
232b07b6d09c [xemacs-hg @ 2007-07-27 22:25:20 by adrian]
adrian
parents: 4034
diff changeset
297 ; "beta/experimental/packages")
4188
436ab23a7a3c [xemacs-hg @ 2007-09-26 20:50:07 by adrian]
adrian
parents: 4184
diff changeset
298 ("China Pre-Releases (ftp.cn.xemacs.org)" "ftp.cn.xemacs.org"
4184
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
299 "pub/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
300 ("Czech Republic Pre-Releases (cz.xemacs.org)" "ftp.cz.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
301 "MIRRORS/ftp.xemacs.org/pub/xemacs/xemacs-21.5/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
302 ("Finland Pre-Releases (fi.xemacs.org)" "ftp.fi.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
303 "pub/mirrors/ftp.xemacs.org/pub/tux/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
304 ("France Pre-Releases (fr.xemacs.org)" "ftp.fr.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
305 "pub/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
306 ("France Pre-Releases (mirror.cict.fr)" "mirror.cict.fr"
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
307 "xemacs/beta/experimental/packages")
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
308 ("France Pre-Releases (pasteur.fr)" "ftp.pasteur.fr"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
309 "pub/computing/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
310 ("Germany Pre-Releases (de.xemacs.org)" "ftp.de.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
311 "pub/ftp.xemacs.org/tux/xemacs/beta/experimental/packages")
4034
f18ecb4232e3 [xemacs-hg @ 2007-06-22 23:17:46 by adrian]
adrian
parents: 4009
diff changeset
312 ("Greece Pre-Releases (gr.xemacs.org)" "ftp.gr.xemacs.org"
f18ecb4232e3 [xemacs-hg @ 2007-06-22 23:17:46 by adrian]
adrian
parents: 4009
diff changeset
313 "mirrors/XEmacs/ftp/beta/experimental/packages")
3141
66c42fc5d26b [xemacs-hg @ 2005-12-16 23:52:22 by adrian]
adrian
parents: 3116
diff changeset
314 ("Hong Kong Pre-Releases (hk.xemacs.org)" "ftp.hk.xemacs.org"
66c42fc5d26b [xemacs-hg @ 2005-12-16 23:52:22 by adrian]
adrian
parents: 3116
diff changeset
315 "pub/xemacsftp/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
316 ("Ireland Pre-Releases (ie.xemacs.org)" "ftp.ie.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
317 "mirrors/ftp.xemacs.org/pub/xemacs/beta/experimental/packages")
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
318 ("Ireland Pre-Releases (heanet.ie)" "ftp.heanet.ie"
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
319 "mirrors/ftp.xemacs.org/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
320 ("Italy Pre-Releases (it.xemacs.org)" "ftp.it.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
321 "unix/packages/XEMACS/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
322 ("Japan Pre-Releases (dti.ad.jp)" "ftp.dti.ad.jp"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
323 "pub/unix/editor/xemacs/beta/experimental/packages")
3116
ffbb20e35ed9 [xemacs-hg @ 2005-11-29 21:00:29 by adrian]
adrian
parents: 3021
diff changeset
324 ; ("Japan Pre-Releases (jaist.ac.jp)" "ftp.jaist.ac.jp"
ffbb20e35ed9 [xemacs-hg @ 2005-11-29 21:00:29 by adrian]
adrian
parents: 3021
diff changeset
325 ; "pub/GNU/xemacs/beta/experimental/packages")
4132
ebc64fb494fe [xemacs-hg @ 2007-08-20 22:29:29 by adrian]
adrian
parents: 4127
diff changeset
326 ("Japan Pre-Releases (jp.xemacs.org)" "ftp.jp.xemacs.org"
ebc64fb494fe [xemacs-hg @ 2007-08-20 22:29:29 by adrian]
adrian
parents: 4127
diff changeset
327 "pub/text/xemacs/beta/experimental/packages")
4184
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
328 ("Korea Pre-Releases (kr.xemacs.org)" "ftp.kr.xemacs.org"
3013
ae52b2073aa3 [xemacs-hg @ 2005-10-23 16:56:43 by adrian]
adrian
parents: 2802
diff changeset
329 "pub/tools/emacs/xemacs/beta/experimental/packages")
4184
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
330 ("Netherlands Pre-Releases (nl.xemacs.org)" "ftp.nl.xemacs.org"
3438
14fbcab7c67b [xemacs-hg @ 2006-06-02 22:18:05 by adrian]
adrian
parents: 3193
diff changeset
331 "pub/xemacs/ftp/beta/experimental/packages")
4184
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
332 ;; no anonymous ftp available, uncomment when updating website
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
333 ;; with
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
334 ;; xemacs-builds/adrian/website/package-get-2-download-sites.el
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
335 ; ("Netherlands Pre-Releases (xemacsftp.digimirror.nl)" "xemacsftp.digimirror.nl"
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
336 ; "beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
337 ("Norway Pre-Releases (no.xemacs.org)" "ftp.no.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
338 "pub/xemacs/beta/experimental/packages")
3193
65264c66457b [xemacs-hg @ 2006-01-06 12:24:19 by adrian]
adrian
parents: 3179
diff changeset
339 ("Portugal Pre-Releases (pt.xemacs.org)" "ftp.pt.xemacs.org"
65264c66457b [xemacs-hg @ 2006-01-06 12:24:19 by adrian]
adrian
parents: 3179
diff changeset
340 "pub/MIRRORS/ftp.xemacs.org/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
341 ("Russia Pre-Releases (ru.xemacs.org)" "ftp.ru.xemacs.org"
3116
ffbb20e35ed9 [xemacs-hg @ 2005-11-29 21:00:29 by adrian]
adrian
parents: 3021
diff changeset
342 "pub/emacs/xemacs/beta/experimental/packages")
4184
1b16ec86578c [xemacs-hg @ 2007-09-25 21:21:08 by adrian]
adrian
parents: 4160
diff changeset
343 ("Saudi Arabia Pre-Releases (sa.xemacs.org)" "ftp.sa.xemacs.org"
4009
7147a4dabc02 [xemacs-hg @ 2007-06-12 10:32:15 by adrian]
adrian
parents: 3438
diff changeset
344 "pub/xemacs.org/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
345 ("Sweden Pre-Releases (se.xemacs.org)" "ftp.se.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
346 "pub/gnu/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
347 ("Switzerland Pre-Releases (ch.xemacs.org)" "ftp.ch.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
348 "mirror/xemacs/beta/experimental/packages")
3021
285d258fdeb6 [xemacs-hg @ 2005-10-24 22:40:20 by adrian]
adrian
parents: 3013
diff changeset
349 ("Taiwan Pre-Releases (ftp.tw.xemacs.org)" "ftp.tw.xemacs.org"
285d258fdeb6 [xemacs-hg @ 2005-10-24 22:40:20 by adrian]
adrian
parents: 3013
diff changeset
350 "Unix/Editors/XEmacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
351 ("UK Pre-Releases (uk.xemacs.org)" "ftp.uk.xemacs.org"
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
352 "sites/ftp.xemacs.org/pub/xemacs/beta/experimental/packages")
3021
285d258fdeb6 [xemacs-hg @ 2005-10-24 22:40:20 by adrian]
adrian
parents: 3013
diff changeset
353 ("US Pre-Releases (ibiblio.org)" "mirrors.ibiblio.org"
285d258fdeb6 [xemacs-hg @ 2005-10-24 22:40:20 by adrian]
adrian
parents: 3013
diff changeset
354 "pub/mirrors/xemacs/beta/experimental/packages")
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
355 ("US Pre-Releases (us.xemacs.org)" "ftp.us.xemacs.org"
4120
abed33dba4a5 [xemacs-hg @ 2007-08-15 23:23:30 by adrian]
adrian
parents: 4082
diff changeset
356 "pub/mirrors/xemacs/beta/experimental/packages")
4132
ebc64fb494fe [xemacs-hg @ 2007-08-20 22:29:29 by adrian]
adrian
parents: 4127
diff changeset
357 )
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
358 "*List of remote sites available for downloading \"Pre-Release\" packages.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
359 List format is '(site-description site-name directory-on-site).
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
360 SITE-DESCRIPTION is a textual description of the site. SITE-NAME
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
361 is the internet address of the download site. DIRECTORY-ON-SITE
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
362 is the directory on the site in which packages may be found.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
363 This variable is used to initialize `package-get-remote', the
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
364 variable actually used to specify package download sites."
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
365 :tag "Pre-Release Package download sites"
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
366 :type '(repeat (list (string :tag "Name") host-name directory))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
367 :group 'package-get)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
368
1374
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
369 ;;;###autoload
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
370 (defcustom package-get-site-release-download-sites
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
371 nil
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
372 "*List of remote sites available for downloading \"Site Release\" packages.
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
373 List format is '(site-description site-name directory-on-site).
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
374 SITE-DESCRIPTION is a textual description of the site. SITE-NAME
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
375 is the internet address of the download site. DIRECTORY-ON-SITE
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
376 is the directory on the site in which packages may be found.
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
377 This variable is used to initialize `package-get-remote', the
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
378 variable actually used to specify package download sites."
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
379 :tag "Site Release Package download sites"
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
380 :type '(repeat (list (string :tag "Name") host-name directory))
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
381 :group 'package-get)
d638fc15d68b [xemacs-hg @ 2003-03-24 11:10:54 by adrian]
adrian
parents: 1368
diff changeset
382
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
383 (defcustom package-get-remove-copy t
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
384 "*After copying and installing a package, if this is t, then remove the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
385 copy. Otherwise, keep it around."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
386 :type 'boolean
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
387 :group 'package-get)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
388
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
389 ;; #### it may make sense for this to be a list of names.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
390 ;; #### also, should we rename "*base*" to "*index*" or "*db*"?
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
391 ;; "base" is a pretty poor name.
681
c00aa0615465 [xemacs-hg @ 2001-12-02 07:27:14 by youngs]
youngs
parents: 678
diff changeset
392 (defcustom package-get-base-filename "package-index.LATEST.gpg"
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
393 "*Name of the default package-get database file.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
394 This may either be a relative path, in which case it is interpreted
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
395 with respect to `package-get-remote', or an absolute path."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
396 :type 'file
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
397 :group 'package-get)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
398
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
399 (defcustom package-get-always-update nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
400 "*If Non-nil always make sure we are using the latest package index (base).
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
401 Otherwise respect the `force-current' argument of `package-get-require-base'."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
402 :type 'boolean
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
403 :group 'package-get)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
404
681
c00aa0615465 [xemacs-hg @ 2001-12-02 07:27:14 by youngs]
youngs
parents: 678
diff changeset
405 (defvar package-get-continue-update-base nil
c00aa0615465 [xemacs-hg @ 2001-12-02 07:27:14 by youngs]
youngs
parents: 678
diff changeset
406 "Non-nil update the index even if it hasn't been signed.")
c00aa0615465 [xemacs-hg @ 2001-12-02 07:27:14 by youngs]
youngs
parents: 678
diff changeset
407
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
408 (defvar package-get-was-current nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
409 "Non-nil we did our best to fetch a current database.")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
410
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
411 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
412 (defun package-get-require-base (&optional force-current)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
413 "Require that a package-get database has been loaded.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
414 If the optional FORCE-CURRENT argument or the value of
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
415 `package-get-always-update' is Non-nil, try to update the database
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
416 from a location in `package-get-remote'. Otherwise a local copy is used
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
417 if available and remote access is never done.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
418
5384
3889ef128488 Fix misspelled words, and some grammar, across the entire source tree.
Jerry James <james@xemacs.org>
parents: 5344
diff changeset
419 Please use FORCE-CURRENT only when the user is explicitly dealing with packages
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
420 and remote access is likely in the near future."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
421 (setq force-current (or force-current package-get-always-update))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
422 (unless (and (boundp 'package-get-base)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
423 package-get-base
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
424 (or (not force-current) package-get-was-current))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
425 (package-get-update-base nil force-current))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
426 (if (or (not (boundp 'package-get-base))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
427 (not package-get-base))
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
428 (error 'void-variable
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
429 "Package-get database not loaded")
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
430 (setq package-get-was-current force-current)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
431
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
432 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
433 (defun package-get-update-base-entry (entry)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
434 "Update an entry in `package-get-base'."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
435 (let ((existing (assq (car entry) package-get-base)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
436 (if existing
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
437 (setcdr existing (cdr entry))
824
0cce4fee510b [xemacs-hg @ 2002-05-01 08:25:40 by youngs]
youngs
parents: 793
diff changeset
438 (setq package-get-base (cons entry package-get-base)))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
439
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
440 (defun package-get-locate-file (file &optional nil-if-not-found no-remote)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
441 "Locate an existing FILE with respect to `package-get-remote'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
442 If FILE is an absolute path or is not found, simply return FILE.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
443 If optional argument NIL-IF-NOT-FOUND is non-nil, return nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
444 if FILE can not be located.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
445 If NO-REMOTE is non-nil never search remote locations."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
446 (if (file-name-absolute-p file)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
447 file
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
448 (let ((site package-get-remote)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
449 (expanded nil))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
450 (when site
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
451 (unless (and no-remote (caar (list site)))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
452 (let ((expn (package-get-remote-filename (car (list site)) file)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
453 (if (and expn (file-exists-p expn))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
454 (setq site nil
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
455 expanded expn)))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
456 (or expanded
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
457 (and (not nil-if-not-found)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
458 file)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
459
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
460 (defun package-get-locate-index-file (no-remote)
1483
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
461 "Locate the package-get index file.
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
462
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
463 Do not return remote paths if NO-REMOTE is non-nil. If the index
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
464 file doesn't exist in `package-get-package-index-file-location', ask
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
465 the user if one should be created using the index file in core as a
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
466 template."
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
467 (or (package-get-locate-file package-get-base-filename t no-remote)
1483
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
468 (if (file-exists-p (expand-file-name package-get-base-filename
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
469 package-get-package-index-file-location))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
470 (expand-file-name package-get-base-filename
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
471 package-get-package-index-file-location)
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
472 (if (y-or-n-p (format "No index file, shall I create one in %s? "
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
473 package-get-package-index-file-location))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
474 (progn
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
475 (save-excursion
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
476 (set-buffer
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
477 (find-file-noselect (expand-file-name
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
478 package-get-base-filename
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
479 package-get-package-index-file-location)))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
480 (let ((coding-system-for-write 'binary))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
481 (erase-buffer)
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
482 (insert-file-contents-literally
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
483 (locate-data-file package-get-base-filename))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
484 (save-buffer (current-buffer))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
485 (kill-buffer (current-buffer))))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
486 (expand-file-name package-get-base-filename
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
487 package-get-package-index-file-location))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
488 (error 'search-failed
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
489 "Can't locate a package index file.")))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
490
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
491 (defun package-get-maybe-save-index (filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
492 "Offer to save the current buffer as the local package index file,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
493 if different."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
494 (let ((location (package-get-locate-index-file t)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
495 (unless (and filename (equal filename location))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
496 (unless (and location
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
497 (equal (md5 (current-buffer))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
498 (with-temp-buffer
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
499 (insert-file-contents-literally location)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
500 (md5 (current-buffer)))))
1483
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
501 (when (not (file-writable-p location))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
502 (if (y-or-n-p (format "Sorry, %s is read-only, can I use %s? "
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
503 location user-init-directory))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
504 (setq location (expand-file-name
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
505 package-get-base-filename
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
506 package-get-package-index-file-location))
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
507 (error 'file-error
410360d3e34e [xemacs-hg @ 2003-05-14 23:57:34 by youngs]
youngs
parents: 1479
diff changeset
508 (format "%s is read-only" location))))
434
9d177e8d4150 Import from CVS: tag r21-2-25
cvs
parents: 430
diff changeset
509 (when (y-or-n-p (concat "Update package index in " location "? "))
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
510 (let ((coding-system-for-write 'binary))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
511 (write-file location)))))))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
512
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
513 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
514 (defun package-get-update-base (&optional db-file force-current)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
515 "Update the package-get database file with entries from DB-FILE.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
516 Unless FORCE-CURRENT is non-nil never try to update the database."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
517 (interactive
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
518 (let ((dflt (package-get-locate-index-file nil)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
519 (list (read-file-name "Load package-get database: "
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
520 (file-name-directory dflt)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
521 dflt
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
522 t
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
523 (file-name-nondirectory dflt)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
524 (setq db-file (expand-file-name (or db-file
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
525 (package-get-locate-index-file
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
526 (not force-current)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
527 (if (not (file-exists-p db-file))
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
528 (error 'file-error
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
529 (format "Package-get database file `%s' does not exist" db-file)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
530 (if (not (file-readable-p db-file))
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
531 (error 'file-error
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
532 (format "Package-get database file `%s' not readable" db-file)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
533 (let ((buf (get-buffer-create "*package database*")))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
534 (unwind-protect
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
535 (save-excursion
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
536 (set-buffer buf)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
537 (erase-buffer buf)
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
538 (insert-file-contents-literally db-file)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
539 (package-get-update-base-from-buffer buf)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
540 (if (file-remote-p db-file)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
541 (package-get-maybe-save-index db-file)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
542 (kill-buffer buf))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
543
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
544 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
545 (defun package-get-update-base-from-buffer (&optional buf)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
546 "Update the package-get database with entries from BUFFER.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
547 BUFFER defaults to the current buffer. This command can be
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
548 used interactively, for example from a mail or news buffer."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
549 (interactive)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
550 (setq buf (or buf (current-buffer)))
1937
cac9e42fd31d [xemacs-hg @ 2004-03-04 21:06:58 by youngs]
youngs
parents: 1832
diff changeset
551 (let ((coding-system-for-read 'binary)
cac9e42fd31d [xemacs-hg @ 2004-03-04 21:06:58 by youngs]
youngs
parents: 1832
diff changeset
552 (coding-system-for-write 'binary)
cac9e42fd31d [xemacs-hg @ 2004-03-04 21:06:58 by youngs]
youngs
parents: 1832
diff changeset
553 content-beg content-end)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
554 (save-excursion
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
555 (set-buffer buf)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
556 (goto-char (point-min))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
557 (setq content-beg (point))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
558 (setq content-end (save-excursion (goto-char (point-max)) (point)))
4160
f35582fa32a9 [xemacs-hg @ 2007-09-03 13:16:39 by viteno]
viteno
parents: 4132
diff changeset
559 (package-get-update-base-entries content-beg content-end)
f35582fa32a9 [xemacs-hg @ 2007-09-03 13:16:39 by viteno]
viteno
parents: 4132
diff changeset
560 (message "Updated package database"))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
561
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
562 (defun package-get-update-base-entries (start end)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
563 "Update the package-get database with the entries found between
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
564 START and END in the current buffer."
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
565 (save-excursion
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
566 (goto-char start)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
567 (if (not (re-search-forward "^(package-get-update-base-entry" nil t))
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
568 (error 'search-failed
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
569 "Buffer does not contain package-get database entries"))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
570 (beginning-of-line)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
571 (let ((count 0))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
572 (while (and (< (point) end)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
573 (re-search-forward "^(package-get-update-base-entry" nil t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
574 (beginning-of-line)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
575 (let ((entry (read (current-buffer))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
576 (if (or (not (consp entry))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
577 (not (eq (car entry) 'package-get-update-base-entry)))
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
578 (error 'syntax-error
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
579 "Invalid package-get database entry found"))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
580 (package-get-update-base-entry
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
581 (car (cdr (car (cdr entry)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
582 (setq count (1+ count))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
583 (message "Got %d package-get database entries" count))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
584
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
585 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
586 (defun package-get-save-base (file)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
587 "Write the package-get database to FILE.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
588
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
589 Note: This database will be unsigned of course."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
590 (interactive "FSave package-get database to: ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
591 (package-get-require-base t)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
592 (let ((buf (get-buffer-create "*package database*")))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
593 (unwind-protect
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
594 (save-excursion
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
595 (set-buffer buf)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
596 (erase-buffer buf)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
597 (goto-char (point-min))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
598 (let ((entries package-get-base) entry plist)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
599 (insert ";; Package Index file -- Do not edit manually.\n")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
600 (insert ";;;@@@\n")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
601 (while entries
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
602 (setq entry (car entries))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
603 (setq plist (car (cdr entry)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
604 (insert "(package-get-update-base-entry (quote\n")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
605 (insert (format "(%s\n" (symbol-name (car entry))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
606 (while plist
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
607 (insert (format " %s%s %S\n"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
608 (if (eq plist (car (cdr entry))) "(" " ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
609 (symbol-name (car plist))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
610 (car (cdr plist))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
611 (setq plist (cdr (cdr plist))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
612 (insert "))\n))\n;;;@@@\n")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
613 (setq entries (cdr entries))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
614 (insert ";; Package Index file ends here\n")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
615 (write-region (point-min) (point-max) file))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
616 (kill-buffer buf))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
617
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
618 (defun package-get-interactive-package-query (get-version package-symbol)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
619 "Perform interactive querying for package and optional version.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
620 Query for a version if GET-VERSION is non-nil. Return package name as
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
621 a symbol instead of a string if PACKAGE-SYMBOL is non-nil.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
622 The return value is suitable for direct passing to `interactive'."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
623 (package-get-require-base t)
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
624 (let ((table (mapcar #'(lambda (item)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
625 (let ((name (symbol-name (car item))))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
626 (cons name name)))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
627 package-get-base))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
628 package package-symbol default-version version)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
629 (save-window-excursion
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
630 (setq package (completing-read "Package: " table nil t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
631 (setq package-symbol (intern package))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
632 (if get-version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
633 (progn
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
634 (setq default-version
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
635 (package-get-info-prop
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
636 (package-get-info-version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
637 (package-get-info-find-package package-get-base
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
638 package-symbol) nil)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
639 'version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
640 (while (string=
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
641 (setq version (read-string "Version: " default-version))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
642 ""))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
643 (if package-symbol
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
644 (list package-symbol version)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
645 (list package version)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
646 (if package-symbol
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
647 (list package-symbol)
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
648 (list package))))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
649
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
650 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
651 (defun package-get-delete-package (package &optional pkg-topdir)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
652 "Delete an installation of PACKAGE below directory PKG-TOPDIR.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
653 PACKAGE is a symbol, not a string.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
654 This is just an interactive wrapper for `package-admin-delete-binary-package'."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
655 (interactive (package-get-interactive-package-query nil t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
656 (package-admin-delete-binary-package package pkg-topdir))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
657
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
658 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
659 (defun package-get-update-all ()
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
660 "Fetch and install the latest versions of all currently installed packages."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
661 (interactive)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
662 (package-get-require-base t)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
663 ;; Load a fresh copy
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
664 (catch 'exit
4783
e29fcfd8df5f Eliminate most core code byte-compile warnings.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4188
diff changeset
665 (mapc (lambda (pkg)
e29fcfd8df5f Eliminate most core code byte-compile warnings.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4188
diff changeset
666 (if (not (package-get (car pkg) nil 'never))
e29fcfd8df5f Eliminate most core code byte-compile warnings.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4188
diff changeset
667 (throw 'exit nil))) ;; Bail out if error detected
e29fcfd8df5f Eliminate most core code byte-compile warnings.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4188
diff changeset
668 packages-package-list))
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 683
diff changeset
669 (package-net-update-installed-db))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
670
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
671 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
672 (defun package-get-all (package version &optional fetched-packages install-dir)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
673 "Fetch PACKAGE with VERSION and all other required packages.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
674 Uses `package-get-base' to determine just what is required and what
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
675 package provides that functionality. If VERSION is nil, retrieves
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
676 latest version. Optional argument FETCHED-PACKAGES is used to keep
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
677 track of packages already fetched. Optional argument INSTALL-DIR,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
678 if non-nil, specifies the package directory where fetched packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
679 should be installed.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
680
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
681 Returns nil upon error."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
682 (interactive (package-get-interactive-package-query t nil))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
683 (let* ((the-package (package-get-info-find-package package-get-base
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
684 package))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
685 (this-package (package-get-info-version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
686 the-package version))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
687 (this-requires (package-get-info-prop this-package 'requires)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
688 (catch 'exit
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
689 (setq version (package-get-info-prop this-package 'version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
690 (unless (package-get-installedp package version)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
691 (if (not (package-get package version nil install-dir))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
692 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
693 (setq fetched-packages nil)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
694 (throw 'exit nil))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
695 (setq fetched-packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
696 (append (list package)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
697 (package-get-info-prop this-package 'provides)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
698 fetched-packages))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
699 ;; grab everything that this package requires plus recursively
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
700 ;; grab everything that the requires require. Keep track
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
701 ;; in `fetched-packages' the list of things provided -- this
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
702 ;; keeps us from going into a loop
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
703 (while this-requires
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
704 (if (not (member (car this-requires) fetched-packages))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
705 (let* ((reqd-package (package-get-package-provider
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
706 (car this-requires) t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
707 (reqd-version (cadr reqd-package))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
708 (reqd-name (car reqd-package)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
709 (if (null reqd-name)
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
710 (error 'search-failed
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
711 (format "Unable to find a provider for %s"
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
712 (car this-requires))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
713 (if (not (setq fetched-packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
714 (package-get-all reqd-name reqd-version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
715 fetched-packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
716 install-dir)))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
717 (throw 'exit nil))))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
718 (setq this-requires (cdr this-requires))))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
719 fetched-packages))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
720
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
721 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
722 (defun package-get-dependencies (packages)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
723 "Compute dependencies for PACKAGES.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
724 Uses `package-get-base' to determine just what is required and what
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
725 package provides that functionality. Returns the list of packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
726 required by PACKAGES."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
727 (package-get-require-base t)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
728 (let ((orig-packages packages)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
729 dependencies provided)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
730 (while packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
731 (let* ((package (car packages))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
732 (the-package (package-get-info-find-package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
733 package-get-base package))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
734 (this-package (package-get-info-version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
735 the-package nil))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
736 (this-requires (package-get-info-prop this-package 'requires))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
737 (new-depends (set-difference
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
738 (mapcar
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
739 #'(lambda (reqd)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
740 (let* ((reqd-package (package-get-package-provider reqd))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
741 (reqd-name (car reqd-package)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
742 (if (null reqd-name)
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
743 (error 'search-failed
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
744 (format "Unable to find a provider for %s" reqd)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
745 reqd-name))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
746 this-requires)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
747 dependencies))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
748 (this-provides (package-get-info-prop this-package 'provides)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
749 (setq dependencies
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
750 (union dependencies new-depends))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
751 (setq provided
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
752 (union provided (union (list package) this-provides)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
753 (setq packages
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
754 (union new-depends (cdr packages)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
755 (set-difference dependencies orig-packages)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
756
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
757 (defun package-get-load-package-file (lispdir file)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
758 (let (pathname)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
759 (setq pathname (expand-file-name file lispdir))
793
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
760 (with-trapping-errors
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
761 :operation (format "loading package file \"%s\"" pathname)
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
762 :error-form nil
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
763 (load pathname t)
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
764 t)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
765
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
766 (defun package-get-init-package (lispdir)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
767 "Initialize the package.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
768 This really assumes that the package has never been loaded. Updating
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
769 a newer package can cause problems, due to old, obsolete functions in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
770 the old package.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
771
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
772 Return `t' upon complete success, `nil' if any errors occurred."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
773 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
774 (if (and lispdir
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
775 (file-accessible-directory-p lispdir))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
776 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
777 ;; Add lispdir to load-path if it doesn't already exist.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
778 ;; NOTE: this does not take symlinks, etc., into account.
2802
52d126cb63af [xemacs-hg @ 2005-06-05 22:46:55 by adrian]
adrian
parents: 2151
diff changeset
779 (add-to-list 'load-path (file-name-as-directory lispdir))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
780 (if (not (package-get-load-package-file lispdir "auto-autoloads"))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
781 (package-get-load-package-file lispdir "_pkg"))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
782 t)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
783 nil)))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
784
2151
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
785 (defun package-get-info-name-array ()
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
786 "Internal, used by `package-get-info'."
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
787 (let ((pkgs package-get-base)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
788 names)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
789 (while pkgs
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
790 (setq names (let ((name (caar pkgs)))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
791 (push (cons (format "%s" name) name) names)))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
792 (setq pkgs (cdr pkgs)))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
793 names))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
794
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
795 (defconst package-get-info-info-array
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
796 '(("standards-version" . standards-version)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
797 ("version" . version)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
798 ("author-version" . author-version)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
799 ("date" . date)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
800 ("build-date" . build-date)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
801 ("maintainer" . maintainer)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
802 ("distribution" . distribution)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
803 ("priority" . priority)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
804 ("category" . category)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
805 ("dump" . dump)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
806 ("description" . description)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
807 ("filename" . filename)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
808 ("md5sum" . md5sum)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
809 ("size" . size)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
810 ("provides" . provides)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
811 ("requires" . requires)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
812 ("type" . type))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
813 "Internal, used by `package-get-info'.")
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
814
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
815 ;;;###autoload
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
816 (defun package-get-info (package information &optional arg remote)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
817 "Get information about a package.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
818
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
819 Quite similar to `package-get-info-prop', but can retrieve a lot more
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
820 information.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
821
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
822 Argument PACKAGE is the name of an XEmacs package (a symbol). It must
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
823 be a valid package, ie, a member of `package-get-base'.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
824
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
825 Argument INFORMATION is a symbol that can be any one of:
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
826
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
827 standards-version Package system version (not used).
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
828 version Version of the XEmacs package.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
829 author-version The upstream version of the package.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
830 date The date the package was last modified.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
831 build-date The date the package was last built.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
832 maintainer The maintainer of the package.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
833 distribution Will always be \"xemacs\" (not used).
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
834 priority \"low\", \"medium\", or \"high\" (not used).
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
835 category Either \"standard\", \"mule\", or \"unsupported\"..
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
836 dump Is the package dumped (not used).
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
837 description A description of the package.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
838 filename The filename of the binary tarball of the package.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
839 md5sum The md5sum of filename.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
840 size The size in bytes of filename.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
841 provides A list of symbols that this package provides.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
842 requires A list of packages that this package requires.
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
843 type Can be either \"regular\" or \"single-file\".
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
844
2151
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
845 Optional argument ARG is a prefix arg. Without a value, ie, just
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
846 doing `C-u M-x package-get-info' will insert the information at point
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
847 in the current buffer using a local package list.
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
848
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
849 ARG can also be given a value of 2 or 3. If 2, use a remote package
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
850 list, displaying the information in the minubuffer. If 3, use a remote
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
851 package list and insert the information at point in the current buffer.
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
852
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
853 If optional argument REMOTE is non-nil use a package list from a
2151
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
854 remote site.
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
855
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
856 To use a remote package list, either via the prefix argument ARG or
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
857 via the REMOTE argument `package-get-remote' must be non-nil. If
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
858 `package-get-remote' is nil, the local package list will be used.
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
859
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
860 If this function is called interactively it will display INFORMATION
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
861 in the minibuffer."
2151
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
862 (interactive "i\ni\np")
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
863 (if (and package-get-remote
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
864 (or (eq arg 2)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
865 (eq arg 3)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
866 remote))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
867 (package-get-require-base t)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
868 (package-get-require-base nil))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
869 (let ((all-pkgs package-get-base)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
870 (package (or package
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
871 (intern (completing-read
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
872 "Package: "
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
873 (package-get-info-name-array) nil t))))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
874 (information (or information
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
875 (intern (completing-read
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
876 "Info: "
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
877 package-get-info-info-array nil t))))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
878 info)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
879 (loop until (equal package (caar all-pkgs))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
880 do (setq all-pkgs (cdr all-pkgs))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
881 do (if (not all-pkgs)
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
882 (error 'invalid-argument
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
883 (format "%s is not a valid package" package))))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
884 (setq info (plist-get (cadar all-pkgs) information))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
885 (if (interactive-p)
2151
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
886 (if (or (eq arg 3)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
887 (eq arg 4))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
888 (insert (format "%s" info))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
889 (if (package-get-key package :version)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
890 (message "%s" info)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
891 (message "%s (Package: %s is not installed)" info package)))
2151
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
892 info)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
893
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
894 ;;;###autoload
1832
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
895 (defun package-get-list-packages-where (item field &optional arg)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
896 "Return a list of packages that fulfill certain criteria.
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
897
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
898 Argument ITEM, a symbol, is what you want to check for. ITEM must be a
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
899 symbol even when it doesn't make sense to be a symbol \(think, searching
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
900 maintainers, descriptions, etc\). The function will convert the symbol
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
901 to a string if a string is what is needed. The downside to this is that
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
902 ITEM can only ever be a single word.
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
903
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
904 Argument FIELD, a symbol, is the field to check in. You can specify
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
905 any one of:
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
906
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
907 Field Sane or Allowable Content
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
908 description any single word
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
909 category `standard' or `mule'
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
910 maintainer any single word
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
911 build-date yyyy-mm-dd
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
912 date yyyy-mm-dd
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
913 type `regular' or `single'
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
914 requires any package name
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
915 provides any symbol
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
916 priority `low', `medium', or `high'
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
917
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
918 Optional Argument ARG, a prefix arg, insert output at point in the
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
919 current buffer."
2151
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
920 (interactive
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
921 (list (intern (read-string "List packages that contain (text): "))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
922 (intern (completing-read "in their package-info field (completion available): "
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
923 '(("description" . description)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
924 ("category" . category)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
925 ("maintainer" . maintainer)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
926 ("build-date" . build-date)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
927 ("date" . date)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
928 ("type" . type)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
929 ("requires" . requires)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
930 ("provides" . provides)
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
931 ("priority" . priority)) nil t))
f33f1487208d [xemacs-hg @ 2004-06-25 21:24:36 by youngs]
youngs
parents: 1937
diff changeset
932 current-prefix-arg))
1832
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
933 (package-get-require-base nil)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
934 (let ((pkgs package-get-base)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
935 (strings '(description category maintainer build-date date))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
936 (symbols '(type requires provides priority))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
937 results)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
938 (cond ((memq field strings)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
939 (setq item (symbol-name item))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
940 (while pkgs
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
941 (when (string-match item (package-get-info (caar pkgs) field))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
942 (setq results (push (caar pkgs) results)))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
943 (setq pkgs (cdr pkgs))))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
944 ((memq field symbols)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
945 (if (or (eq field 'type)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
946 (eq field 'priority))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
947 (while pkgs
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
948 (when (eq item (package-get-info (caar pkgs) field))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
949 (setq results (push (caar pkgs) results)))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
950 (setq pkgs (cdr pkgs)))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
951 (while pkgs
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
952 (when (memq item (package-get-info (caar pkgs) field))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
953 (setq results (push (caar pkgs) results)))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
954 (setq pkgs (cdr pkgs)))))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
955 (t
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
956 (error 'wrong-type-argument field)))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
957 (if (interactive-p)
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
958 (if arg
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
959 (insert (format "%s" results))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
960 (message "%s" results)))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
961 results))
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
962
5d8dcaecc32b [xemacs-hg @ 2003-12-19 11:24:58 by youngs]
youngs
parents: 1563
diff changeset
963 ;;;###autoload
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
964 (defun package-get (package &optional version conflict install-dir)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
965 "Fetch PACKAGE from remote site.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
966 Optional arguments VERSION indicates which version to retrieve, nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
967 means most recent version. CONFLICT indicates what happens if the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
968 package is already installed. Valid values for CONFLICT are:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
969 'always always retrieve the package even if it is already installed
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
970 'never do not retrieve the package if it is installed.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
971 INSTALL-DIR, if non-nil, specifies the package directory where
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
972 fetched packages should be installed.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
973
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
974 The value of `package-get-base' is used to determine what files should
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
975 be retrieved. The value of `package-get-remote' is used to determine
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
976 where a package should be retrieved from.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
977
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
978 Once the package is retrieved, its md5 checksum is computed. If that
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
979 sum does not match that stored in `package-get-base' for this version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
980 of the package, an error is signalled.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
981
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
982 Returns `t' upon success, the symbol `error' if the package was
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
983 successfully installed but errors occurred during initialization, or
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
984 `nil' upon error."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
985 (interactive (package-get-interactive-package-query nil t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
986 (catch 'skip-update
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
987 (let* ((this-package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
988 (package-get-info-version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
989 (package-get-info-find-package package-get-base
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
990 package) version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
991 (latest (package-get-info-prop this-package 'version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
992 (installed (package-get-key package :version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
993 (found nil)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
994 (search-dir package-get-remote)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
995 (base-filename (package-get-info-prop this-package 'filename))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
996 (package-status t)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
997 filenames full-package-filename)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
998 (if (and (equal (package-get-info package 'category) "mule")
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
999 (not (featurep 'mule)))
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1000 (error 'invalid-state
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1001 "Mule packages can't be installed with a non-Mule XEmacs"))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1002 (if (null this-package)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1003 (if package-get-remote
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1004 (error 'search-failed
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1005 (format "Couldn't find package %s with version %s"
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1006 package version))
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1007 (error 'syntax-error
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1008 "No download site or local package location specified.")))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1009 (if (null base-filename)
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1010 (error 'syntax-error
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1011 (format "No filename associated with package %s, version %s"
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1012 package version)))
1378
69a674f5861f [xemacs-hg @ 2003-03-24 16:30:55 by youngs]
youngs
parents: 1374
diff changeset
1013 (setq install-dir (package-admin-get-install-dir package install-dir))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1014
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1015 ;; If they asked for the latest using version=nil, don't get an older
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1016 ;; version than we already have.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1017 (if installed
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1018 (if (> (if (stringp installed)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1019 (string-to-number installed)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1020 installed)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1021 (if (stringp latest)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1022 (string-to-number latest)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1023 latest))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1024 (if (not (null version))
825
eb3bc15a6e0f [xemacs-hg @ 2002-05-02 14:35:28 by youngs]
youngs
parents: 824
diff changeset
1025 (warn "Installing %s package version %s, you had a newer version %s"
793
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
1026 package latest installed)
825
eb3bc15a6e0f [xemacs-hg @ 2002-05-02 14:35:28 by youngs]
youngs
parents: 824
diff changeset
1027 (warn "Skipping %s package, you have a newer version %s"
793
e38acbeb1cae [xemacs-hg @ 2002-03-29 04:46:17 by ben]
ben
parents: 776
diff changeset
1028 package installed)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1029 (throw 'skip-update t))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1030
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1031 ;; Contrive a list of possible package filenames.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1032 ;; Ugly. Is there a better way to do this?
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1033 (setq filenames (cons base-filename nil))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1034 (if (string-match "^\\(..*\\)\.tar\.gz$" base-filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1035 (setq filenames (append filenames
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1036 (list (concat (match-string 1 base-filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1037 ".tgz")))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1038
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1039 (setq version latest)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1040 (unless (and (eq conflict 'never)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1041 (package-get-installedp package version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1042 ;; Find the package from the search list in package-get-remote
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1043 ;; and copy it into the staging directory. Then validate
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1044 ;; the checksum. Finally, install the package.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1045 (catch 'done
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1046 (let (search-filenames host dir current-filename dest-filename)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1047 ;; In each search directory ...
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1048 (when search-dir
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1049 (setq host (car search-dir)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1050 dir (car (cdr search-dir))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1051 search-filenames filenames)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1052
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1053 ;; Look for one of the possible package filenames ...
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1054 (while search-filenames
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1055 (setq current-filename (car search-filenames)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1056 dest-filename (package-get-staging-dir current-filename))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1057 (cond
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1058 ;; No host means look on the current system.
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1059 ((null host)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1060 (setq full-package-filename
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1061 (substitute-in-file-name
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1062 (expand-file-name current-filename
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1063 (file-name-as-directory dir)))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1064
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1065 ;; If it's already on the disk locally, and the size is
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1066 ;; correct
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1067 ((and (file-exists-p dest-filename)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1068 (eq (nth 7 (file-attributes dest-filename))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1069 (package-get-info package 'size)))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1070 (setq full-package-filename dest-filename))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1071
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1072 ;; If the file exists on the remote system ...
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1073 ((file-exists-p (package-get-remote-filename
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1074 search-dir current-filename))
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1075 ;; Get it
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1076 (setq full-package-filename dest-filename)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1077 (message "Retrieving package `%s' ..."
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1078 current-filename)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1079 (sit-for 0)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1080 (copy-file (package-get-remote-filename search-dir
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1081 current-filename)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1082 full-package-filename t)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1083
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1084 ;; If we found it, we're done.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1085 (if (and full-package-filename
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1086 (file-exists-p full-package-filename))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1087 (throw 'done nil))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1088 ;; Didn't find it. Try the next possible filename.
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1089 (setq search-filenames (cdr search-filenames))))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1090
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1091 (if (or (not full-package-filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1092 (not (file-exists-p full-package-filename)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1093 (if package-get-remote
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1094 (error 'search-failed
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1095 (format "Unable to find file %s" base-filename))
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1096 (error 'syntax-error
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1097 "No download sites or local package locations specified.")))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1098 ;; Validate the md5 checksum
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1099 ;; Doing it with XEmacs removes the need for an external md5 program
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1100 (message "Validating checksum for `%s'..." package) (sit-for 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1101 (with-temp-buffer
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1102 (insert-file-contents-literally full-package-filename)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1103 (if (not (string= (md5 (current-buffer))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1104 (package-get-info-prop this-package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1105 'md5sum)))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1106 (progn
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1107 (delete-file full-package-filename)
1410
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1108 (error 'process-error
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1109 (format "Package %s does not match md5 checksum %s has been deleted"
44de306310b8 [xemacs-hg @ 2003-04-14 03:40:26 by youngs]
youngs
parents: 1378
diff changeset
1110 base-filename full-package-filename)))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1111
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1112 (package-admin-delete-binary-package package install-dir)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1113
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1114 (message "Installing package `%s' ..." package) (sit-for 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1115 (let ((status
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1116 (package-admin-add-binary-package full-package-filename
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1117 install-dir)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1118 (if (= status 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1119 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1120 ;; clear messages so that only messages from
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1121 ;; package-get-init-package are seen, below.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1122 (clear-message)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1123 (if (package-get-init-package (package-admin-get-lispdir
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1124 install-dir package))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1125 (progn
628
e545f3ec2337 [xemacs-hg @ 2001-07-14 08:42:16 by youngs]
youngs
parents: 502
diff changeset
1126 (run-hook-with-args 'package-install-hook package install-dir)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1127 (message "Added package `%s'" package)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1128 (sit-for 0))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1129 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1130 ;; display message only if there isn't already one.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1131 (if (not (current-message))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1132 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1133 (message "Added package `%s' (errors occurred)"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1134 package)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1135 (sit-for 0)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1136 (if package-status
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1137 (setq package-status 'errors)))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1138 (message "Installation of package %s failed." base-filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1139 (sit-for 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1140 (switch-to-buffer package-admin-temp-buffer)
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1141 (delete-file full-package-filename)
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1142 (setq package-status nil)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1143 (setq found t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1144 (if (and found package-get-remove-copy)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1145 (delete-file full-package-filename))
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1146 package-status)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1147
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1148 (defun package-get-info-find-package (which name)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1149 "Look in WHICH for the package called NAME and return all the info
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1150 associated with it. See `package-get-base' for info on the format
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1151 returned.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1152
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1153 To access fields returned from this, use
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1154 `package-get-info-version' to return information about particular a
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1155 version. Use `package-get-info-find-prop' to find particular property
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1156 from a version returned by `package-get-info-version'."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1157 (interactive "xPackage list: \nsPackage Name: ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1158 (if which
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1159 (if (eq (caar which) name)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1160 (cdar which)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1161 (if (cdr which)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1162 (package-get-info-find-package (cdr which) name)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1163
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1164 (defun package-get-info-version (package version)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1165 "In PACKAGE, return the plist associated with a particular VERSION of the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1166 package. PACKAGE is typically as returned by
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1167 `package-get-info-find-package'. If VERSION is nil, then return the
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1168 first (aka most recent) version. Use `package-get-info-find-prop'
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1169 to retrieve a particular property from the value returned by this."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1170 (interactive (package-get-interactive-package-query t t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1171 (while (and version package (not (string= (plist-get (car package) 'version) version)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1172 (setq package (cdr package)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1173 (if package (car package)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1174
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1175 (defun package-get-info-prop (package-version property)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1176 "In PACKAGE-VERSION, return the value associated with PROPERTY.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1177 PACKAGE-VERSION is typically returned by `package-get-info-version'
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1178 and PROPERTY is typically (although not limited to) one of the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1179 following:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1180
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1181 version - version of this package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1182 provides - list of symbols provided
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1183 requires - list of symbols that are required.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1184 These in turn are provided by other packages.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1185 size - size of the bundled package
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1186 md5sum - computed md5 checksum"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1187 (interactive "xPackage Version: \nSProperty")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1188 (plist-get package-version property))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1189
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1190 (defun package-get-info-version-prop (package-list package version property)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1191 "In PACKAGE-LIST, search for PACKAGE with this VERSION and return
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1192 PROPERTY value."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1193 (package-get-info-prop
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1194 (package-get-info-version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1195 (package-get-info-find-package package-list package) version) property))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1196
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1197 (defun package-get-staging-dir (filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1198 "Return a good place to stash FILENAME when it is retrieved.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1199 Use `package-get-dir' for directory to store stuff.
629
a6c89d799f00 [xemacs-hg @ 2001-07-15 08:18:59 by adrian]
adrian
parents: 628
diff changeset
1200 Creates `package-get-dir' if it doesn't exist."
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1201 (interactive "FPackage filename: ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1202 (if (not (file-exists-p package-get-dir))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1203 (make-directory package-get-dir))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1204 (expand-file-name
776
79940b592197 [xemacs-hg @ 2002-03-15 07:43:14 by ben]
ben
parents: 771
diff changeset
1205 (file-name-nondirectory (or (and-fboundp 'efs-ftp-path
79940b592197 [xemacs-hg @ 2002-03-15 07:43:14 by ben]
ben
parents: 771
diff changeset
1206 (nth 2 (efs-ftp-path filename)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1207 filename))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1208 (file-name-as-directory package-get-dir)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1209
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1210 (defun package-get-remote-filename (search filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1211 "Return FILENAME as a remote filename.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1212 It first checks if FILENAME already is a remote filename. If it is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1213 not, then it uses the (car search) as the remote site-name and the (cadr
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1214 search) as the remote-directory and concatenates filename. In other
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1215 words
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1216 site-name:remote-directory/filename.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1217
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1218 If (car search) is nil, (cadr search is interpreted as a local directory).
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1219 "
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1220 (if (file-remote-p filename)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1221 filename
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1222 (let ((dir (cadr search)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1223 (concat (when (car search)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1224 (concat
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1225 (if (string-match "@" (car search))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1226 "/"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1227 "/anonymous@")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1228 (car search) ":"))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1229 (if (string-match "/$" dir)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1230 dir
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1231 (concat dir "/"))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1232 filename))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1233
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1234 (defun package-get-installedp (package version)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1235 "Determine if PACKAGE with VERSION has already been installed.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1236 I'm not sure if I want to do this by searching directories or checking
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1237 some built in variables. For now, use packages-package-list."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1238 ;; Use packages-package-list which contains name and version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1239 (equal (plist-get
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1240 (package-get-info-find-package packages-package-list
5344
2a54dfbe434f Don't quote keywords, they've been self-quoting for well over a decade.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4787
diff changeset
1241 package) :version)
1368
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
1242 (if (floatp version)
1aba3abebad6 [xemacs-hg @ 2003-03-21 01:19:37 by adrian]
adrian
parents: 1365
diff changeset
1243 version
1365
02909207294a [xemacs-hg @ 2003-03-20 13:19:56 by youngs]
youngs
parents: 1111
diff changeset
1244 (string-to-number version))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1245
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1246 ;;;###autoload
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1247 (defun package-get-package-provider (sym &optional force-current)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1248 "Search for a package that provides SYM and return the name and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1249 version. Searches in `package-get-base' for SYM. If SYM is a
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1250 consp, then it must match a corresponding (provide (SYM VERSION)) from
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1251 the package.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1252
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1253 If FORCE-CURRENT is non-nil make sure the database is up to date. This might
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1254 lead to Emacs accessing remote sites."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1255 (interactive "SSymbol: ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1256 (package-get-require-base force-current)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1257 (let ((packages package-get-base)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1258 (done nil)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1259 (found nil))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1260 (while (and (not done) packages)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1261 (let* ((this-name (caar packages))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1262 (this-package (cdr (car packages)))) ;strip off package name
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1263 (while (and (not done) this-package)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1264 (if (or (eq this-name sym)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1265 (eq (cons this-name
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1266 (package-get-info-prop (car this-package) 'version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1267 sym)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1268 (member sym
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1269 (package-get-info-prop (car this-package) 'provides)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1270 (progn (setq done t)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1271 (setq found
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1272 (list (caar packages)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1273 (package-get-info-prop (car this-package) 'version))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1274 (setq this-package (cdr this-package)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1275 (setq packages (cdr packages)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1276 (when (interactive-p)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1277 (if found
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1278 (message "%S" found)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1279 (message "No appropriate package found")))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1280 found))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1281
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1282 (defun package-get-ever-installed-p (pkg &optional notused)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1283 (string-match "-package$" (symbol-name pkg))
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1284 (custom-initialize-set
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1285 pkg
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1286 (if (package-get-info-find-package
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
1287 packages-package-list
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1288 (intern (substring (symbol-name pkg) 0 (match-beginning 0))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1289 t)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1290
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1291 (provide 'package-get)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1292 ;;; package-get.el ends here