annotate lisp/packages/backup-dir.el @ 169:15872534500d r20-3b11

Import from CVS: tag r20-3b11
author cvs
date Mon, 13 Aug 2007 09:46:53 +0200
parents bcdc7deadc19
children e45d5e7c476e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
12
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
1 ;;; BACKUP-DIR.EL: Emacs functions to allow backup files to live in
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
2 ;;; some other directory(s). Version 2.0
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
3 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
4 ;;; Copyright (C) 1992-97 Greg Klanderman
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
5 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
6 ;;; This program is free software; you can redistribute it and/or modify
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
7 ;;; it under the terms of the GNU General Public License as published by
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
8 ;;; the Free Software Foundation; either version 1, or (at your option)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
9 ;;; any later version.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
10 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
11 ;;; This program is distributed in the hope that it will be useful,
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
12 ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
13 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
14 ;;; GNU General Public License for more details.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
15 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
16 ;;; A copy of the GNU General Public License can be obtained from
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
17 ;;; the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
18 ;;; 02139, USA.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
19 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
20 ;;; Send bug reports, etc. to greg@alphatech.com or gregk@ai.mit.edu.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
21 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
22 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
23 ;;; Modification History
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
24 ;;; ====================
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
25 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
26 ;;; 12/28/1996 Version 2.0
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
27 ;;; Updated for XEmacs 19.15b4, much of code reorganized & cleaned up
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
28 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
29 ;;; 12/27/1996 Version 1.6
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
30 ;;; explicit loading of dired replaced to use dired-load-hook
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
31 ;;; (suggested by Thomas Feuster, feuster@tp4.physik.uni-giessen.de)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
32 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
33 ;;; 12/2/1996 Version 1.5
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
34 ;;; Took out obsolete byte compiler options
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
35 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
36 ;;; 9/24/1996 Version 1.4
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
37 ;;; Fix some bugs, change to alist OPTIONS list (ok-create, full-path..) from
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
38 ;;; separate fields for each option variable. Added search-upward option.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
39 ;;; Added new function `find-file-latest-backup' to find a file's latest backup.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
40 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
41 ;;; 1/26/1996 Version 1.3
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
42 ;;; Name change to backup-dir.el
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
43 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
44 ;;; 3/22/1995 Version 1.2
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
45 ;;; Added new definitions for functions `file-newest-backup', `latest-backup-file',
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
46 ;;; and `diff-latest-backup-file' so various other emacs functions will find the
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
47 ;;; right backup files.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
48 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
49 ;;; 4/23/1993 Version 1.1
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
50 ;;; Reworked to allow different behavior for different files based on the
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
51 ;;; alist `bkup-backup-directory-info'.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
52 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
53 ;;; Fall 1992 Version 1.0
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
54 ;;; Name change and added ability to make directories absolute. Added the
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
55 ;;; full path stuff to make backup name unique for absolute directories.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
56 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
57 ;;; Spring 1992 Version 0.0
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
58 ;;; Original
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
59 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
60 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
61 ;;; Description:
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
62 ;;; ============
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
63 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
64 ;;; Allows backup files to be optionally stored in some directories, based on
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
65 ;;; the value of the alist, `bkup-backup-directory-info'. This variable is a
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
66 ;;; list of lists of the form (FILE-REGEXP BACKUP-DIR OPTIONS ...). If the
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
67 ;;; filename to be backed up matches FILE-REGEXP, or FILE-REGEXP is t, then
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
68 ;;; BACKUP-DIR is used as the path for its backups. Directories may begin with
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
69 ;;; "/" to specify an absolute pathname. If BACKUP-DIR does not exist and
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
70 ;;; OPTIONS contains the symbol `ok-create', then it is created if possible.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
71 ;;; Otherwise the usual behavior (backup in the same directory as the file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
72 ;;; results. If OPTIONS contains the symbol `full-path', then the full path of
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
73 ;;; the file being backed up is prepended to the backup file name, with each "/"
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
74 ;;; replaced by a "!". This is intended for cases where an absolute backup path
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
75 ;;; is used. If OPTIONS contains the symbol `search-upward' and the backup
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
76 ;;; directory BACKUP-DIR is a relative path, then a directory with that name is
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
77 ;;; searched for starting at the current directory and proceeding upward (..,
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
78 ;;; ../.., etc) until one is found of that name or the root is reached, and if
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
79 ;;; one is found it is used as the backup directory. Finally, if no FILE-REGEXP
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
80 ;;; matches the file name being backed up, then the usual behavior results.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
81 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
82 ;;; These lines from my .emacs load this file and set the values I like:
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
83 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
84 ;;; (require 'backup-dir)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
85 ;;; (setq bkup-backup-directory-info
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
86 ;;; '(("/home/greg/.*" "/~/.backups/" ok-create full-path)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
87 ;;; (t ".backups/" full-path search-upward)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
88 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
89 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
90 ;;; The package also provides a new function, `find-file-latest-backup' to find
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
91 ;;; the latest backup file for the current buffer's file.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
92 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
93 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
94 ;;; This file is based on `files.el' from XEmacs 19.15b4.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
95 ;;; It has not been extensively tested on GNU Emacs past 18.58.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
96 ;;; It does not work under ms-dos.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
97
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
98
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
99
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
100 (byte-compiler-options
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
101 (optimize t)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
102 (warnings (- free-vars)) ; Don't warn about free variables
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
103 )
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
104
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
105
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
106 ;;; New variables affecting backup file behavior
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
107 ;;; This is the only user-customizable variable for this package.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
108 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
109 (defvar bkup-backup-directory-info nil
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
110 "Alist of (FILE-REGEXP BACKUP-DIR OPTIONS ...))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
111 If the filename to be backed up matches FILE-REGEXP, or FILE-REGEXP is t,
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
112 then BACKUP-DIR is used as the path for its backups. Directories may
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
113 begin with \"/\" to specify an absolute pathname. If BACKUP-DIR does
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
114 not exist and OPTIONS contains the symbol `ok-create', then it is created if possible.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
115 Otherwise the usual behavior (backup in the same directory as the file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
116 results. If OPTIONS contains the symbol `full-path', then the full path of the file
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
117 being backed up is prepended to the backup file name, with each \"/\"
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
118 replaced by a \"!\". This is intended for cases where an absolute backup path
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
119 is used. If OPTIONS contains the symbol `search-upward' and the backup
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
120 directory BACKUP-DIR is a relative path, then a directory with that name is
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
121 searched for starting at the current directory and proceeding upward (..,
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
122 ../.., etc) until one is found of that name or the root is reached, and if
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
123 one is found it is used as the backup directory. Finally, if no FILE-REGEXP
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
124 matches the file name being backed up, then the usual behavior results.")
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
125
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
126
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
127 ;;; New functions
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
128 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
129 (defun bkup-search-upward-for-backup-dir (base bd-name)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
130 "search upward for a directory named BD-NAME, starting in the
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
131 directory BASE and continuing with its parent directories until
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
132 one is found or the root is reached."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
133 (let ((prev nil) (curr base) (gotit nil) (tryit nil))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
134 (while (and (not gotit)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
135 (not (equal prev curr))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
136 (not (equal curr "//")))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
137 (setq prev curr)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
138 (setq curr (expand-file-name (concat curr "../")))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
139 (setq tryit (expand-file-name bd-name curr))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
140 (if (and (file-directory-p tryit) (file-exists-p tryit))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
141 (setq gotit tryit)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
142 (if (and gotit
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
143 (eq (aref gotit (1- (length gotit))) ?/))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
144 (setq gotit (substring gotit 0 (1- (length gotit)))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
145 gotit))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
146
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
147 (defun bkup-replace-slashes-with-exclamations (s)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
148 "Replaces slashes in the string S with exclamations.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
149 A new string is produced and returned."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
150 (let ((ns (copy-sequence s))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
151 (i (1- (length s))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
152 (while (>= i 0)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
153 (if (= (aref ns i) ?/)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
154 (aset ns i ?!))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
155 (setq i (1- i)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
156 ns))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
157
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
158 (defun bkup-try-making-directory (dir)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
159 "try making directory DIR, return non-nil if successful"
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
160 (condition-case ()
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
161 (progn (make-directory dir t)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
162 t)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
163 (t
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
164 nil)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
165
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
166 (defun bkup-backup-basename (file full-path)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
167 "Gives the base part of the backup name for FILE, according to FULL-PATH."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
168 (if full-path
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
169 (bkup-replace-slashes-with-exclamations file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
170 (file-name-nondirectory file)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
171
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
172 (defun bkup-backup-directory-and-basename (file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
173 "Return the cons of the backup directory name
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
174 and backup file name base for FILE."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
175 (let ((file (expand-file-name file)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
176 (let ((dir (file-name-directory file))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
177 (alist bkup-backup-directory-info)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
178 (bk-dir nil)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
179 (bk-base nil))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
180 (if (listp alist)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
181 (while (and (not bk-dir) alist)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
182 (if (or (eq (car (car alist)) t)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
183 (eq (string-match (car (car alist)) file) 0))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
184 (let* ((bd (car (cdr (car alist))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
185 (bd-rel-p (and (> (length bd) 0)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
186 (not (eq (aref bd 0) ?/))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
187 (bd-expn (expand-file-name bd dir))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
188 (bd-noslash (if (eq (aref bd-expn (1- (length bd-expn))) ?/)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
189 (substring bd-expn 0 (1- (length bd-expn)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
190 bd-expn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
191 (options (cdr (cdr (car alist))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
192 (ok-create (and (memq 'ok-create options) t))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
193 (full-path (and (memq 'full-path options) t))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
194 (search-upward (and (memq 'search-upward options) t)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
195 (if bd-expn
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
196 (cond ((or (file-directory-p bd-expn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
197 (and ok-create
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
198 (not (file-exists-p bd-expn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
199 (bkup-try-making-directory bd-noslash)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
200 (setq bk-dir (concat bd-noslash "/")
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
201 bk-base (bkup-backup-basename file full-path)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
202 ((and bd-rel-p search-upward)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
203 (let ((bd-up (bkup-search-upward-for-backup-dir dir bd)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
204 (if bd-up
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
205 (setq bk-dir (concat bd-up "/")
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
206 bk-base (bkup-backup-basename file full-path)))))))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
207 (setq alist (cdr alist))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
208 (if (and bk-dir bk-base)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
209 (cons bk-dir bk-base)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
210 (cons dir (bkup-backup-basename file nil))))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
211
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
212
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
213 ;;; This next one is based on the following from `files.el'
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
214 ;;; but accepts a second optional argument
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
215
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
216 ;;(defun make-backup-file-name (file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
217 ;; "Create the non-numeric backup file name for FILE.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
218 ;;This is a separate function so you can redefine it for customization."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
219 ;; (if (and (eq system-type 'ms-dos)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
220 ;; (not (msdos-long-file-names)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
221 ;; (let ((fn (file-name-nondirectory file)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
222 ;; (concat (file-name-directory file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
223 ;; (if (string-match "\\([^.]*\\)\\(\\..*\\)?" fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
224 ;; (substring fn 0 (match-end 1)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
225 ;; ".bak"))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
226 ;; (concat file "~")))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
227
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
228 (defun bkup-make-backup-file-name (file &optional dir-n-base)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
229 "Create the non-numeric backup file name for FILE.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
230 Optionally accept a list containing the backup directory and
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
231 backup basename. NB: we don't really handle ms-dos."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
232 (if (and (eq system-type 'ms-dos)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
233 (not (and (fboundp 'msdos-long-file-names) (msdos-long-file-names))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
234 (let ((fn (file-name-nondirectory file)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
235 (concat (file-name-directory file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
236 (if (string-match "\\([^.]*\\)\\(\\..*\\)?" fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
237 (substring fn 0 (match-end 1)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
238 ".bak"))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
239 (let ((d-n-b (or dir-n-base
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
240 (bkup-backup-directory-and-basename file))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
241 (concat (car d-n-b) (cdr d-n-b) "~"))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
242
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
243 (defun bkup-existing-backup-files (fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
244 "Return list of existing backup files for file"
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
245 (let* ((efn (expand-file-name fn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
246 (dir-n-base (bkup-backup-directory-and-basename efn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
247 (non-num-bk-name (bkup-make-backup-file-name efn dir-n-base))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
248 (non-num-bk (file-exists-p non-num-bk-name))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
249 (backup-dir (car dir-n-base))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
250 (base-versions (concat (cdr dir-n-base) ".~"))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
251 (possibilities (file-name-all-completions base-versions backup-dir))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
252 (poss (mapcar #'(lambda (name) (concat backup-dir name)) possibilities)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
253 (mapcar #'expand-file-name
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
254 (if non-num-bk (cons non-num-bk-name poss) poss))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
255
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
256 (defun find-file-latest-backup (file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
257 "Find the latest backup file for FILE"
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
258 (interactive (list (read-file-name (format "Find latest backup of file (default %s): "
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
259 (file-name-nondirectory (buffer-file-name)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
260 nil (buffer-file-name) t)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
261 (let ((backup (file-newest-backup file)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
262 (if backup
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
263 (find-file backup)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
264 (message "no backups found for `%s'" file))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
265
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
266
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
267 ;;; Functions changed from `files.el' and elsewhere -- originals precede new versions
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
268
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
269 ;;(defun make-backup-file-name (file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
270 ;; "Create the non-numeric backup file name for FILE.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
271 ;;This is a separate function so you can redefine it for customization."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
272 ;; (if (and (eq system-type 'ms-dos)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
273 ;; (not (msdos-long-file-names)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
274 ;; (let ((fn (file-name-nondirectory file)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
275 ;; (concat (file-name-directory file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
276 ;; (if (string-match "\\([^.]*\\)\\(\\..*\\)?" fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
277 ;; (substring fn 0 (match-end 1)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
278 ;; ".bak"))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
279 ;; (concat file "~")))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
280
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
281 (defun make-backup-file-name (file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
282 "Create the non-numeric backup file name for FILE.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
283 This is a separate function so you can redefine it for customization.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
284 *** Changed by \"backup-dir.el\""
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
285 (bkup-make-backup-file-name file))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
286
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
287
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
288 ;;(defun find-backup-file-name (fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
289 ;; "Find a file name for a backup file, and suggestions for deletions.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
290 ;;Value is a list whose car is the name for the backup file
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
291 ;; and whose cdr is a list of old versions to consider deleting now.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
292 ;;If the value is nil, don't make a backup."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
293 ;; (let ((handler (find-file-name-handler fn 'find-backup-file-name)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
294 ;; ;; Run a handler for this function so that ange-ftp can refuse to do it.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
295 ;; (if handler
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
296 ;; (funcall handler 'find-backup-file-name fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
297 ;; (if (eq version-control 'never)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
298 ;; (list (make-backup-file-name fn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
299 ;; (let* ((base-versions (concat (file-name-nondirectory fn) ".~"))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
300 ;; ;; used by backup-extract-version:
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
301 ;; (bv-length (length base-versions))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
302 ;; possibilities
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
303 ;; (versions nil)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
304 ;; (high-water-mark 0)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
305 ;; (deserve-versions-p nil)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
306 ;; (number-to-delete 0))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
307 ;; (condition-case ()
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
308 ;; (setq possibilities (file-name-all-completions
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
309 ;; base-versions
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
310 ;; (file-name-directory fn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
311 ;; versions (sort (mapcar
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
312 ;; #'backup-extract-version
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
313 ;; possibilities)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
314 ;; '<)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
315 ;; high-water-mark (apply #'max 0 versions)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
316 ;; deserve-versions-p (or version-control
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
317 ;; (> high-water-mark 0))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
318 ;; number-to-delete (- (length versions)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
319 ;; kept-old-versions kept-new-versions -1))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
320 ;; (file-error
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
321 ;; (setq possibilities nil)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
322 ;; (if (not deserve-versions-p)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
323 ;; (list (make-backup-file-name fn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
324 ;; (cons (concat fn ".~" (int-to-string (1+ high-water-mark)) "~")
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
325 ;; (if (and (> number-to-delete 0)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
326 ;; ;; Delete nothing if there is overflow
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
327 ;; ;; in the number of versions to keep.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
328 ;; (>= (+ kept-new-versions kept-old-versions -1) 0))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
329 ;; (mapcar #'(lambda (n)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
330 ;; (concat fn ".~" (int-to-string n) "~"))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
331 ;; (let ((v (nthcdr kept-old-versions versions)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
332 ;; (rplacd (nthcdr (1- number-to-delete) v) ())
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
333 ;; v))))))))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
334
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
335 (defun find-backup-file-name (fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
336 "Find a file name for a backup file, and suggestions for deletions.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
337 Value is a list whose car is the name for the backup file
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
338 and whose cdr is a list of old versions to consider deleting now.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
339 If the value is nil, don't make a backup.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
340 *** Changed by \"backup-dir.el\""
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
341 (let ((handler (find-file-name-handler fn 'find-backup-file-name)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
342 ;; Run a handler for this function so that ange-ftp can refuse to do it.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
343 (if handler
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
344 (funcall handler 'find-backup-file-name fn)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
345 (if (eq version-control 'never)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
346 (list (make-backup-file-name fn))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
347 (let* ((dir-n-base (bkup-backup-directory-and-basename fn)) ;add
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
348 (non-num-bk-name (bkup-make-backup-file-name fn dir-n-base)) ;add
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
349 (bk-dir (car dir-n-base)) ;add
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
350 (bk-base (cdr dir-n-base)) ;add
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
351 (base-versions (concat bk-base ".~")) ;mod
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
352 ;; used by backup-extract-version:
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
353 (bv-length (length base-versions))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
354 possibilities
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
355 (versions nil)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
356 (high-water-mark 0)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
357 (deserve-versions-p nil)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
358 (number-to-delete 0))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
359 (condition-case ()
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
360 (setq possibilities (file-name-all-completions
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
361 base-versions
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
362 bk-dir) ;mod
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
363 versions (sort (mapcar
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
364 #'backup-extract-version
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
365 possibilities)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
366 '<)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
367 high-water-mark (apply #'max 0 versions)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
368 deserve-versions-p (or version-control
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
369 (> high-water-mark 0))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
370 number-to-delete (- (length versions)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
371 kept-old-versions kept-new-versions -1))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
372 (file-error
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
373 (setq possibilities nil)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
374 (if (not deserve-versions-p)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
375 (list (bkup-make-backup-file-name fn dir-n-base)) ;mod
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
376 (cons (concat bk-dir base-versions (int-to-string (1+ high-water-mark)) "~") ;mod
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
377 (if (and (> number-to-delete 0)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
378 ;; Delete nothing if there is overflow
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
379 ;; in the number of versions to keep.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
380 (>= (+ kept-new-versions kept-old-versions -1) 0))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
381 (mapcar #'(lambda (n)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
382 (concat bk-dir base-versions (int-to-string n) "~")) ;mod
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
383 (let ((v (nthcdr kept-old-versions versions)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
384 (rplacd (nthcdr (1- number-to-delete) v) ())
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
385 v))))))))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
386
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
387
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
388 ;;(defun file-newest-backup (filename)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
389 ;; "Return most recent backup file for FILENAME or nil if no backups exist."
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
390 ;; (let* ((filename (expand-file-name filename))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
391 ;; (file (file-name-nondirectory filename))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
392 ;; (dir (file-name-directory filename))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
393 ;; (comp (file-name-all-completions file dir))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
394 ;; newest tem)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
395 ;; (while comp
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
396 ;; (setq tem (car comp)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
397 ;; comp (cdr comp))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
398 ;; (cond ((and (backup-file-name-p tem)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
399 ;; (string= (file-name-sans-versions tem) file))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
400 ;; (setq tem (concat dir tem))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
401 ;; (if (or (null newest)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
402 ;; (file-newer-than-file-p tem newest))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
403 ;; (setq newest tem)))))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
404 ;; newest))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
405
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
406 (defun file-newest-backup (filename)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
407 "Return most recent backup file for FILENAME or nil if no backups exist.
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
408 *** Changed by \"backup-dir.el\""
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
409 (let ((comp (bkup-existing-backup-files filename))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
410 (newest nil)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
411 (file nil))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
412 (while comp
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
413 (setq file (car comp)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
414 comp (cdr comp))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
415 (if (and (backup-file-name-p file)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
416 (or (null newest) (file-newer-than-file-p file newest)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
417 (setq newest file)))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
418 newest))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
419
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
420
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
421 ;;; patch `latest-backup-file' from "dired"
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
422 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
423 ;;; we use `dired-load-hook' to avoid loading dired now. This speeds things up
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
424 ;;; considerably according to Thomas Feuster, feuster@tp4.physik.uni-giessen.de
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
425 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
426 ;;; one really wonders why there are 3 functions to do the same thing...
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
427 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
428 (defun bkup-patch-latest-backup-file ()
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
429 (fset 'latest-backup-file (symbol-function 'file-newest-backup))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
430 (remove-hook 'dired-load-hook 'bkup-patch-latest-backup-file))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
431
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
432 (if (featurep 'dired)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
433 ;; if loaded, patch it now
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
434 (fset 'latest-backup-file (symbol-function 'file-newest-backup))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
435 ;; otherwise do it later
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
436 (add-hook 'dired-load-hook 'bkup-patch-latest-backup-file))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
437
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
438
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
439 ;;; patch `diff-latest-backup-file' from "diff"
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
440 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
441 (require 'diff)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
442 (fset 'diff-latest-backup-file (symbol-function 'file-newest-backup))
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
443
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
444
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
445 ;;; finally, add to list of features
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
446 ;;;
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
447 (provide 'backup-dir)
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
448
bcdc7deadc19 Import from CVS: tag r19-15b7
cvs
parents:
diff changeset
449 ;;; backup-dir.el ends here