annotate lisp/vc-dav.el @ 104389:03262c903016

(imenu-example--name-and-position): Fix obsolescence message.
author Glenn Morris <rgm@gnu.org>
date Fri, 21 Aug 2009 07:36:41 +0000
parents a9dc0e7c3f2b
children 1d1d5d9bd884
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
96198
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
1 ;;; vc-dav.el --- vc.el support for WebDAV
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
2
100908
a9dc0e7c3f2b Add 2009 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 96199
diff changeset
3 ;; Copyright (C) 2001, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
96198
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
4
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
5 ;; Author: Bill Perry <wmperry@gnu.org>
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
6 ;; Maintainer: Bill Perry <wmperry@gnu.org>
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
7 ;; Keywords: url, vc
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
8
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
9 ;; GNU Emacs is free software: you can redistribute it and/or modify
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
10 ;; it under the terms of the GNU General Public License as published by
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
11 ;; the Free Software Foundation, either version 3 of the License, or
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
12 ;; (at your option) any later version.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
13
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
14 ;; GNU Emacs is distributed in the hope that it will be useful,
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
15 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
16 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
17 ;; GNU General Public License for more details.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
18
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
19 ;; You should have received a copy of the GNU General Public License
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
20 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
21
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
22
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
23 ;;; Commentary:
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
24
96199
8322a8f8ab08 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96198
diff changeset
25 ;;; Todo:
8322a8f8ab08 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96198
diff changeset
26 ;;
8322a8f8ab08 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96198
diff changeset
27 ;; - Some methods need to be updated to match the current vc.el.
8322a8f8ab08 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96198
diff changeset
28 ;; - rename "version" -> "revision"
8322a8f8ab08 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96198
diff changeset
29 ;; - some methods need to take a fileset as a parameter instead of a
8322a8f8ab08 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96198
diff changeset
30 ;; single file.
8322a8f8ab08 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96198
diff changeset
31
96198
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
32 ;;; Code:
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
33
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
34 (require 'url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
35 (require 'url-dav)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
36
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
37 ;;; Required functions for a vc backend
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
38 (defun vc-dav-registered (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
39 "Return t if URL is registered with a DAV aware server."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
40 (url-dav-vc-registered url))
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
41
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
42 (defun vc-dav-state (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
43 "Return the current version control state of URL.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
44 For a list of possible values, see `vc-state'."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
45 ;; Things we can support for WebDAV
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
46 ;;
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
47 ;; up-to-date - use lockdiscovery
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
48 ;; edited - check for an active lock by us
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
49 ;; USER - use lockdiscovery + owner
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
50 ;;
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
51 ;; These don't make sense for WebDAV
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
52 ;; needs-patch
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
53 ;; needs-merge
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
54 ;; unlocked-changes
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
55 (let ((locks (url-dav-active-locks url)))
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
56 (cond
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
57 ((null locks) 'up-to-date)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
58 ((assoc url locks)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
59 ;; SOMEBODY has a lock... let's find out who.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
60 (setq locks (cdr (assoc url locks)))
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
61 (if (rassoc url-dav-lock-identifier locks)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
62 ;; _WE_ have a lock
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
63 'edited
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
64 (cdr (car locks)))))))
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
65
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
66 (defun vc-dav-checkout-model (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
67 "Indicate whether URL needs to be \"checked out\" before it can be edited.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
68 See `vc-checkout-model' for a list of possible values."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
69 ;; The only thing we can support with webdav is 'locking
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
70 'locking)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
71
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
72 ;; This should figure out the version # of the file somehow. What is
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
73 ;; the most appropriate property in WebDAV to look at for this?
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
74 (defun vc-dav-workfile-version (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
75 "Return the current workfile version of URL."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
76 "Unknown")
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
77
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
78 (defun vc-dav-register (url &optional rev comment)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
79 "Register URL in the DAV backend."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
80 ;; Do we need to do anything here? FIXME?
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
81 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
82
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
83 (defun vc-dav-checkin (url rev comment)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
84 "Commit changes in URL to WebDAV.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
85 If REV is non-nil, that should become the new revision number.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
86 COMMENT is used as a check-in comment."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
87 ;; This should PUT the resource and release any locks that we hold.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
88 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
89
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
90 (defun vc-dav-checkout (url &optional editable rev destfile)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
91 "Check out revision REV of URL into the working area.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
92
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
93 If EDITABLE is non-nil URL should be writable by the user and if
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
94 locking is used for URL, a lock should also be set.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
95
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
96 If REV is non-nil, that is the revision to check out. If REV is the
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
97 empty string, that means to check ou tht ehead of the trunk.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
98
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
99 If optional arg DESTFILE is given, it is an alternate filename to
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
100 write the contents to.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
101 "
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
102 ;; This should LOCK the resource.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
103 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
104
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
105 (defun vc-dav-revert (url &optional contents-done)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
106 "Revert URL back to the current workfile version.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
107
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
108 If optional arg CONTENTS-DONE is non-nil, then the contents of FILE
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
109 have already been reverted from a version backup, and this function
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
110 only needs to update the status of URL within the backend.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
111 "
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
112 ;; Should do a GET if !contents_done
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
113 ;; Should UNLOCK the file.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
114 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
115
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
116 (defun vc-dav-print-log (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
117 "Insert the revision log of URL into the *vc* buffer."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
118 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
119
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
120 (defun vc-dav-diff (url &optional rev1 rev2)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
121 "Insert the diff for URL into the *vc-diff* buffer.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
122 If REV1 and REV2 are non-nil report differences from REV1 to REV2.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
123 If REV1 is nil, use the current workfile version as the older version.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
124 If REV2 is nil, use the current workfile contents as the nwer version.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
125
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
126 It should return a status of either 0 (no differences found), or
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
127 1 (either non-empty diff or the diff is run asynchronously).
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
128 "
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
129 ;; We should do this asynchronously...
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
130 ;; How would we do it at all, that is the question!
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
131 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
132
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
133
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
134
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
135 ;;; Optional functions
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
136 ;; Should be faster than vc-dav-state - but how?
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
137 (defun vc-dav-state-heuristic (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
138 "Estimate the version control state of URL at visiting time."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
139 (vc-dav-state url))
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
140
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
141 ;; This should use url-dav-get-properties with a depth of `1' to get
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
142 ;; all the properties.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
143 (defun vc-dav-dir-state (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
144 "find the version control state of all files in DIR in a fast way."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
145 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
146
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
147 (defun vc-dav-workfile-unchanged-p (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
148 "Return non-nil if URL is unchanged from its current workfile version."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
149 ;; Probably impossible with webdav
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
150 )
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
151
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
152 (defun vc-dav-responsible-p (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
153 "Return non-nil if DAV considers itself `responsible' for URL."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
154 ;; Check for DAV support on the web server.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
155 t)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
156
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
157 (defun vc-dav-could-register (url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
158 "Return non-nil if URL could be registered under this backend."
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
159 ;; Check for DAV support on the web server.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
160 t)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
161
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
162 ;;; Unimplemented functions
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
163 ;;
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
164 ;; vc-dav-latest-on-branch-p(URL)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
165 ;; Return non-nil if the current workfile version of FILE is the
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
166 ;; latest on its branch. There are no branches in webdav yet.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
167 ;;
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
168 ;; vc-dav-mode-line-string(url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
169 ;; Return a dav-specific mode line string for URL. Are there any
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
170 ;; specific states that we want exposed?
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
171 ;;
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
172 ;; vc-dav-dired-state-info(url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
173 ;; Translate the `vc-state' property of URL into a string that can
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
174 ;; be used in a vc-dired buffer. Are there any extra states that
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
175 ;; we want exposed?
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
176 ;;
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
177 ;; vc-dav-receive-file(url rev)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
178 ;; Let this backend `receive' a file that is already registered
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
179 ;; under another backend. The default just calls `register', which
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
180 ;; should be sufficient for WebDAV.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
181 ;;
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
182 ;; vc-dav-unregister(url)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
183 ;; Unregister URL. Not possible with WebDAV, other than by
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
184 ;; deleting the resource.
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
185
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
186 (provide 'vc-dav)
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
187
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
188 ;; arch-tag: 0a0fb9fe-8190-4c0a-a179-5c291d3a467e
0c1619dd6a24 * vc-dav.el: Move here from url/vc-dav.el.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
189 ;;; vc-dav.el ends here