Mercurial > emacs
annotate lisp/vc/vc-bzr.el @ 111685:411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
* vc/vc.el (vc-merge): Remove optional arg PROMPT. Always prompt
for a merge location.
* vc/vc-bzr.el (vc-bzr-pull): Remove unused var.
(vc-bzr-merge-branch): Always prompt.
(vc-bzr-async-command): Use the full branch filename.
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Tue, 23 Nov 2010 10:13:43 -0500 |
parents | 33ed3cf8260b |
children | 4b2ef298966a |
rev | line source |
---|---|
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1 ;;; vc-bzr.el --- VC backend for the bzr revision control system |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
2 |
106815 | 3 ;; Copyright (C) 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
4 |
101078
5f4e85fd7c0a
Comments (minor fixes of some header conventions).
Glenn Morris <rgm@gnu.org>
parents:
100908
diff
changeset
|
5 ;; Author: Dave Love <fx@gnu.org> |
5f4e85fd7c0a
Comments (minor fixes of some header conventions).
Glenn Morris <rgm@gnu.org>
parents:
100908
diff
changeset
|
6 ;; Riccardo Murri <riccardo.murri@gmail.com> |
108971
d928a6a7c3f2
* lisp/finder.el (finder-known-keywords): Add keyword "vc"
Juri Linkov <juri@jurta.org>
parents:
108970
diff
changeset
|
7 ;; Keywords: vc tools |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
8 ;; Created: Sept 2006 |
110015
280c8ae2476d
Add "Package:" file headers to denote built-in packages.
Chong Yidong <cyd@stupidchicken.com>
parents:
108971
diff
changeset
|
9 ;; Version: 2008-01-04 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
10 ;; URL: http://launchpad.net/vc-bzr |
110015
280c8ae2476d
Add "Package:" file headers to denote built-in packages.
Chong Yidong <cyd@stupidchicken.com>
parents:
108971
diff
changeset
|
11 ;; Package: vc |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
12 |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
13 ;; This file is part of GNU Emacs. |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
14 |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
15 ;; GNU Emacs is free software: you can redistribute it and/or modify |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
16 ;; it under the terms of the GNU General Public License as published by |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
17 ;; the Free Software Foundation, either version 3 of the License, or |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
18 ;; (at your option) any later version. |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
19 |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
20 ;; GNU Emacs is distributed in the hope that it will be useful, |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
21 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
79695
f62e87c6eb20
2008-01-05 Sven Joachim <svenjoac@gmx.de>
Romain Francoise <romain@orebokech.com>
parents:
79688
diff
changeset
|
22 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
23 ;; GNU General Public License for more details. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
24 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
25 ;; You should have received a copy of the GNU General Public License |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
26 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
27 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
28 ;;; Commentary: |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
29 |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
30 ;; See <URL:http://bazaar-vcs.org/> concerning bzr. See |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
31 ;; <URL:http://launchpad.net/vc-bzr> for alternate development |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
32 ;; branches of `vc-bzr'. |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
33 |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
34 ;; Load this library to register bzr support in VC. |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
35 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
36 ;; Known bugs |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
37 ;; ========== |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
38 |
107175
6e6072f0c0a2
2010-02-17 Mark A. Hershberger <mah@everybody.org>
Mark A. Hershberger <mah@everybody.org>
parents:
107097
diff
changeset
|
39 ;; When editing a symlink and *both* the symlink and its target |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
40 ;; are bzr-versioned, `vc-bzr` presently runs `bzr status` on the |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
41 ;; symlink, thereby not detecting whether the actual contents |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94563
diff
changeset
|
42 ;; (that is, the target contents) are changed. |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
43 ;; See https://bugs.launchpad.net/vc-bzr/+bug/116607 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
44 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
45 ;; For an up-to-date list of bugs, please see: |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
46 ;; https://bugs.launchpad.net/vc-bzr/+bugs |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
47 |
94563
a0bb8ca25a33
Clean up vc*-revision-granularity and vc*-checkout-model.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
94539
diff
changeset
|
48 ;;; Properties of the backend |
a0bb8ca25a33
Clean up vc*-revision-granularity and vc*-checkout-model.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
94539
diff
changeset
|
49 |
a0bb8ca25a33
Clean up vc*-revision-granularity and vc*-checkout-model.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
94539
diff
changeset
|
50 (defun vc-bzr-revision-granularity () 'repository) |
a0bb8ca25a33
Clean up vc*-revision-granularity and vc*-checkout-model.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
94539
diff
changeset
|
51 (defun vc-bzr-checkout-model (files) 'implicit) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
52 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
53 ;;; Code: |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
54 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
55 (eval-when-compile |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
56 (require 'cl) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
57 (require 'vc) ;; for vc-exec-after |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
58 (require 'vc-dir)) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
59 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
60 ;; Clear up the cache to force vc-call to check again and discover |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
61 ;; new functions when we reload this file. |
78404
27f00e50116a
Change capitalization of VC backend names for new backends
Miles Bader <miles@gnu.org>
parents:
78387
diff
changeset
|
62 (put 'Bzr 'vc-functions nil) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
63 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
64 (defgroup vc-bzr nil |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
65 "VC bzr backend." |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
66 :version "22.2" |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
67 :group 'vc) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
68 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
69 (defcustom vc-bzr-program "bzr" |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
70 "Name of the bzr command (excluding any arguments)." |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
71 :group 'vc-bzr |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
72 :type 'string) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
73 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
74 (defcustom vc-bzr-diff-switches nil |
100178
6974583b6281
(vc-bzr-diff-switches): Doc fix. Add t as option.
Glenn Morris <rgm@gnu.org>
parents:
99388
diff
changeset
|
75 "String or list of strings specifying switches for bzr diff under VC. |
6974583b6281
(vc-bzr-diff-switches): Doc fix. Add t as option.
Glenn Morris <rgm@gnu.org>
parents:
99388
diff
changeset
|
76 If nil, use the value of `vc-diff-switches'. If t, use no switches." |
6974583b6281
(vc-bzr-diff-switches): Doc fix. Add t as option.
Glenn Morris <rgm@gnu.org>
parents:
99388
diff
changeset
|
77 :type '(choice (const :tag "Unspecified" nil) |
6974583b6281
(vc-bzr-diff-switches): Doc fix. Add t as option.
Glenn Morris <rgm@gnu.org>
parents:
99388
diff
changeset
|
78 (const :tag "None" t) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
79 (string :tag "Argument String") |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
80 (repeat :tag "Argument List" :value ("") string)) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
81 :group 'vc-bzr) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
82 |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
83 (defcustom vc-bzr-log-switches nil |
100178
6974583b6281
(vc-bzr-diff-switches): Doc fix. Add t as option.
Glenn Morris <rgm@gnu.org>
parents:
99388
diff
changeset
|
84 "String or list of strings specifying switches for bzr log under VC." |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
85 :type '(choice (const :tag "None" nil) |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
86 (string :tag "Argument String") |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
87 (repeat :tag "Argument List" :value ("") string)) |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
88 :group 'vc-bzr) |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
89 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
90 ;; since v0.9, bzr supports removing the progress indicators |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
91 ;; by setting environment variable BZR_PROGRESS_BAR to "none". |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
92 (defun vc-bzr-command (bzr-command buffer okstatus file-or-list &rest args) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
93 "Wrapper round `vc-do-command' using `vc-bzr-program' as COMMAND. |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
94 Invoke the bzr command adding `BZR_PROGRESS_BAR=none' and |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
95 `LC_MESSAGES=C' to the environment." |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
96 (let ((process-environment |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
97 (list* "BZR_PROGRESS_BAR=none" ; Suppress progress output (bzr >=0.9) |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
98 "LC_MESSAGES=C" ; Force English output |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
99 process-environment))) |
94847
5e64dca662f0
Remove assumption about what nil means as a first arument to vc-do-command.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
94729
diff
changeset
|
100 (apply 'vc-do-command (or buffer "*vc*") okstatus vc-bzr-program |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
101 file-or-list bzr-command args))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
102 |
81512
1214f1b9e278
(vc-bzr-dir-state): Use setq rather than set.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
81477
diff
changeset
|
103 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
104 ;;;###autoload |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
105 (defconst vc-bzr-admin-dirname ".bzr" |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
106 "Name of the directory containing Bzr repository status files.") |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
107 ;;;###autoload |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
108 (defconst vc-bzr-admin-checkout-format-file |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
109 (concat vc-bzr-admin-dirname "/checkout/format")) |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
110 (defconst vc-bzr-admin-dirstate |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
111 (concat vc-bzr-admin-dirname "/checkout/dirstate")) |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
112 (defconst vc-bzr-admin-branch-format-file |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
113 (concat vc-bzr-admin-dirname "/branch/format")) |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
114 (defconst vc-bzr-admin-revhistory |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
115 (concat vc-bzr-admin-dirname "/branch/revision-history")) |
78748
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
116 (defconst vc-bzr-admin-lastrev |
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
117 (concat vc-bzr-admin-dirname "/branch/last-revision")) |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
118 (defconst vc-bzr-admin-branchconf |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
119 (concat vc-bzr-admin-dirname "/branch/branch.conf")) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
120 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
121 ;;;###autoload (defun vc-bzr-registered (file) |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
122 ;;;###autoload (if (vc-find-root file vc-bzr-admin-checkout-format-file) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
123 ;;;###autoload (progn |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
124 ;;;###autoload (load "vc-bzr") |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
125 ;;;###autoload (vc-bzr-registered file)))) |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
126 |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
127 (defun vc-bzr-root (file) |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
128 "Return the root directory of the bzr repository containing FILE." |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
129 ;; Cache technique copied from vc-arch.el. |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
130 (or (vc-file-getprop file 'bzr-root) |
87574
21fcd219fd6e
* mouse.el (mouse-popup-menubar): Fix typo.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
87477
diff
changeset
|
131 (let ((root (vc-find-root file vc-bzr-admin-checkout-format-file))) |
21fcd219fd6e
* mouse.el (mouse-popup-menubar): Fix typo.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
87477
diff
changeset
|
132 (when root (vc-file-setprop file 'bzr-root root))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
133 |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
134 (defun vc-bzr--branch-conf (file) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
135 "Return the Bzr branch config for file FILE, as a string." |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
136 (with-temp-buffer |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
137 (insert-file-contents |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
138 (expand-file-name vc-bzr-admin-branchconf (vc-bzr-root file))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
139 (buffer-string))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
140 |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
141 (require 'sha1) ;For sha1-program |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
142 |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
143 (defun vc-bzr-sha1 (file) |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
144 (with-temp-buffer |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
145 (set-buffer-multibyte nil) |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
146 (let ((prog sha1-program) |
104595
cfc336042c1b
* vc-bzr.el (vc-bzr-sha1, vc-bzr-revision-completion-table):
Michael Albinus <michael.albinus@gmx.de>
parents:
104086
diff
changeset
|
147 (args nil) |
cfc336042c1b
* vc-bzr.el (vc-bzr-sha1, vc-bzr-revision-completion-table):
Michael Albinus <michael.albinus@gmx.de>
parents:
104086
diff
changeset
|
148 process-file-side-effects) |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
149 (when (consp prog) |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
150 (setq args (cdr prog)) |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
151 (setq prog (car prog))) |
94873
66788c63a40a
(vc-bzr-sha1, vc-bzr-command-discarding-stderr)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94847
diff
changeset
|
152 (apply 'process-file prog (file-relative-name file) t nil args) |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
153 (buffer-substring (point-min) (+ (point-min) 40))))) |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
154 |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
155 (defun vc-bzr-state-heuristic (file) |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
156 "Like `vc-bzr-state' but hopefully without running Bzr." |
103236
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
157 ;; `bzr status' was excrutiatingly slow with large histories and |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
158 ;; pending merges, so try to avoid using it until they fix their |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
159 ;; performance problems. |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
160 ;; This function tries first to parse Bzr internal file |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
161 ;; `checkout/dirstate', but it may fail if Bzr internal file format |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
162 ;; has changed. As a safeguard, the `checkout/dirstate' file is |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
163 ;; only parsed if it contains the string `#bazaar dirstate flat |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
164 ;; format 3' in the first line. |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
165 ;; If the `checkout/dirstate' file cannot be parsed, fall back to |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
166 ;; running `vc-bzr-state'." |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
167 (lexical-let ((root (vc-bzr-root file))) |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
168 (when root ; Short cut. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
169 ;; This looks at internal files. May break if they change |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
170 ;; their format. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
171 (lexical-let ((dirstate (expand-file-name vc-bzr-admin-dirstate root))) |
103236
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
172 (condition-case nil |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
173 (with-temp-buffer |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
174 (insert-file-contents dirstate) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
175 (goto-char (point-min)) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
176 (if (not (looking-at "#bazaar dirstate flat format 3")) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
177 (vc-bzr-state file) ; Some other unknown format? |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
178 (let* ((relfile (file-relative-name file root)) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
179 (reldir (file-name-directory relfile))) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
180 (if (re-search-forward |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
181 (concat "^\0" |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
182 (if reldir (regexp-quote |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
183 (directory-file-name reldir))) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
184 "\0" |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
185 (regexp-quote (file-name-nondirectory relfile)) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
186 "\0" |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
187 "[^\0]*\0" ;id? |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
188 "\\([^\0]*\\)\0" ;"a/f/d", a=removed? |
106723
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
189 "\\([^\0]*\\)\0" ;sha1 (empty if conflicted)? |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
190 "\\([^\0]*\\)\0" ;size?p |
103236
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
191 "[^\0]*\0" ;"y/n", executable? |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
192 "[^\0]*\0" ;? |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
193 "\\([^\0]*\\)\0" ;"a/f/d" a=added? |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
194 "\\([^\0]*\\)\0" ;sha1 again? |
106723
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
195 "\\([^\0]*\\)\0" ;size again? |
103236
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
196 "[^\0]*\0" ;"y/n", executable again? |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
197 "[^\0]*\0" ;last revid? |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
198 ;; There are more fields when merges are pending. |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
199 ) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
200 nil t) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
201 ;; Apparently the second sha1 is the one we want: when |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
202 ;; there's a conflict, the first sha1 is absent (and the |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
203 ;; first size seems to correspond to the file with |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
204 ;; conflict markers). |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
205 (cond |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
206 ((eq (char-after (match-beginning 1)) ?a) 'removed) |
106723
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
207 ((eq (char-after (match-beginning 4)) ?a) 'added) |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
208 ((or (and (eq (string-to-number (match-string 3)) |
103236
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
209 (nth 7 (file-attributes file))) |
106723
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
210 (equal (match-string 5) |
103236
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
211 (vc-bzr-sha1 file))) |
106723
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
212 (and |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
213 ;; It looks like for lightweight |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
214 ;; checkouts \2 is empty and we need to |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
215 ;; look for size in \6. |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
216 (eq (match-beginning 2) (match-end 2)) |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
217 (eq (string-to-number (match-string 6)) |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
218 (nth 7 (file-attributes file))) |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
219 (equal (match-string 5) |
82660e679622
(vc-bzr-state-heuristic): Make it work for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106677
diff
changeset
|
220 (vc-bzr-sha1 file)))) |
103236
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
221 'up-to-date) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
222 (t 'edited)) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
223 'unregistered)))) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
224 ;; Either the dirstate file can't be read, or the sha1 |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
225 ;; executable is missing, or ... |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
226 ;; In either case, recent versions of Bzr aren't that slow |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
227 ;; any more. |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
228 (error (vc-bzr-state file))))))) |
b4e12b7edf39
(vc-bzr-state-heuristic): Fallback on vc-bzr-state in case
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
102876
diff
changeset
|
229 |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
230 |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
231 (defun vc-bzr-registered (file) |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
232 "Return non-nil if FILE is registered with bzr." |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
233 (let ((state (vc-bzr-state-heuristic file))) |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
234 (not (memq state '(nil unregistered ignored))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
235 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
236 (defconst vc-bzr-state-words |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
237 "added\\|ignored\\|kind changed\\|modified\\|removed\\|renamed\\|unknown" |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
238 "Regexp matching file status words as reported in `bzr' output.") |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
239 |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
240 ;; History of Bzr commands. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
241 (defvar vc-bzr-history nil) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
242 |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
243 (defun vc-bzr-file-name-relative (filename) |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
244 "Return file name FILENAME stripped of the initial Bzr repository path." |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
245 (lexical-let* |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
246 ((filename* (expand-file-name filename)) |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
247 (rootdir (vc-bzr-root filename*))) |
96002
26f719e36c03
(log-view-per-file-logs): Pacify byte compiler.
Juanma Barranquero <lekktu@gmail.com>
parents:
95966
diff
changeset
|
248 (when rootdir |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
249 (file-relative-name filename* rootdir)))) |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
250 |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
251 (defun vc-bzr-async-command (command args) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
252 "Run Bzr COMMAND asynchronously with ARGS, displaying the result. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
253 Send the output to a buffer named \"*vc-bzr : NAME*\", where NAME |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
254 is the root of the current Bzr branch. Display the buffer in |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
255 some window, but don't select it." |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
256 ;; TODO: set up hyperlinks. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
257 (let* ((dir default-directory) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
258 (root (vc-bzr-root default-directory)) |
111685
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
259 (buffer (get-buffer-create |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
260 (format "*vc-bzr : %s*" |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
261 (expand-file-name root))))) |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
262 (with-current-buffer buffer |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
263 (setq default-directory root) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
264 (goto-char (point-max)) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
265 (unless (eq (point) (point-min)) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
266 (insert "\n")) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
267 (insert "Running \"" vc-bzr-program " " command) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
268 (dolist (arg args) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
269 (insert " " arg)) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
270 (insert "\"...\n") |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
271 ;; Run bzr in the original working directory. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
272 (let ((default-directory dir)) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
273 (apply 'vc-bzr-command command t 'async nil args))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
274 (display-buffer buffer))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
275 |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
276 (defun vc-bzr-pull (prompt) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
277 "Pull changes into the current Bzr branch. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
278 Normally, this runs \"bzr pull\". However, if the branch is a |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
279 bound branch, run \"bzr update\" instead. If there is no default |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
280 location from which to pull or update, or if PROMPT is non-nil, |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
281 prompt for the Bzr command to run." |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
282 (let* ((vc-bzr-program vc-bzr-program) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
283 (branch-conf (vc-bzr--branch-conf default-directory)) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
284 ;; Check whether the branch is bound. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
285 (bound (string-match "^bound\\s-*=\\s-*True" branch-conf)) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
286 ;; If we need to do a "bzr pull", check for a parent. If it |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
287 ;; does not exist, bzr will need a pull location. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
288 (parent (unless bound |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
289 (string-match |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
290 "^parent_location\\s-*=\\s-*[^\n[:space:]]+" |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
291 branch-conf))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
292 (command (if bound "update" "pull")) |
111685
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
293 args) |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
294 ;; If necessary, prompt for the exact command. |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
295 (when (or prompt (not (or bound parent))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
296 (setq args (split-string |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
297 (read-shell-command |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
298 "Run Bzr (like this): " |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
299 (concat vc-bzr-program " " command) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
300 'vc-bzr-history) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
301 " " t)) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
302 (setq vc-bzr-program (car args) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
303 command (cadr args) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
304 args (cddr args))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
305 (vc-bzr-async-command command args))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
306 |
111685
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
307 (defun vc-bzr-merge-branch () |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
308 "Merge another Bzr branch into the current one. |
111685
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
309 Prompt for the Bzr command to run, providing a pre-defined merge |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
310 source (an upstream branch or a previous merge source) as a |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
311 default if it is available." |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
312 (let* ((branch-conf (vc-bzr--branch-conf default-directory)) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
313 ;; "bzr merge" without an argument defaults to submit_branch, |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
314 ;; then parent_location. We extract the specific location |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
315 ;; and add it explicitly to the command line. |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
316 (location |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
317 (cond |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
318 ((string-match |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
319 "^submit_branch\\s-*=\\s-*\\(?:file://\\)?\\([^\n[:space:]]+\\)$" |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
320 branch-conf) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
321 (match-string 1 branch-conf)) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
322 ((string-match |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
323 "^parent_location\\s-*=\\s-*\\(?:file://\\)?\\([^\n[:space:]]+\\)$" |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
324 branch-conf) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
325 (match-string 1 branch-conf)))) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
326 (cmd |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
327 (split-string |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
328 (read-shell-command |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
329 "Run Bzr (like this): " |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
330 (concat vc-bzr-program " merge --pull" |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
331 (if location (concat " " location) "")) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
332 'vc-bzr-history) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
333 " " t)) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
334 (vc-bzr-program (car cmd)) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
335 (command (cadr cmd)) |
411dce7ee068
Always issue a full prompt in vc-merge-branch operation.
Chong Yidong <cyd@stupidchicken.com>
parents:
111679
diff
changeset
|
336 (args (cddr cmd))) |
111679
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
337 (vc-bzr-async-command command args))) |
33ed3cf8260b
Initial support for unified DVCS pull and merge.
Chong Yidong <cyd@stupidchicken.com>
parents:
110015
diff
changeset
|
338 |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
339 (defun vc-bzr-status (file) |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
340 "Return FILE status according to Bzr. |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
341 Return value is a cons (STATUS . WARNING), where WARNING is a |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
342 string or nil, and STATUS is one of the symbols: `added', |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
343 `ignored', `kindchanged', `modified', `removed', `renamed', `unknown', |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
344 which directly correspond to `bzr status' output, or 'unchanged |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
345 for files whose copy in the working tree is identical to the one |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
346 in the branch repository, or nil for files that are not |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
347 registered with Bzr. |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
348 |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
349 If any error occurred in running `bzr status', then return nil." |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
350 (with-temp-buffer |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
351 (let ((ret (condition-case nil |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
352 (vc-bzr-command "status" t 0 file) |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
353 (file-error nil))) ; vc-bzr-program not found. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
354 (status 'unchanged)) |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
355 ;; the only secure status indication in `bzr status' output |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
356 ;; is a couple of lines following the pattern:: |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
357 ;; | <status>: |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
358 ;; | <file name> |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
359 ;; if the file is up-to-date, we get no status report from `bzr', |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
360 ;; so if the regexp search for the above pattern fails, we consider |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
361 ;; the file to be up-to-date. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
362 (goto-char (point-min)) |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
363 (when (re-search-forward |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
364 ;; bzr prints paths relative to the repository root. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
365 (concat "^\\(" vc-bzr-state-words "\\):[ \t\n]+" |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
366 (regexp-quote (vc-bzr-file-name-relative file)) |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
367 ;; Bzr appends a '/' to directory names and |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
368 ;; '*' to executable files |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
369 (if (file-directory-p file) "/?" "\\*?") |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
370 "[ \t\n]*$") |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
371 nil t) |
78748
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
372 (lexical-let ((statusword (match-string 1))) |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
373 ;; Erase the status text that matched. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
374 (delete-region (match-beginning 0) (match-end 0)) |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
375 (setq status |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
376 (intern (replace-regexp-in-string " " "" statusword))))) |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
377 (when status |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
378 (goto-char (point-min)) |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
379 (skip-chars-forward " \n\t") ;Throw away spaces. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
380 (cons status |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
381 ;; "bzr" will output warnings and informational messages to |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
382 ;; stderr; due to Emacs' `vc-do-command' (and, it seems, |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
383 ;; `start-process' itself) limitations, we cannot catch stderr |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
384 ;; and stdout into different buffers. So, if there's anything |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
385 ;; left in the buffer after removing the above status |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
386 ;; keywords, let us just presume that any other message from |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
387 ;; "bzr" is a user warning, and display it. |
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
388 (unless (eobp) (buffer-substring (point) (point-max)))))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
389 |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
390 (defun vc-bzr-state (file) |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
391 (lexical-let ((result (vc-bzr-status file))) |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
392 (when (consp result) |
93671
2b3d42806dcc
(vc-bzr-state): Use when instead of if.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93602
diff
changeset
|
393 (when (cdr result) |
2b3d42806dcc
(vc-bzr-state): Use when instead of if.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93602
diff
changeset
|
394 (message "Warnings in `bzr' output: %s" (cdr result))) |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
395 (cdr (assq (car result) |
93118
01d3fd1a2cfe
* vc-hg.el (vc-hg-state):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93039
diff
changeset
|
396 '((added . added) |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
397 (kindchanged . edited) |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
398 (renamed . edited) |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
399 (modified . edited) |
93164
849abb573acb
(vc-bzr-state): Return 'removed for removed files and
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93118
diff
changeset
|
400 (removed . removed) |
94521
2a61c5f918a5
Change 'needs-patch to 'needs-update.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
94481
diff
changeset
|
401 (ignored . ignored) |
93164
849abb573acb
(vc-bzr-state): Return 'removed for removed files and
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93118
diff
changeset
|
402 (unknown . unregistered) |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
403 (unchanged . up-to-date))))))) |
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
404 |
92537
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
405 (defun vc-bzr-resolve-when-done () |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
406 "Call \"bzr resolve\" if the conflict markers have been removed." |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
407 (save-excursion |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
408 (goto-char (point-min)) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
409 (unless (re-search-forward "^<<<<<<< " nil t) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
410 (vc-bzr-command "resolve" nil 0 buffer-file-name) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
411 ;; Remove the hook so that it is not called multiple times. |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
412 (remove-hook 'after-save-hook 'vc-bzr-resolve-when-done t)))) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
413 |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
414 (defun vc-bzr-find-file-hook () |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
415 (when (and buffer-file-name |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
416 ;; FIXME: We should check that "bzr status" says "conflict". |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
417 (file-exists-p (concat buffer-file-name ".BASE")) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
418 (file-exists-p (concat buffer-file-name ".OTHER")) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
419 (file-exists-p (concat buffer-file-name ".THIS")) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
420 ;; If "bzr status" says there's a conflict but there are no |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
421 ;; conflict markers, it's not clear what we should do. |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
422 (save-excursion |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
423 (goto-char (point-min)) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
424 (re-search-forward "^<<<<<<< " nil t))) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
425 ;; TODO: the merge algorithm used in `bzr merge' is nicely configurable, |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
426 ;; but the one in `bzr pull' isn't, so it would be good to provide an |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
427 ;; elisp function to remerge from the .BASE/OTHER/THIS files. |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
428 (smerge-start-session) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
429 (add-hook 'after-save-hook 'vc-bzr-resolve-when-done nil t) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
430 (message "There are unresolved conflicts in this file"))) |
7071cfe2789e
(vc-bzr-resolve-when-done, vc-bzr-find-file-hook): New functions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92122
diff
changeset
|
431 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
432 (defun vc-bzr-workfile-unchanged-p (file) |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
433 (eq 'unchanged (car (vc-bzr-status file)))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
434 |
85139
8ba0e30716a5
Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85114
diff
changeset
|
435 (defun vc-bzr-working-revision (file) |
93363
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
436 ;; Together with the code in vc-state-heuristic, this makes it possible |
9e7b1b11aa5c
(vc-bzr-sha1): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93180
diff
changeset
|
437 ;; to get the initial VC state of a Bzr file even if Bzr is not installed. |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
438 (lexical-let* |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
439 ((rootdir (vc-bzr-root file)) |
78748
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
440 (branch-format-file (expand-file-name vc-bzr-admin-branch-format-file |
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
441 rootdir)) |
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
442 (revhistory-file (expand-file-name vc-bzr-admin-revhistory rootdir)) |
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
443 (lastrev-file (expand-file-name vc-bzr-admin-lastrev rootdir))) |
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
444 ;; This looks at internal files to avoid forking a bzr process. |
0b7bd1d9ffbf
(vc-bzr-admin-lastrev): New constant.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78564
diff
changeset
|
445 ;; May break if they change their format. |
102704
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
446 (if (and (file-exists-p branch-format-file) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
447 ;; For lightweight checkouts (obtained with bzr checkout --lightweight) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
448 ;; the branch-format-file does not contain the revision |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
449 ;; information, we need to look up the branch-format-file |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
450 ;; in the place where the lightweight checkout comes |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
451 ;; from. We only do that if it's a local file. |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
452 (let ((location-fname (expand-file-name |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
453 (concat vc-bzr-admin-dirname |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
454 "/branch/location") rootdir))) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
455 ;; The existence of this file is how we distinguish |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
456 ;; lightweight checkouts. |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
457 (if (file-exists-p location-fname) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
458 (with-temp-buffer |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
459 (insert-file-contents location-fname) |
106742
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
460 ;; If the lightweight checkout points to a |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
461 ;; location in the local file system, then we can |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
462 ;; look there for the version information. |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
463 (when (re-search-forward "file://\\(.+\\)" nil t) |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
464 (let ((l-c-parent-dir (match-string 1))) |
106778
95040dd9104b
Fix bug#5345: password asked when visiting files on a lightweight checkout.
Juanma Barranquero <lekktu@gmail.com>
parents:
106751
diff
changeset
|
465 (when (and (memq system-type '(ms-dos windows-nt)) |
95040dd9104b
Fix bug#5345: password asked when visiting files on a lightweight checkout.
Juanma Barranquero <lekktu@gmail.com>
parents:
106751
diff
changeset
|
466 (string-match-p "^/[[:alpha:]]:" l-c-parent-dir)) |
106819
328951014a28
Fix comment for bug#5345.
Juanma Barranquero <lekktu@gmail.com>
parents:
106815
diff
changeset
|
467 ;;; The non-Windows code takes a shortcut by using the host/path |
328951014a28
Fix comment for bug#5345.
Juanma Barranquero <lekktu@gmail.com>
parents:
106815
diff
changeset
|
468 ;;; separator slash as the start of the absolute path. That |
328951014a28
Fix comment for bug#5345.
Juanma Barranquero <lekktu@gmail.com>
parents:
106815
diff
changeset
|
469 ;;; does not work on Windows, so we must remove it (bug#5345) |
106778
95040dd9104b
Fix bug#5345: password asked when visiting files on a lightweight checkout.
Juanma Barranquero <lekktu@gmail.com>
parents:
106751
diff
changeset
|
470 (setq l-c-parent-dir (substring l-c-parent-dir 1))) |
106742
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
471 (setq branch-format-file |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
472 (expand-file-name vc-bzr-admin-branch-format-file |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
473 l-c-parent-dir)) |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
474 (setq lastrev-file |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
475 (expand-file-name vc-bzr-admin-lastrev l-c-parent-dir)) |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
476 ;; FIXME: maybe it's overkill to check if both these files exist. |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
477 (and (file-exists-p branch-format-file) |
debedd261607
(vc-bzr-working-revision): Fix looking for a revision
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106732
diff
changeset
|
478 (file-exists-p lastrev-file))))) |
102704
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
479 t))) |
78564
8f9613d80af0
Don't fiddle with vc-handled-backend.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78521
diff
changeset
|
480 (with-temp-buffer |
96002
26f719e36c03
(log-view-per-file-logs): Pacify byte compiler.
Juanma Barranquero <lekktu@gmail.com>
parents:
95966
diff
changeset
|
481 (insert-file-contents branch-format-file) |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
482 (goto-char (point-min)) |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
483 (cond |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
484 ((or |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
485 (looking-at "Bazaar-NG branch, format 0.0.4") |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
486 (looking-at "Bazaar-NG branch format 5")) |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
487 ;; count lines in .bzr/branch/revision-history |
96002
26f719e36c03
(log-view-per-file-logs): Pacify byte compiler.
Juanma Barranquero <lekktu@gmail.com>
parents:
95966
diff
changeset
|
488 (insert-file-contents revhistory-file) |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
489 (number-to-string (count-lines (line-end-position) (point-max)))) |
101790
e98ddfaefcae
(vc-bzr-working-revision): Recognize a newer branch
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101078
diff
changeset
|
490 ((or |
e98ddfaefcae
(vc-bzr-working-revision): Recognize a newer branch
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101078
diff
changeset
|
491 (looking-at "Bazaar Branch Format 6 (bzr 0.15)") |
e98ddfaefcae
(vc-bzr-working-revision): Recognize a newer branch
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101078
diff
changeset
|
492 (looking-at "Bazaar Branch Format 7 (needs bzr 1.6)")) |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
493 ;; revno is the first number in .bzr/branch/last-revision |
96002
26f719e36c03
(log-view-per-file-logs): Pacify byte compiler.
Juanma Barranquero <lekktu@gmail.com>
parents:
95966
diff
changeset
|
494 (insert-file-contents lastrev-file) |
101790
e98ddfaefcae
(vc-bzr-working-revision): Recognize a newer branch
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101078
diff
changeset
|
495 (when (re-search-forward "[0-9]+" nil t) |
e98ddfaefcae
(vc-bzr-working-revision): Recognize a newer branch
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101078
diff
changeset
|
496 (buffer-substring (match-beginning 0) (match-end 0)))))) |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
497 ;; fallback to calling "bzr revno" |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
498 (lexical-let* |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
499 ((result (vc-bzr-command-discarding-stderr |
94873
66788c63a40a
(vc-bzr-sha1, vc-bzr-command-discarding-stderr)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94847
diff
changeset
|
500 vc-bzr-program "revno" (file-relative-name file))) |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
501 (exitcode (car result)) |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
502 (output (cdr result))) |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
503 (cond |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
504 ((eq exitcode 0) (substring output 0 -1)) |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
505 (t nil)))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
506 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
507 (defun vc-bzr-create-repo () |
78404
27f00e50116a
Change capitalization of VC backend names for new backends
Miles Bader <miles@gnu.org>
parents:
78387
diff
changeset
|
508 "Create a new Bzr repository." |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
509 (vc-bzr-command "init" nil 0 nil)) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
510 |
92122
74bf6df13b6c
* vc.el (vc-find-revision): Make vc-parent-buffer local before
Dan Nicolaescu <dann@ics.uci.edu>
parents:
87649
diff
changeset
|
511 (defun vc-bzr-init-revision (&optional file) |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
512 "Always return nil, as Bzr cannot register explicit versions." |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
513 nil) |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
514 |
93602
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
515 (defun vc-bzr-previous-revision (file rev) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
516 (if (string-match "\\`[0-9]+\\'" rev) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
517 (number-to-string (1- (string-to-number rev))) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
518 (concat "before:" rev))) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
519 |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
520 (defun vc-bzr-next-revision (file rev) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
521 (if (string-match "\\`[0-9]+\\'" rev) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
522 (number-to-string (1+ (string-to-number rev))) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
523 (error "Don't know how to compute the next revision of %s" rev))) |
702b99dd7604
(vc-bzr-previous-revision, vc-bzr-next-revision): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93563
diff
changeset
|
524 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
525 (defun vc-bzr-register (files &optional rev comment) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
526 "Register FILE under bzr. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
527 Signal an error unless REV is nil. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
528 COMMENT is ignored." |
85141
b16f7408cd3f
Carry through today's big terminology change to a few places where I
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85139
diff
changeset
|
529 (if rev (error "Can't register explicit revision with bzr")) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
530 (vc-bzr-command "add" nil 0 files)) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
531 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
532 ;; Could run `bzr status' in the directory and see if it succeeds, but |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
533 ;; that's relatively expensive. |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
534 (defalias 'vc-bzr-responsible-p 'vc-bzr-root |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
535 "Return non-nil if FILE is (potentially) controlled by bzr. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
536 The criterion is that there is a `.bzr' directory in the same |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
537 or a superior directory.") |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
538 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
539 (defun vc-bzr-could-register (file) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
540 "Return non-nil if FILE could be registered under bzr." |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
541 (and (vc-bzr-responsible-p file) ; shortcut |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
542 (condition-case () |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
543 (with-temp-buffer |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
544 (vc-bzr-command "add" t 0 file "--dry-run") |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
545 ;; The command succeeds with no output if file is |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
546 ;; registered (in bzr 0.8). |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
547 (goto-char (point-min)) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
548 (looking-at "added ")) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
549 (error)))) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
550 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
551 (defun vc-bzr-unregister (file) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
552 "Unregister FILE from bzr." |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
553 (vc-bzr-command "remove" nil 0 file "--keep")) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
554 |
108009
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
555 (declare-function log-edit-extract-headers "log-edit" (headers string)) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
556 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
557 (defun vc-bzr-checkin (files rev comment) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
558 "Check FILE in to bzr with log message COMMENT. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
559 REV non-nil gets an error." |
85141
b16f7408cd3f
Carry through today's big terminology change to a few places where I
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85139
diff
changeset
|
560 (if rev (error "Can't check in a specific revision with bzr")) |
108010
4ae75c6f19d6
vc-bzr.el (vc-bzr-checkin): Undo spurious `async' arg change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108009
diff
changeset
|
561 (apply 'vc-bzr-command "commit" nil 0 |
108009
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
562 files (cons "-m" (log-edit-extract-headers '(("Author" . "--author") |
108913
c05344a913c8
Improve support for special markup in the VC commit message.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
108840
diff
changeset
|
563 ("Date" . "--commit-time") |
108009
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
564 ("Fixes" . "--fixes")) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
565 comment)))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
566 |
97401
58215ab2e8e6
(vc-bzr-find-revision): Rename from
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96539
diff
changeset
|
567 (defun vc-bzr-find-revision (file rev buffer) |
58215ab2e8e6
(vc-bzr-find-revision): Rename from
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96539
diff
changeset
|
568 "Fetch revision REV of file FILE and put it into BUFFER." |
79688
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
569 (with-current-buffer buffer |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
570 (if (and rev (stringp rev) (not (string= rev ""))) |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
571 (vc-bzr-command "cat" t 0 file "-r" rev) |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
572 (vc-bzr-command "cat" t 0 file)))) |
f82034083629
Copyright and version headers update.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78748
diff
changeset
|
573 |
93563
c505d070db06
(vc-bzr-checkout): Simplify.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93461
diff
changeset
|
574 (defun vc-bzr-checkout (file &optional editable rev) |
c505d070db06
(vc-bzr-checkout): Simplify.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93461
diff
changeset
|
575 (if rev (error "Operation not supported") |
c505d070db06
(vc-bzr-checkout): Simplify.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93461
diff
changeset
|
576 ;; Else, there's nothing to do. |
c505d070db06
(vc-bzr-checkout): Simplify.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93461
diff
changeset
|
577 nil)) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
578 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
579 (defun vc-bzr-revert (file &optional contents-done) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
580 (unless contents-done |
78521
98c39e79e082
(vc-bzr-registered): Use \0 instead of literal NULs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78435
diff
changeset
|
581 (with-temp-buffer (vc-bzr-command "revert" t 0 file)))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
582 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
583 (defvar log-view-message-re) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
584 (defvar log-view-file-re) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
585 (defvar log-view-font-lock-keywords) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
586 (defvar log-view-current-tag-function) |
96002
26f719e36c03
(log-view-per-file-logs): Pacify byte compiler.
Juanma Barranquero <lekktu@gmail.com>
parents:
95966
diff
changeset
|
587 (defvar log-view-per-file-logs) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
588 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
589 (define-derived-mode vc-bzr-log-view-mode log-view-mode "Bzr-Log-View" |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
590 (remove-hook 'log-view-mode-hook 'vc-bzr-log-view-mode) ;Deactivate the hack. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
591 (require 'add-log) |
95966
054335cbee3d
* log-view.el (log-view-diff-changeset): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
95232
diff
changeset
|
592 (set (make-local-variable 'log-view-per-file-logs) nil) |
104086
1bce2f053aeb
(vc-bzr-print-log): Pass multiple arguments to bzr log.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
103236
diff
changeset
|
593 (set (make-local-variable 'log-view-file-re) "\\`a\\`") |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
594 (set (make-local-variable 'log-view-message-re) |
107795
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
595 (if (eq vc-log-view-type 'short) |
106985
e9c454218ac8
(vc-bzr-print-log): Use the more compact --line option
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106982
diff
changeset
|
596 "^ *\\([0-9.]+\\): \\(.*?\\)[ \t]+\\([0-9]\\{4\\}-[0-9]\\{2\\}-[0-9]\\{2\\}\\)\\( \\[merge\\]\\)?" |
105010
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
597 "^ *\\(?:revno: \\([0-9.]+\\)\\|merged: .+\\)")) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
598 (set (make-local-variable 'log-view-font-lock-keywords) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
599 ;; log-view-font-lock-keywords is careful to use the buffer-local |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
600 ;; value of log-view-message-re only since Emacs-23. |
107795
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
601 (if (eq vc-log-view-type 'short) |
105010
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
602 (append `((,log-view-message-re |
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
603 (1 'log-view-message-face) |
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
604 (2 'change-log-name) |
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
605 (3 'change-log-date) |
106506
c43a4817b264
Fix short log parsing and fontification.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106476
diff
changeset
|
606 (4 'change-log-list nil lax)))) |
105010
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
607 (append `((,log-view-message-re . 'log-view-message-face)) |
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
608 ;; log-view-font-lock-keywords |
106724
37a9363510b2
(vc-bzr-log-view-mode): Also highlight the author.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106723
diff
changeset
|
609 '(("^ *\\(?:committer\\|author\\): \ |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
610 \\([^<(]+?\\)[ ]*[(<]\\([[:alnum:]_.+-]+@[[:alnum:]_.-]+\\)[>)]" |
105010
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
611 (1 'change-log-name) |
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
612 (2 'change-log-email)) |
b3c2589ed19e
* vc.el (top): print-log method now takes an optional SHORTLOG
Dan Nicolaescu <dann@ics.uci.edu>
parents:
104618
diff
changeset
|
613 ("^ *timestamp: \\(.*\\)" (1 'change-log-date-face))))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
614 |
106472
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
615 (defun vc-bzr-print-log (files buffer &optional shortlog start-revision limit) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
616 "Get bzr change log for FILES into specified BUFFER." |
80343
3c75e19e7ec9
(vc-bzr-print-log): Insert a file marker. Run the log
Dan Nicolaescu <dann@ics.uci.edu>
parents:
80340
diff
changeset
|
617 ;; `vc-do-command' creates the buffer, but we need it before running |
3c75e19e7ec9
(vc-bzr-print-log): Insert a file marker. Run the log
Dan Nicolaescu <dann@ics.uci.edu>
parents:
80340
diff
changeset
|
618 ;; the command. |
3c75e19e7ec9
(vc-bzr-print-log): Insert a file marker. Run the log
Dan Nicolaescu <dann@ics.uci.edu>
parents:
80340
diff
changeset
|
619 (vc-setup-buffer buffer) |
3c75e19e7ec9
(vc-bzr-print-log): Insert a file marker. Run the log
Dan Nicolaescu <dann@ics.uci.edu>
parents:
80340
diff
changeset
|
620 ;; If the buffer exists from a previous invocation it might be |
3c75e19e7ec9
(vc-bzr-print-log): Insert a file marker. Run the log
Dan Nicolaescu <dann@ics.uci.edu>
parents:
80340
diff
changeset
|
621 ;; read-only. |
93563
c505d070db06
(vc-bzr-checkout): Simplify.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93461
diff
changeset
|
622 ;; FIXME: `vc-bzr-command' runs `bzr log' with `LC_MESSAGES=C', so |
c505d070db06
(vc-bzr-checkout): Simplify.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93461
diff
changeset
|
623 ;; the log display may not what the user wants - but I see no other |
c505d070db06
(vc-bzr-checkout): Simplify.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93461
diff
changeset
|
624 ;; way of getting the above regexps working. |
104086
1bce2f053aeb
(vc-bzr-print-log): Pass multiple arguments to bzr log.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
103236
diff
changeset
|
625 (with-current-buffer buffer |
1bce2f053aeb
(vc-bzr-print-log): Pass multiple arguments to bzr log.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
103236
diff
changeset
|
626 (apply 'vc-bzr-command "log" buffer 'async files |
106386
d1166d927ca2
(vc-bzr-print-log): Deal with nil arguments better.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106269
diff
changeset
|
627 (append |
106985
e9c454218ac8
(vc-bzr-print-log): Use the more compact --line option
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106982
diff
changeset
|
628 (when shortlog '("--line")) |
106472
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
629 (when start-revision (list (format "-r..%s" start-revision))) |
106386
d1166d927ca2
(vc-bzr-print-log): Deal with nil arguments better.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106269
diff
changeset
|
630 (when limit (list "-l" (format "%s" limit))) |
d1166d927ca2
(vc-bzr-print-log): Deal with nil arguments better.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106269
diff
changeset
|
631 (if (stringp vc-bzr-log-switches) |
d1166d927ca2
(vc-bzr-print-log): Deal with nil arguments better.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106269
diff
changeset
|
632 (list vc-bzr-log-switches) |
d1166d927ca2
(vc-bzr-print-log): Deal with nil arguments better.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106269
diff
changeset
|
633 vc-bzr-log-switches))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
634 |
107795
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
635 (defun vc-bzr-log-incoming (buffer remote-location) |
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
636 (apply 'vc-bzr-command "missing" buffer 'async nil |
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
637 (list "--theirs-only" (unless (string= remote-location "") remote-location)))) |
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
638 |
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
639 (defun vc-bzr-log-outgoing (buffer remote-location) |
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
640 (apply 'vc-bzr-command "missing" buffer 'async nil |
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
641 (list "--mine-only" (unless (string= remote-location "") remote-location)))) |
d47e1fb98df3
Add new VC methods: vc-log-incoming and vc-log-outgoing.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107487
diff
changeset
|
642 |
85141
b16f7408cd3f
Carry through today's big terminology change to a few places where I
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85139
diff
changeset
|
643 (defun vc-bzr-show-log-entry (revision) |
b16f7408cd3f
Carry through today's big terminology change to a few places where I
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85139
diff
changeset
|
644 "Find entry for patch name REVISION in bzr change log buffer." |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
645 (goto-char (point-min)) |
98220
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
646 (when revision |
106472
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
647 (let (case-fold-search |
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
648 found) |
98220
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
649 (if (re-search-forward |
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
650 ;; "revno:" can appear either at the beginning of a line, |
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
651 ;; or indented. |
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
652 (concat "^[ ]*-+\n[ ]*revno: " |
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
653 ;; The revision can contain ".", quote it so that it |
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
654 ;; does not interfere with regexp matching. |
962e4709829b
* vc-bzr.el (vc-bzr-show-log-entry):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98079
diff
changeset
|
655 (regexp-quote revision) "$") nil t) |
106472
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
656 (progn |
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
657 (beginning-of-line 0) |
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
658 (setq found t)) |
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
659 (goto-char (point-min))) |
6e0f1038bc44
Support showing a single log entry from vc-annotate.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106466
diff
changeset
|
660 found))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
661 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
662 (defun vc-bzr-diff (files &optional rev1 rev2 buffer) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
663 "VC bzr backend for diff." |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
664 ;; `bzr diff' exits with code 1 if diff is non-empty. |
106732
d804f575197b
(vc-bzr-diff): Obey vc-disable-async-diff.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106729
diff
changeset
|
665 (apply #'vc-bzr-command "diff" (or buffer "*vc-diff*") |
d804f575197b
(vc-bzr-diff): Obey vc-disable-async-diff.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106729
diff
changeset
|
666 (if vc-disable-async-diff 1 'async) files |
96002
26f719e36c03
(log-view-per-file-logs): Pacify byte compiler.
Juanma Barranquero <lekktu@gmail.com>
parents:
95966
diff
changeset
|
667 "--diff-options" (mapconcat 'identity |
98464
75e08f08f5e5
(vc-bzr-diff): Use vc-switches rather than the obsolete vc-diff-switches.
Glenn Morris <rgm@gnu.org>
parents:
98220
diff
changeset
|
668 (vc-switches 'bzr 'diff) |
87649 | 669 " ") |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
670 ;; This `when' is just an optimization because bzr-1.2 is *much* |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
671 ;; faster when the revision argument is not given. |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
672 (when (or rev1 rev2) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
673 (list "-r" (format "%s..%s" |
96002
26f719e36c03
(log-view-per-file-logs): Pacify byte compiler.
Juanma Barranquero <lekktu@gmail.com>
parents:
95966
diff
changeset
|
674 (or rev1 "revno:-1") |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
675 (or rev2 "")))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
676 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
677 |
85141
b16f7408cd3f
Carry through today's big terminology change to a few places where I
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85139
diff
changeset
|
678 ;; FIXME: vc-{next,previous}-revision need fixing in vc.el to deal with |
b16f7408cd3f
Carry through today's big terminology change to a few places where I
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85139
diff
changeset
|
679 ;; straight integer revisions. |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
680 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
681 (defun vc-bzr-delete-file (file) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
682 "Delete FILE and delete it in the bzr repository." |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
683 (condition-case () |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
684 (delete-file file) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
685 (file-error nil)) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
686 (vc-bzr-command "remove" nil 0 file)) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
687 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
688 (defun vc-bzr-rename-file (old new) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
689 "Rename file from OLD to NEW using `bzr mv'." |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
690 (vc-bzr-command "mv" nil 0 new old)) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
691 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
692 (defvar vc-bzr-annotation-table nil |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
693 "Internal use.") |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
694 (make-variable-buffer-local 'vc-bzr-annotation-table) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
695 |
85141
b16f7408cd3f
Carry through today's big terminology change to a few places where I
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
85139
diff
changeset
|
696 (defun vc-bzr-annotate-command (file buffer &optional revision) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
697 "Prepare BUFFER for `vc-annotate' on FILE. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
698 Each line is tagged with the revision number, which has a `help-echo' |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
699 property containing author and date information." |
106269
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
700 (apply #'vc-bzr-command "annotate" buffer 'async file "--long" "--all" |
93039
e48df1ee4371
Revert unintended change.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93035
diff
changeset
|
701 (if revision (list "-r" revision))) |
106269
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
702 (lexical-let ((table (make-hash-table :test 'equal))) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
703 (set-process-filter |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
704 (get-buffer-process buffer) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
705 (lambda (proc string) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
706 (when (process-buffer proc) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
707 (with-current-buffer (process-buffer proc) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
708 (setq string (concat (process-get proc :vc-left-over) string)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
709 (while (string-match "^\\( *[0-9.]+ *\\) \\([^\n ]+\\) +\\([0-9]\\{8\\}\\)\\( |.*\n\\)" string) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
710 (let* ((rev (match-string 1 string)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
711 (author (match-string 2 string)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
712 (date (match-string 3 string)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
713 (key (substring string (match-beginning 0) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
714 (match-beginning 4))) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
715 (line (match-string 4 string)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
716 (tag (gethash key table)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
717 (inhibit-read-only t)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
718 (setq string (substring string (match-end 0))) |
106461
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
719 (unless tag |
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
720 (setq tag |
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
721 (propertize |
106476
97d377672952
* vc-bzr.el (vc-bzr-annotate-command): More elegant form for last
Chong Yidong <cyd@stupidchicken.com>
parents:
106472
diff
changeset
|
722 (format "%s %-7.7s" rev author) |
106461
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
723 'help-echo (format "Revision: %d, author: %s, date: %s" |
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
724 (string-to-number rev) |
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
725 author date) |
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
726 'mouse-face 'highlight)) |
106269
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
727 (puthash key tag table)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
728 (goto-char (process-mark proc)) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
729 (insert tag line) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
730 (move-marker (process-mark proc) (point)))) |
e90925cbde07
(vc-bzr-annotate-command): Make operation asynchronous.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106033
diff
changeset
|
731 (process-put proc :vc-left-over string))))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
732 |
96213
09da7727f35f
* vc-hg.el (vc-annotate-convert-time, vc-default-status-printer):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96128
diff
changeset
|
733 (declare-function vc-annotate-convert-time "vc-annotate" (time)) |
09da7727f35f
* vc-hg.el (vc-annotate-convert-time, vc-default-status-printer):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96128
diff
changeset
|
734 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
735 (defun vc-bzr-annotate-time () |
106461
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
736 (when (re-search-forward "^ *[0-9.]+ +[^\n ]* +|" nil t) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
737 (let ((prop (get-text-property (line-beginning-position) 'help-echo))) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
738 (string-match "[0-9]+\\'" prop) |
95228
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
739 (let ((str (match-string-no-properties 0 prop))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
740 (vc-annotate-convert-time |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
741 (encode-time 0 0 0 |
95228
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
742 (string-to-number (substring str 6 8)) |
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
743 (string-to-number (substring str 4 6)) |
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
744 (string-to-number (substring str 0 4)))))))) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
745 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
746 (defun vc-bzr-annotate-extract-revision-at-line () |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
747 "Return revision for current line of annoation buffer, or nil. |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
748 Return nil if current line isn't annotated." |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
749 (save-excursion |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
750 (beginning-of-line) |
106461
26c68e7906a5
* vc-bzr.el (vc-bzr-annotate-command): Show author in annotation.
Chong Yidong <cyd@stupidchicken.com>
parents:
106388
diff
changeset
|
751 (if (looking-at "^ *\\([0-9.]+\\) +[^\n ]* +|") |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
752 (match-string-no-properties 1)))) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
753 |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
754 (defun vc-bzr-command-discarding-stderr (command &rest args) |
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
755 "Execute shell command COMMAND (with ARGS); return its output and exitcode. |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
756 Return value is a cons (EXITCODE . OUTPUT), where EXITCODE is |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
757 the (numerical) exit code of the process, and OUTPUT is a string |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
758 containing whatever the process sent to its standard output |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
759 stream. Standard error output is discarded." |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
760 (with-temp-buffer |
78435
adc16e5bfb60
Remove comments about vc-bzr.el being a modified unofficial version.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78431
diff
changeset
|
761 (cons |
94873
66788c63a40a
(vc-bzr-sha1, vc-bzr-command-discarding-stderr)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94847
diff
changeset
|
762 (apply #'process-file command nil (list (current-buffer) nil) nil args) |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
763 (buffer-substring (point-min) (point-max))))) |
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
764 |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
765 (defstruct (vc-bzr-extra-fileinfo |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
766 (:copier nil) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
767 (:constructor vc-bzr-create-extra-fileinfo (extra-name)) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
768 (:conc-name vc-bzr-extra-fileinfo->)) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
769 extra-name) ;; original name for rename targets, new name for |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
770 |
99388
fcdc9cfd2092
(vc-bzr-dir-extra-headers): New function.
Chong Yidong <cyd@stupidchicken.com>
parents:
98524
diff
changeset
|
771 (defun vc-bzr-dir-printer (info) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
772 "Pretty-printer for the vc-dir-fileinfo structure." |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
773 (let ((extra (vc-dir-fileinfo->extra info))) |
99388
fcdc9cfd2092
(vc-bzr-dir-extra-headers): New function.
Chong Yidong <cyd@stupidchicken.com>
parents:
98524
diff
changeset
|
774 (vc-default-dir-printer 'Bzr info) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
775 (when extra |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
776 (insert (propertize |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
777 (format " (renamed from %s)" |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
778 (vc-bzr-extra-fileinfo->extra-name extra)) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
779 'face 'font-lock-comment-face))))) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
780 |
96539
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
781 ;; FIXME: this needs testing, it's probably incomplete. |
106677
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
782 (defun vc-bzr-after-dir-status (update-function relative-dir) |
93035
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
783 (let ((status-str nil) |
96539
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
784 (translation '(("+N " . added) |
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
785 ("-D " . removed) |
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
786 (" M " . edited) ;; file text modified |
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
787 (" *" . edited) ;; execute bit changed |
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
788 (" M*" . edited) ;; text modified + execute bit changed |
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
789 ;; FIXME: what about ignored files? |
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
790 (" D " . missing) |
95228
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
791 ;; For conflicts, should we list the .THIS/.BASE/.OTHER? |
96539
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
792 ("C " . conflict) |
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
793 ("? " . unregistered) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
794 ;; No such state, but we need to distinguish this case. |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
795 ("R " . renamed) |
107049
6791d69ed71e
(vc-bzr-after-dir-status): Match another renaming indicator.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106985
diff
changeset
|
796 ("RM " . renamed) |
98524
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
797 ;; For a non existent file FOO, the output is: |
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
798 ;; bzr: ERROR: Path(s) do not exist: FOO |
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
799 ("bzr" . not-found) |
102704
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
800 ;; If the tree is not up to date, bzr will print this warning: |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
801 ;; working tree is out of date, run 'bzr update' |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
802 ;; ignore it. |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
803 ;; FIXME: maybe this warning can be put in the vc-dir header... |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
804 ("wor" . not-found) |
95228
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
805 ;; Ignore "P " and "P." for pending patches. |
106751
d94786c1fa6c
(vc-bzr-after-dir-status): Ignore pending merges.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106742
diff
changeset
|
806 ("P " . not-found) |
d94786c1fa6c
(vc-bzr-after-dir-status): Ignore pending merges.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106742
diff
changeset
|
807 ("P. " . not-found) |
95228
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
808 )) |
93035
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
809 (translated nil) |
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
810 (result nil)) |
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
811 (goto-char (point-min)) |
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
812 (while (not (eobp)) |
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
813 (setq status-str |
96539
d9bc43f652b0
(vc-bzr-after-dir-status): Deal with execute bit changes.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96213
diff
changeset
|
814 (buffer-substring-no-properties (point) (+ (point) 3))) |
93976
c53b75d15c27
(vc-bzr-after-dir-status): Detect the conflict state.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93759
diff
changeset
|
815 (setq translated (cdr (assoc status-str translation))) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
816 (cond |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
817 ((eq translated 'conflict) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
818 ;; For conflicts the file appears twice in the listing: once |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
819 ;; with the M flag and once with the C flag, so take care |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
820 ;; not to add it twice to `result'. Ugly. |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
821 (let* ((file |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
822 (buffer-substring-no-properties |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
823 ;;For files with conflicts the format is: |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
824 ;;C Text conflict in FILENAME |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
825 ;; Bah. |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
826 (+ (point) 21) (line-end-position))) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
827 (entry (assoc file result))) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
828 (when entry |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
829 (setf (nth 1 entry) 'conflict)))) |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
830 ((eq translated 'renamed) |
107049
6791d69ed71e
(vc-bzr-after-dir-status): Match another renaming indicator.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106985
diff
changeset
|
831 (re-search-forward "R[ M] \\(.*\\) => \\(.*\\)$" (line-end-position) t) |
106677
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
832 (let ((new-name (file-relative-name (match-string 2) relative-dir)) |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
833 (old-name (file-relative-name (match-string 1) relative-dir))) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
834 (push (list new-name 'edited |
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
835 (vc-bzr-create-extra-fileinfo old-name)) result))) |
98524
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
836 ;; do nothing for non existent files |
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
837 ((eq translated 'not-found)) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
838 (t |
106677
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
839 (push (list (file-relative-name |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
840 (buffer-substring-no-properties |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
841 (+ (point) 4) |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
842 (line-end-position)) relative-dir) |
98079
9fc5b62e3967
(vc-bzr-extra-fileinfo): New defstruct.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
97401
diff
changeset
|
843 translated) result))) |
93035
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
844 (forward-line)) |
94003
2ecb2ea8d5b5
Change `dir-status' to not take (and pass) status-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93976
diff
changeset
|
845 (funcall update-function result))) |
93035
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
846 |
94003
2ecb2ea8d5b5
Change `dir-status' to not take (and pass) status-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93976
diff
changeset
|
847 (defun vc-bzr-dir-status (dir update-function) |
93035
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
848 "Return a list of conses (file . state) for DIR." |
93382
8e46096e0cb3
* vc.el (vc-status-menu-map, vc-status-mode-map): Bind vc-revert.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93368
diff
changeset
|
849 (vc-bzr-command "status" (current-buffer) 'async dir "-v" "-S") |
8e46096e0cb3
* vc.el (vc-status-menu-map, vc-status-mode-map): Bind vc-revert.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
93368
diff
changeset
|
850 (vc-exec-after |
106677
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
851 `(vc-bzr-after-dir-status (quote ,update-function) |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
852 ;; "bzr status" results are relative to |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
853 ;; the bzr root directory, NOT to the |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
854 ;; directory "bzr status" was invoked in. |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
855 ;; Ugh. |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
856 ;; We pass the relative directory here so |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
857 ;; that `vc-bzr-after-dir-status' can |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
858 ;; frob the results accordingly. |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
859 (file-relative-name ,dir (vc-bzr-root ,dir))))) |
93035
5f4eb3149e6d
* vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
92980
diff
changeset
|
860 |
98524
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
861 (defun vc-bzr-dir-status-files (dir files default-state update-function) |
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
862 "Return a list of conses (file . state) for DIR." |
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
863 (apply 'vc-bzr-command "status" (current-buffer) 'async dir "-v" "-S" files) |
622e1277bbf2
(vc-bzr-after-dir-status): Parse the output for non
Dan Nicolaescu <dann@ics.uci.edu>
parents:
98464
diff
changeset
|
864 (vc-exec-after |
106677
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
865 `(vc-bzr-after-dir-status (quote ,update-function) |
f147ed43b1d5
Make vc-dir work on subdirectories of the bzr root.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106670
diff
changeset
|
866 (file-relative-name ,dir (vc-bzr-root ,dir))))) |
99388
fcdc9cfd2092
(vc-bzr-dir-extra-headers): New function.
Chong Yidong <cyd@stupidchicken.com>
parents:
98524
diff
changeset
|
867 |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
868 (defvar vc-bzr-shelve-map |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
869 (let ((map (make-sparse-keymap))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
870 ;; Turn off vc-dir marking |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
871 (define-key map [mouse-2] 'ignore) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
872 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
873 (define-key map [down-mouse-3] 'vc-bzr-shelve-menu) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
874 (define-key map "\C-k" 'vc-bzr-shelve-delete-at-point) |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
875 (define-key map "=" 'vc-bzr-shelve-show-at-point) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
876 (define-key map "\C-m" 'vc-bzr-shelve-show-at-point) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
877 (define-key map "A" 'vc-bzr-shelve-apply-and-keep-at-point) |
106729
b4d5ac4906a0
(vc-bzr-shelve-map): Change binding for vc-bzr-shelve-apply-at-point.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106724
diff
changeset
|
878 (define-key map "P" 'vc-bzr-shelve-apply-at-point) |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
879 (define-key map "S" 'vc-bzr-shelve-snapshot) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
880 map)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
881 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
882 (defvar vc-bzr-shelve-menu-map |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
883 (let ((map (make-sparse-keymap "Bzr Shelve"))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
884 (define-key map [de] |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
885 '(menu-item "Delete shelf" vc-bzr-shelve-delete-at-point |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
886 :help "Delete the current shelf")) |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
887 (define-key map [ap] |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
888 '(menu-item "Apply and keep shelf" vc-bzr-shelve-apply-and-keep-at-point |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
889 :help "Apply the current shelf and keep it")) |
106729
b4d5ac4906a0
(vc-bzr-shelve-map): Change binding for vc-bzr-shelve-apply-at-point.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106724
diff
changeset
|
890 (define-key map [po] |
b4d5ac4906a0
(vc-bzr-shelve-map): Change binding for vc-bzr-shelve-apply-at-point.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106724
diff
changeset
|
891 '(menu-item "Apply and remove shelf (pop)" vc-bzr-shelve-apply-at-point |
b4d5ac4906a0
(vc-bzr-shelve-map): Change binding for vc-bzr-shelve-apply-at-point.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106724
diff
changeset
|
892 :help "Apply the current shelf and remove it")) |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
893 (define-key map [sh] |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
894 '(menu-item "Show shelve" vc-bzr-shelve-show-at-point |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
895 :help "Show the contents of the current shelve")) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
896 map)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
897 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
898 (defvar vc-bzr-extra-menu-map |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
899 (let ((map (make-sparse-keymap))) |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
900 (define-key map [bzr-sn] |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
901 '(menu-item "Shelve a snapshot" vc-bzr-shelve-snapshot |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
902 :help "Shelve the current state of the tree and keep the current state")) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
903 (define-key map [bzr-sh] |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
904 '(menu-item "Shelve..." vc-bzr-shelve |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
905 :help "Shelve changes")) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
906 map)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
907 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
908 (defun vc-bzr-extra-menu () vc-bzr-extra-menu-map) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
909 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
910 (defun vc-bzr-extra-status-menu () vc-bzr-extra-menu-map) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
911 |
99388
fcdc9cfd2092
(vc-bzr-dir-extra-headers): New function.
Chong Yidong <cyd@stupidchicken.com>
parents:
98524
diff
changeset
|
912 (defun vc-bzr-dir-extra-headers (dir) |
102704
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
913 (let* |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
914 ((str (with-temp-buffer |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
915 (vc-bzr-command "info" t 0 dir) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
916 (buffer-string))) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
917 (shelve (vc-bzr-shelve-list)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
918 (shelve-help-echo "Use M-x vc-bzr-shelve to create shelves") |
107068
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
919 (root-dir (vc-bzr-root dir)) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
920 (pending-merge |
107097
6692a4cd2966
* vc-bzr.el (vc-bzr-dir-extra-headers): Disable the pending merges header.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107068
diff
changeset
|
921 ;; FIXME: looking for .bzr/checkout/merge-hashes is not a |
6692a4cd2966
* vc-bzr.el (vc-bzr-dir-extra-headers): Disable the pending merges header.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107068
diff
changeset
|
922 ;; reliable method to detect pending merges, disable this |
6692a4cd2966
* vc-bzr.el (vc-bzr-dir-extra-headers): Disable the pending merges header.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107068
diff
changeset
|
923 ;; until a proper solution is implemented. |
6692a4cd2966
* vc-bzr.el (vc-bzr-dir-extra-headers): Disable the pending merges header.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107068
diff
changeset
|
924 (and nil |
6692a4cd2966
* vc-bzr.el (vc-bzr-dir-extra-headers): Disable the pending merges header.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107068
diff
changeset
|
925 (file-exists-p |
6692a4cd2966
* vc-bzr.el (vc-bzr-dir-extra-headers): Disable the pending merges header.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107068
diff
changeset
|
926 (expand-file-name ".bzr/checkout/merge-hashes" root-dir)))) |
107068
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
927 (pending-merge-help-echo |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
928 (format "A merge has been performed.\nA commit from the top-level directory (%s)\nis required before being able to check in anything else" root-dir)) |
102704
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
929 (light-checkout |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
930 (when (string-match ".+light checkout root: \\(.+\\)$" str) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
931 (match-string 1 str))) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
932 (light-checkout-branch |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
933 (when light-checkout |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
934 (when (string-match ".+checkout of branch: \\(.+\\)$" str) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
935 (match-string 1 str))))) |
99388
fcdc9cfd2092
(vc-bzr-dir-extra-headers): New function.
Chong Yidong <cyd@stupidchicken.com>
parents:
98524
diff
changeset
|
936 (concat |
102704
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
937 (propertize "Parent branch : " 'face 'font-lock-type-face) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
938 (propertize |
99388
fcdc9cfd2092
(vc-bzr-dir-extra-headers): New function.
Chong Yidong <cyd@stupidchicken.com>
parents:
98524
diff
changeset
|
939 (if (string-match "parent branch: \\(.+\\)$" str) |
102704
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
940 (match-string 1 str) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
941 "None") |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
942 'face 'font-lock-variable-name-face) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
943 "\n" |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
944 (when light-checkout |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
945 (concat |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
946 (propertize "Light checkout root: " 'face 'font-lock-type-face) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
947 (propertize light-checkout 'face 'font-lock-variable-name-face) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
948 "\n")) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
949 (when light-checkout-branch |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
950 (concat |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
951 (propertize "Checkout of branch : " 'face 'font-lock-type-face) |
acda56dde7fb
(vc-bzr-working-revision): Add support for lightweight
Dan Nicolaescu <dann@ics.uci.edu>
parents:
101790
diff
changeset
|
952 (propertize light-checkout-branch 'face 'font-lock-variable-name-face) |
106388
afe271b2ef40
(vc-bzr-dir-extra-headers): Fix typo.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106387
diff
changeset
|
953 "\n")) |
107068
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
954 (when pending-merge |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
955 (concat |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
956 (propertize "Warning : " 'face 'font-lock-warning-face |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
957 'help-echo pending-merge-help-echo) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
958 (propertize "Pending merges, commit recommended before any other action" |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
959 'help-echo pending-merge-help-echo |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
960 'face 'font-lock-warning-face) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
961 "\n")) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
962 (if shelve |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
963 (concat |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
964 (propertize "Shelves :\n" 'face 'font-lock-type-face |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
965 'help-echo shelve-help-echo) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
966 (mapconcat |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
967 (lambda (x) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
968 (propertize x |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
969 'face 'font-lock-variable-name-face |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
970 'mouse-face 'highlight |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
971 'help-echo "mouse-3: Show shelve menu\nA: Apply and keep shelf\nP: Apply and remove shelf (pop)\nS: Snapshot to a shelf\nC-k: Delete shelf" |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
972 'keymap vc-bzr-shelve-map)) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
973 shelve "\n")) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
974 (concat |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
975 (propertize "Shelves : " 'face 'font-lock-type-face |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
976 'help-echo shelve-help-echo) |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
977 (propertize "No shelved changes" |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
978 'help-echo shelve-help-echo |
8d8e02bbef81
(vc-bzr-dir-extra-headers): Add a header when a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107049
diff
changeset
|
979 'face 'font-lock-variable-name-face)))))) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
980 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
981 (defun vc-bzr-shelve (name) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
982 "Create a shelve." |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
983 (interactive "sShelf name: ") |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
984 (let ((root (vc-bzr-root default-directory))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
985 (when root |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
986 (vc-bzr-command "shelve" nil 0 nil "--all" "-m" name) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
987 (vc-resynch-buffer root t t)))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
988 |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
989 (defun vc-bzr-shelve-show (name) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
990 "Show the contents of shelve NAME." |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
991 (interactive "sShelve name: ") |
107979
bb75dfb8839a
* vc-bzr: Use standard *vc* and *vc-diff* buffers.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107795
diff
changeset
|
992 (vc-setup-buffer "*vc-diff*") |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
993 ;; FIXME: how can you show the contents of a shelf? |
107979
bb75dfb8839a
* vc-bzr: Use standard *vc* and *vc-diff* buffers.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107795
diff
changeset
|
994 (vc-bzr-command "unshelve" "*vc-diff*" 'async nil "--preview" name) |
bb75dfb8839a
* vc-bzr: Use standard *vc* and *vc-diff* buffers.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107795
diff
changeset
|
995 (set-buffer "*vc-diff*") |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
996 (diff-mode) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
997 (setq buffer-read-only t) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
998 (pop-to-buffer (current-buffer))) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
999 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1000 (defun vc-bzr-shelve-apply (name) |
106729
b4d5ac4906a0
(vc-bzr-shelve-map): Change binding for vc-bzr-shelve-apply-at-point.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106724
diff
changeset
|
1001 "Apply shelve NAME and remove it afterwards." |
b4d5ac4906a0
(vc-bzr-shelve-map): Change binding for vc-bzr-shelve-apply-at-point.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106724
diff
changeset
|
1002 (interactive "sApply (and remove) shelf: ") |
107979
bb75dfb8839a
* vc-bzr: Use standard *vc* and *vc-diff* buffers.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107795
diff
changeset
|
1003 (vc-bzr-command "unshelve" nil 0 nil "--apply" name) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1004 (vc-resynch-buffer (vc-bzr-root default-directory) t t)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1005 |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1006 (defun vc-bzr-shelve-apply-and-keep (name) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1007 "Apply shelve NAME and keep it afterwards." |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1008 (interactive "sApply (and keep) shelf: ") |
107979
bb75dfb8839a
* vc-bzr: Use standard *vc* and *vc-diff* buffers.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107795
diff
changeset
|
1009 (vc-bzr-command "unshelve" nil 0 nil "--apply" "--keep" name) |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1010 (vc-resynch-buffer (vc-bzr-root default-directory) t t)) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1011 |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1012 (defun vc-bzr-shelve-snapshot () |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1013 "Create a stash with the current tree state." |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1014 (interactive) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1015 (vc-bzr-command "shelve" nil 0 nil "--all" "-m" |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1016 (let ((ct (current-time))) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1017 (concat |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1018 (format-time-string "Snapshot on %Y-%m-%d" ct) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1019 (format-time-string " at %H:%M" ct)))) |
107979
bb75dfb8839a
* vc-bzr: Use standard *vc* and *vc-diff* buffers.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107795
diff
changeset
|
1020 (vc-bzr-command "unshelve" nil 0 nil "--apply" "--keep") |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1021 (vc-resynch-buffer (vc-bzr-root default-directory) t t)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1022 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1023 (defun vc-bzr-shelve-list () |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1024 (with-temp-buffer |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1025 (vc-bzr-command "shelve" (current-buffer) 1 nil "--list" "-q") |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1026 (delete |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1027 "" |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1028 (split-string |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1029 (buffer-substring (point-min) (point-max)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1030 "\n")))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1031 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1032 (defun vc-bzr-shelve-get-at-point (point) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1033 (save-excursion |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1034 (goto-char point) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1035 (beginning-of-line) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1036 (if (looking-at "^ +\\([0-9]+\\):") |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1037 (match-string 1) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1038 (error "Cannot find shelf at point")))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1039 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1040 (defun vc-bzr-shelve-delete-at-point () |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1041 (interactive) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1042 (let ((shelve (vc-bzr-shelve-get-at-point (point)))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1043 (when (y-or-n-p (format "Remove shelf %s ?" shelve)) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1044 (vc-bzr-command "unshelve" nil 0 nil "--delete-only" shelve) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1045 (vc-dir-refresh)))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1046 |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1047 (defun vc-bzr-shelve-show-at-point () |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1048 (interactive) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1049 (vc-bzr-shelve-show (vc-bzr-shelve-get-at-point (point)))) |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1050 |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1051 (defun vc-bzr-shelve-apply-at-point () |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1052 (interactive) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1053 (vc-bzr-shelve-apply (vc-bzr-shelve-get-at-point (point)))) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1054 |
107372
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1055 (defun vc-bzr-shelve-apply-and-keep-at-point () |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1056 (interactive) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1057 (vc-bzr-shelve-apply-and-keep (vc-bzr-shelve-get-at-point (point)))) |
b73242777fb9
Add support for shelving snapshots and for showing shelves.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107175
diff
changeset
|
1058 |
106387
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1059 (defun vc-bzr-shelve-menu (e) |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1060 (interactive "e") |
e01e9655414f
Add support for bzr shelve/unshelve.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
106386
diff
changeset
|
1061 (vc-dir-at-event e (popup-menu vc-bzr-shelve-menu-map e))) |
99388
fcdc9cfd2092
(vc-bzr-dir-extra-headers): New function.
Chong Yidong <cyd@stupidchicken.com>
parents:
98524
diff
changeset
|
1062 |
106982
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1063 (defun vc-bzr-revision-table (files) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1064 (let ((vc-bzr-revisions '()) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1065 (default-directory (file-name-directory (car files)))) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1066 (with-temp-buffer |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1067 (vc-bzr-command "log" t 0 files "--line") |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1068 (let ((start (point-min)) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1069 (loglines (buffer-substring-no-properties (point-min) (point-max)))) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1070 (while (string-match "^\\([0-9]+\\):" loglines) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1071 (push (match-string 1 loglines) vc-bzr-revisions) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1072 (setq start (+ start (match-end 0))) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1073 (setq loglines (buffer-substring-no-properties start (point-max)))))) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1074 vc-bzr-revisions)) |
38312121c181
working version of vc-bzr-revision-table
Mark A. Hershberger <mhershberger@intrahealth.org>
parents:
106819
diff
changeset
|
1075 |
108009
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1076 (defun vc-bzr-conflicted-files (dir) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1077 (let ((default-directory (vc-bzr-root dir)) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1078 (files ())) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1079 (with-temp-buffer |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1080 (vc-bzr-command "status" t 0 default-directory) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1081 (goto-char (point-min)) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1082 (when (re-search-forward "^conflicts:\n" nil t) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1083 (while (looking-at " \\(?:Text conflict in \\(.*\\)\\|.*\\)\n") |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1084 (if (match-end 1) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1085 (push (expand-file-name (match-string 1)) files)) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1086 (goto-char (match-end 0))))) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1087 files)) |
17d3324f96dd
Make the log-edit comments use RFC822 format throughout.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107979
diff
changeset
|
1088 |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1089 ;;; Revision completion |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1090 |
105800
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1091 (eval-and-compile |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1092 (defconst vc-bzr-revision-keywords |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1093 '("revno" "revid" "last" "before" |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1094 "tag" "date" "ancestor" "branch" "submit"))) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1095 |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1096 (defun vc-bzr-revision-completion-table (files) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1097 (lexical-let ((files files)) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1098 ;; What about using `files'?!? --Stef |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1099 (lambda (string pred action) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1100 (cond |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1101 ((string-match "\\`\\(ancestor\\|branch\\|\\(revno:\\)?[-0-9]+:\\):" |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1102 string) |
94216
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1103 (completion-table-with-context (substring string 0 (match-end 0)) |
108681
1b1048318854
* lisp/vc-bzr.el (vc-bzr-revision-completion-table): Apply
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107175
diff
changeset
|
1104 (apply-partially |
1b1048318854
* lisp/vc-bzr.el (vc-bzr-revision-completion-table): Apply
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107175
diff
changeset
|
1105 'completion-table-with-predicate |
1b1048318854
* lisp/vc-bzr.el (vc-bzr-revision-completion-table): Apply
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107175
diff
changeset
|
1106 'completion-file-name-table |
1b1048318854
* lisp/vc-bzr.el (vc-bzr-revision-completion-table): Apply
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107175
diff
changeset
|
1107 'file-directory-p t) |
94216
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1108 (substring string (match-end 0)) |
108681
1b1048318854
* lisp/vc-bzr.el (vc-bzr-revision-completion-table): Apply
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107175
diff
changeset
|
1109 pred |
94216
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1110 action)) |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1111 ((string-match "\\`\\(before\\):" string) |
94216
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1112 (completion-table-with-context (substring string 0 (match-end 0)) |
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1113 (vc-bzr-revision-completion-table files) |
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1114 (substring string (match-end 0)) |
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1115 pred |
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1116 action)) |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1117 ((string-match "\\`\\(tag\\):" string) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1118 (let ((prefix (substring string 0 (match-end 0))) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1119 (tag (substring string (match-end 0))) |
104595
cfc336042c1b
* vc-bzr.el (vc-bzr-sha1, vc-bzr-revision-completion-table):
Michael Albinus <michael.albinus@gmx.de>
parents:
104086
diff
changeset
|
1120 (table nil) |
cfc336042c1b
* vc-bzr.el (vc-bzr-sha1, vc-bzr-revision-completion-table):
Michael Albinus <michael.albinus@gmx.de>
parents:
104086
diff
changeset
|
1121 process-file-side-effects) |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1122 (with-temp-buffer |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1123 ;; "bzr-1.2 tags" is much faster with --show-ids. |
94873
66788c63a40a
(vc-bzr-sha1, vc-bzr-command-discarding-stderr)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94847
diff
changeset
|
1124 (process-file vc-bzr-program nil '(t) nil "tags" "--show-ids") |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1125 ;; The output is ambiguous, unless we assume that revids do not |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1126 ;; contain spaces. |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1127 (goto-char (point-min)) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1128 (while (re-search-forward "^\\(.*[^ \n]\\) +[^ \n]*$" nil t) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1129 (push (match-string-no-properties 1) table))) |
94216
34110d646fc8
(vc-bzr-complete-with-prefix): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94003
diff
changeset
|
1130 (completion-table-with-context prefix table tag pred action))) |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1131 |
105800
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1132 ((string-match "\\`\\([a-z]+\\):" string) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1133 ;; no actual completion for the remaining keywords. |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1134 (completion-table-with-context (substring string 0 (match-end 0)) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1135 (if (member (match-string 1 string) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1136 vc-bzr-revision-keywords) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1137 ;; If it's a valid keyword, |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1138 ;; use a non-empty table to |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1139 ;; indicate it. |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1140 '("") nil) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1141 (substring string (match-end 0)) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1142 pred |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1143 action)) |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1144 (t |
95228
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
1145 ;; Could use completion-table-with-terminator, except that it |
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
1146 ;; currently doesn't work right w.r.t pcm and doesn't give |
451f4028c096
* minibuffer.el (completion-boundaries): Change calling convention, so
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95077
diff
changeset
|
1147 ;; the *Completions* output we want. |
105800
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1148 (complete-with-action action (eval-when-compile |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1149 (mapcar (lambda (s) (concat s ":")) |
35ac8b2ebcf2
(vc-bzr-revision-keywords): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105697
diff
changeset
|
1150 vc-bzr-revision-keywords)) |
92980
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1151 string pred)))))) |
ba464718dbd7
(vc-bzr-diff): Use a faster invocation when possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92938
diff
changeset
|
1152 |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1153 (eval-after-load "vc" |
78431
abd7f08fa06b
(vc-bzr-registered): Gracefully handle missing "bzr"
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78404
diff
changeset
|
1154 '(add-to-list 'vc-directory-exclusion-list vc-bzr-admin-dirname t)) |
78372
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1155 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1156 (provide 'vc-bzr) |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1157 ;; arch-tag: 8101bad8-4e92-4e7d-85ae-d8e08b4e7c06 |
53ed644d1a88
* vc-bzr.el: New file (copied from the trunk).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1158 ;;; vc-bzr.el ends here |