summaryrefslogtreecommitdiff
path: root/lisp/vc-cvs.el
diff options
context:
space:
mode:
authorDan Nicolaescu <dann@ics.uci.edu>2008-10-13 01:16:49 +0000
committerDan Nicolaescu <dann@ics.uci.edu>2008-10-13 01:16:49 +0000
commit5870cb7682e7b70471d86b1b0b5724aa0fe18d74 (patch)
treeed1c973bd81a9ea79801b939cbb1bccd58572481 /lisp/vc-cvs.el
parentdd4fdc44b1143f7959439eecb00d3a79c471a962 (diff)
downloademacs-5870cb7682e7b70471d86b1b0b5724aa0fe18d74.tar.gz
* vc-hooks.el (vc-stay-local): Add a new choice and default to it.
* vc-cvs.el (vc-cvs-dir-stay-local): Remove. (vc-cvs-stay-local): Add a new choice and default to it. (vc-cvs-dir-status): Use the new vc-stay-local choice. * vc-svn.el (vc-svn-dir-status): Use the new vc-stay-local choice.
Diffstat (limited to 'lisp/vc-cvs.el')
-rw-r--r--lisp/vc-cvs.el40
1 files changed, 19 insertions, 21 deletions
diff --git a/lisp/vc-cvs.el b/lisp/vc-cvs.el
index bd6e755d128..0d8cbb1e6fb 100644
--- a/lisp/vc-cvs.el
+++ b/lisp/vc-cvs.el
@@ -105,11 +105,15 @@ This is only meaningful if you don't use the implicit checkout model
:version "21.1"
:group 'vc)
-(defcustom vc-cvs-stay-local t
+(defcustom vc-cvs-stay-local 'only-file
"*Non-nil means use local operations when possible for remote repositories.
This avoids slow queries over the network and instead uses heuristics
and past information to determine the current status of a file.
+If value is the symbol `only-file' `vc-dir' will connect to the
+server, but heuristics will be used to determine the status for
+all other VC operations.
+
The value can also be a regular expression or list of regular
expressions to match against the host name of a repository; then VC
only stays local for hosts that match it. Alternatively, the value
@@ -117,19 +121,12 @@ can be a list of regular expressions where the first element is the
symbol `except'; then VC always stays local except for hosts matched
by these regular expressions."
:type '(choice (const :tag "Always stay local" t)
- (const :tag "Don't stay local" nil)
+ (const :tag "Only for file operations" 'only-file)
+ (const :tag "Don't stay local" nil)
(list :format "\nExamine hostname and %v" :tag "Examine hostname ..."
(set :format "%v" :inline t (const :format "%t" :tag "don't" except))
(regexp :format " stay local,\n%t: %v" :tag "if it matches")
(repeat :format "%v%i\n" :inline t (regexp :tag "or"))))
- :version "21.1"
- :group 'vc)
-
-(defcustom vc-cvs-dir-stay-local nil
- "*Non-nil means use local operations when possible for remote repositories.
-This avoids slow queries over the network and instead uses heuristics
-and past information to determine the current status of files for `vc-dir'."
- :type 'boolean
:version "23.1"
:group 'vc)
@@ -961,17 +958,18 @@ state."
(defun vc-cvs-dir-status (dir update-function)
"Create a list of conses (file . state) for DIR."
;; FIXME check all files in DIR instead?
- (if vc-cvs-dir-stay-local
- (vc-cvs-dir-status-heuristic dir update-function)
- (vc-cvs-command (current-buffer) 'async dir "-f" "status")
- ;; Alternative implementation: use the "update" command instead of
- ;; the "status" command.
- ;; (vc-cvs-command (current-buffer) 'async
- ;; (file-relative-name dir)
- ;; "-f" "-n" "update" "-d" "-P")
- (vc-exec-after
- `(vc-cvs-after-dir-status (quote ,update-function)))))
-
+ (let ((local (vc-stay-local-p dir)))
+ (if (and local (not (eq local 'only-file)))
+ (vc-cvs-dir-status-heuristic dir update-function)
+ (vc-cvs-command (current-buffer) 'async dir "-f" "status")
+ ;; Alternative implementation: use the "update" command instead of
+ ;; the "status" command.
+ ;; (vc-cvs-command (current-buffer) 'async
+ ;; (file-relative-name dir)
+ ;; "-f" "-n" "update" "-d" "-P")
+ (vc-exec-after
+ `(vc-cvs-after-dir-status (quote ,update-function))))))
+
(defun vc-cvs-dir-status-files (dir files default-state update-function)
"Create a list of conses (file . state) for DIR."
(apply 'vc-cvs-command (current-buffer) 'async dir "-f" "status" files)