changeset 99531:bdd322f177a6

(project-settings-file): New variable. (project-find-settings-file): Use it, instead of hardcoding .dir.settings.el.
author Chong Yidong <cyd@stupidchicken.com>
date Thu, 13 Nov 2008 15:17:48 +0000
parents 0c311ab3d969
children a84ee30498a7
files lisp/files.el
diffstat 1 files changed, 23 insertions(+), 15 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/files.el	Thu Nov 13 15:17:28 2008 +0000
+++ b/lisp/files.el	Thu Nov 13 15:17:48 2008 +0000
@@ -3202,6 +3202,13 @@
 	(setcdr elt list)
       (push (cons class list) project-class-alist))))
 
+(defcustom project-settings-file ".dir-settings.el"
+  "Settings file for per-project settings. Set this to nil if you dont want  to load project-specific settings."
+  :type '(choice
+       (const  :tag "Ignore" nil)
+       (file :tag "File"))
+:group 'files)
+
 (defun project-find-settings-file (file)
   "Find the settings file for FILE.
 This searches upward in the directory tree.
@@ -3209,21 +3216,22 @@
 If the file is in a registered project, a cons from
 `project-directory-alist' is returned.
 Otherwise this returns nil."
-  (setq file (expand-file-name file))
-  (let* ((settings (locate-dominating-file file ".dir-settings.el"))
-         (pda nil))
-    ;; `locate-dominating-file' may have abbreviated the name.
-    (if settings (setq settings (expand-file-name ".dir-settings.el" settings)))
-    (dolist (x project-directory-alist)
-      (when (and (eq t (compare-strings file nil (length (car x))
-                                        (car x) nil nil))
-                 (> (length (car x)) (length (car pda))))
-        (setq pda x)))
-    (if (and settings pda)
-        (if (> (length (file-name-directory settings))
-               (length (car pda)))
-            settings pda)
-      (or settings pda))))
+  (when project-settings-file
+    (setq file (expand-file-name file))
+    (let* ((settings (locate-dominating-file file project-settings-file))
+	   (pda nil))
+      ;; `locate-dominating-file' may have abbreviated the name.
+      (if settings (setq settings (expand-file-name ".dir-settings.el" settings)))
+      (dolist (x project-directory-alist)
+	(when (and (eq t (compare-strings file nil (length (car x))
+					  (car x) nil nil))
+		   (> (length (car x)) (length (car pda))))
+	  (setq pda x)))
+      (if (and settings pda)
+	  (if (> (length (file-name-directory settings))
+		 (length (car pda)))
+	      settings pda)
+	(or settings pda)))))
 
 (defun project-define-from-project-file (settings-file)
   "Load a settings file and register a new project class and instance.