diff options
author | Dan Nicolaescu <dann@ics.uci.edu> | 2008-10-13 01:16:49 +0000 |
---|---|---|
committer | Dan Nicolaescu <dann@ics.uci.edu> | 2008-10-13 01:16:49 +0000 |
commit | 5870cb7682e7b70471d86b1b0b5724aa0fe18d74 (patch) | |
tree | ed1c973bd81a9ea79801b939cbb1bccd58572481 /lisp/vc-cvs.el | |
parent | dd4fdc44b1143f7959439eecb00d3a79c471a962 (diff) | |
download | emacs-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.el | 40 |
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) |