comparison lisp/find-paths.el @ 308:33bdb3d4b97f r21-0b52

Import from CVS: tag r21-0b52
author cvs
date Mon, 13 Aug 2007 10:42:44 +0200
parents 70ad99077275
children 182f72e8cd0d
comparison
equal deleted inserted replaced
307:42d630fd9bd8 308:33bdb3d4b97f
60 (let ((path '())) 60 (let ((path '()))
61 (while directories 61 (while directories
62 (let ((directory (file-name-as-directory 62 (let ((directory (file-name-as-directory
63 (expand-file-name 63 (expand-file-name
64 (car directories))))) 64 (car directories)))))
65 (if (file-directory-p directory) 65 (if (paths-file-readable-directory-p directory)
66 (let ((raw-entries 66 (let ((raw-entries
67 (if (equal 0 max-depth) 67 (if (equal 0 max-depth)
68 '() 68 '()
69 (directory-files directory nil "^[^.-]"))) 69 (directory-files directory nil "^[^.-]")))
70 (reverse-dirs '())) 70 (reverse-dirs '()))
86 (list directory) 86 (list directory)
87 sub-path)))))) 87 sub-path))))))
88 (setq directories (cdr directories))) 88 (setq directories (cdr directories)))
89 path)) 89 path))
90 90
91 (defun paths-file-readable-directory-p (filename)
92 "Check if filename is a readable directory."
93 (and (file-directory-p filename)
94 (file-readable-p filename)))
95
91 (defun paths-find-recursive-load-path (directories &optional max-depth) 96 (defun paths-find-recursive-load-path (directories &optional max-depth)
92 "Construct a recursive load path underneath DIRECTORIES." 97 "Construct a recursive load path underneath DIRECTORIES."
93 (paths-find-recursive-path directories 98 (paths-find-recursive-path directories
94 max-depth paths-no-lisp-directory-regexp)) 99 max-depth paths-no-lisp-directory-regexp))
95 100
96 (defun paths-emacs-root-p (directory) 101 (defun paths-emacs-root-p (directory)
97 "Check if DIRECTORY is a plausible installation root for XEmacs." 102 "Check if DIRECTORY is a plausible installation root for XEmacs."
98 (or 103 (or
99 ;; installed 104 ;; installed
100 (file-directory-p (paths-construct-path (list directory 105 (paths-file-readable-directory-p (paths-construct-path (list directory
101 "lib" 106 "lib"
102 emacs-program-name))) 107 emacs-program-name)))
103 ;; in-place or windows-nt 108 ;; in-place or windows-nt
104 (and 109 (and
105 (file-directory-p (paths-construct-path (list directory "lisp"))) 110 (paths-file-readable-directory-p (paths-construct-path (list directory "lisp")))
106 (file-directory-p (paths-construct-path (list directory "etc")))))) 111 (paths-file-readable-directory-p (paths-construct-path (list directory "etc"))))))
107 112
108 (defun paths-chase-symlink (file-name) 113 (defun paths-chase-symlink (file-name)
109 "Chase a symlink until the bitter end." 114 "Chase a symlink until the bitter end."
110 (let ((maybe-symlink (file-symlink-p file-name))) 115 (let ((maybe-symlink (file-symlink-p file-name)))
111 (if maybe-symlink 116 (if maybe-symlink
166 If KEEP-SUFFIX is non-nil, the suffix must be respected in searching 171 If KEEP-SUFFIX is non-nil, the suffix must be respected in searching
167 the directory." 172 the directory."
168 (let ((preferred-value (or (and envvar (getenv envvar)) 173 (let ((preferred-value (or (and envvar (getenv envvar))
169 default))) 174 default)))
170 (if (and preferred-value 175 (if (and preferred-value
171 (file-directory-p preferred-value)) 176 (paths-file-readable-directory-p preferred-value))
172 (file-name-as-directory preferred-value) 177 (file-name-as-directory preferred-value)
173 (catch 'gotcha 178 (catch 'gotcha
174 (while roots 179 (while roots
175 (let* ((root (car roots)) 180 (let* ((root (car roots))
176 ;; installed 181 ;; installed
177 (path (paths-construct-emacs-directory root suffix base))) 182 (path (paths-construct-emacs-directory root suffix base)))
178 (if (file-directory-p path) 183 (if (paths-file-readable-directory-p path)
179 (throw 'gotcha path) 184 (throw 'gotcha path)
180 ;; in-place 185 ;; in-place
181 (if (null keep-suffix) 186 (if (null keep-suffix)
182 (let ((path (paths-construct-emacs-directory root "" base))) 187 (let ((path (paths-construct-emacs-directory root "" base)))
183 (if (file-directory-p path) 188 (if (paths-file-readable-directory-p path)
184 (throw 'gotcha path)))))) 189 (throw 'gotcha path))))))
185 (setq roots (cdr roots))) 190 (setq roots (cdr roots)))
186 nil)))) 191 nil))))
187 192
188 (defun paths-find-site-directory (roots base &optional envvar default) 193 (defun paths-find-site-directory (roots base &optional envvar default)
228 233
229 (defun paths-directories-which-exist (directories) 234 (defun paths-directories-which-exist (directories)
230 "Return the directories among DIRECTORIES." 235 "Return the directories among DIRECTORIES."
231 (let ((reverse-directories '())) 236 (let ((reverse-directories '()))
232 (while directories 237 (while directories
233 (if (file-directory-p (car directories)) 238 (if (paths-file-readable-directory-p (car directories))
234 (setq reverse-directories 239 (setq reverse-directories
235 (cons (car directories) 240 (cons (car directories)
236 reverse-directories))) 241 reverse-directories)))
237 (setq directories (cdr directories))) 242 (setq directories (cdr directories)))
238 (reverse reverse-directories))) 243 (reverse reverse-directories)))