annotate lisp/vc-git.el @ 94395:f020c9568544

* net/tramp.el (tramp-replace-environment-variables): New defun. (tramp-handle-substitute-in-file-name, tramp-file-name-handler): Use it.
author Michael Albinus <michael.albinus@gmx.de>
date Sun, 27 Apr 2008 09:29:41 +0000
parents 55b13d307a7a
children ad6c174910db
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
1 ;;; vc-git.el --- VC backend for the git version control system
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
2
79721
73661ddc7ac7 Add 2008 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 79687
diff changeset
3 ;; Copyright (C) 2006, 2007, 2008 Free Software Foundation, Inc.
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
4
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
5 ;; Author: Alexandre Julliard <julliard@winehq.org>
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
6 ;; Keywords: tools
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
7
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
8 ;; This file is part of GNU Emacs.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
9
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
12 ;; the Free Software Foundation; either version 3, or (at your option)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
13 ;; any later version.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
14
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
18 ;; GNU General Public License for more details.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
19
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
22 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
23 ;; Boston, MA 02110-1301, USA.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
24
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
25 ;;; Commentary:
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
26
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
27 ;; This file contains a VC backend for the git version control
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
28 ;; system.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
29 ;;
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
30
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
31 ;;; Installation:
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
32
78404
27f00e50116a Change capitalization of VC backend names for new backends
Miles Bader <miles@gnu.org>
parents: 78359
diff changeset
33 ;; To install: put this file on the load-path and add Git to the list
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
34 ;; of supported backends in `vc-handled-backends'; the following line,
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
35 ;; placed in your ~/.emacs, will accomplish this:
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
36 ;;
78404
27f00e50116a Change capitalization of VC backend names for new backends
Miles Bader <miles@gnu.org>
parents: 78359
diff changeset
37 ;; (add-to-list 'vc-handled-backends 'Git)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
38
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
39 ;;; Todo:
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
40 ;; - check if more functions could use vc-git-command instead
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
41 ;; of start-process.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
42 ;; - changelog generation
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
43
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
44 ;; Implement the rest of the vc interface. See the comment at the
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
45 ;; beginning of vc.el. The current status is:
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
46 ;; ("??" means: "figure out what to do about it")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
47 ;;
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
48 ;; FUNCTION NAME STATUS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
49 ;; BACKEND PROPERTIES
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
50 ;; * revision-granularity OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
51 ;; STATE-QUERYING FUNCTIONS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
52 ;; * registered (file) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
53 ;; * state (file) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
54 ;; - state-heuristic (file) NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
55 ;; - dir-state (dir) OK
85139
8ba0e30716a5 Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 85114
diff changeset
56 ;; * working-revision (file) OK
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
57 ;; - latest-on-branch-p (file) NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
58 ;; * checkout-model (file) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
59 ;; - workfile-unchanged-p (file) OK
82843
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
60 ;; - mode-line-string (file) OK
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
61 ;; - dired-state-info (file) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
62 ;; STATE-CHANGING FUNCTIONS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
63 ;; * create-repo () OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
64 ;; * register (files &optional rev comment) OK
85139
8ba0e30716a5 Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 85114
diff changeset
65 ;; - init-revision (file) NOT NEEDED
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
66 ;; - responsible-p (file) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
67 ;; - could-register (file) NOT NEEDED, DEFAULT IS GOOD
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
68 ;; - receive-file (file rev) NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
69 ;; - unregister (file) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
70 ;; * checkin (files rev comment) OK
85139
8ba0e30716a5 Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 85114
diff changeset
71 ;; * find-revision (file rev buffer) OK
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
72 ;; * checkout (file &optional editable rev) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
73 ;; * revert (file &optional contents-done) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
74 ;; - rollback (files) COULD BE SUPPORTED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
75 ;; - merge (file rev1 rev2) It would be possible to merge changes into
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
76 ;; a single file, but when committing they
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
77 ;; wouldn't be identified as a merge by git,
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
78 ;; so it's probably not a good idea.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
79 ;; - merge-news (file) see `merge'
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
80 ;; - steal-lock (file &optional revision) NOT NEEDED
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
81 ;; HISTORY FUNCTIONS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
82 ;; * print-log (files &optional buffer) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
83 ;; - log-view-mode () OK
86397
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
84 ;; - show-log-entry (revision) OK
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
85 ;; - wash-log (file) COULD BE SUPPORTED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
86 ;; - logentry-check () NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
87 ;; - comment-history (file) ??
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
88 ;; - update-changelog (files) COULD BE SUPPORTED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
89 ;; * diff (file &optional rev1 rev2 buffer) OK
94290
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
90 ;; - revision-completion-table (files) OK
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
91 ;; - annotate-command (file buf &optional rev) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
92 ;; - annotate-time () OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
93 ;; - annotate-current-time () NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
94 ;; - annotate-extract-revision-at-line () OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
95 ;; SNAPSHOT SYSTEM
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
96 ;; - create-snapshot (dir name branchp) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
97 ;; - assign-name (file name) NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
98 ;; - retrieve-snapshot (dir name update) OK, needs to update buffers
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
99 ;; MISCELLANEOUS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
100 ;; - make-version-backups-p (file) NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
101 ;; - repository-hostname (dirname) NOT NEEDED
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
102 ;; - previous-revision (file rev) OK
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
103 ;; - next-revision (file rev) OK
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
104 ;; - check-headers () COULD BE SUPPORTED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
105 ;; - clear-headers () NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
106 ;; - delete-file (file) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
107 ;; - rename-file (old new) OK
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
108 ;; - find-file-hook () NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
109 ;; - find-file-not-found-hook () NOT NEEDED
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
110
94290
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
111 (eval-when-compile
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
112 (require 'cl)
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
113 (require 'vc)
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
114 (require 'grep))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
115
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
116 (defvar git-commits-coding-system 'utf-8
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
117 "Default coding system for git commits.")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
118
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
119 ;;; BACKEND PROPERTIES
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
120
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
121 (defun vc-git-revision-granularity ()
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
122 'repository)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
123
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
124 ;;; STATE-QUERYING FUNCTIONS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
125
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
126 ;;;###autoload (defun vc-git-registered (file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
127 ;;;###autoload "Return non-nil if FILE is registered with git."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
128 ;;;###autoload (if (vc-find-root file ".git") ; short cut
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
129 ;;;###autoload (progn
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
130 ;;;###autoload (load "vc-git")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
131 ;;;###autoload (vc-git-registered file))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
132
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
133 (defun vc-git-registered (file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
134 "Check whether FILE is registered with git."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
135 (when (vc-git-root file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
136 (with-temp-buffer
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
137 (let* ((dir (file-name-directory file))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
138 (name (file-relative-name file dir)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
139 (and (ignore-errors
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
140 (when dir (cd dir))
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
141 (vc-git--out-ok "ls-files" "-c" "-z" "--" name))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
142 (let ((str (buffer-string)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
143 (and (> (length str) (length name))
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
144 (string= (substring str 0 (1+ (length name)))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
145 (concat name "\0")))))))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
146
93173
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
147 (defun vc-git--state-code (code)
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
148 "Convert from a string to a added/deleted/modified state."
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
149 (case (string-to-char code)
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
150 (?M 'edited)
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
151 (?A 'added)
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
152 (?D 'removed)
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
153 (?U 'edited) ;; FIXME
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
154 (?T 'edited))) ;; FIXME
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
155
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
156 (defun vc-git-state (file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
157 "Git-specific version of `vc-state'."
87450
71fc7b1db920 * vc-hooks.el (vc-state): Document new 'ignored and 'unregistered
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 87442
diff changeset
158 ;; FIXME: This can't set 'ignored yet
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
159 (vc-git--call nil "add" "--refresh" "--" (file-relative-name file))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
160 (let ((diff (vc-git--run-command-string file "diff-index" "-z" "HEAD" "--")))
93173
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
161 (if (and diff (string-match ":[0-7]\\{6\\} [0-7]\\{6\\} [0-9a-f]\\{40\\} [0-9a-f]\\{40\\} \\([ADMUT]\\)\0[^\0]+\0"
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
162 diff))
93173
019e6794fecf (vc-git-after-dir-status-stage1): Move state matching
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93146
diff changeset
163 (vc-git--state-code (match-string 1 diff))
93146
c73e70274c0c (vc-git--empty-db-p)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93145
diff changeset
164 (if (vc-git--empty-db-p) 'added 'up-to-date))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
165
87525
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
166 (defun vc-git--ls-files-state (state &rest args)
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
167 "Set state to STATE on all files found with git-ls-files ARGS."
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
168 (with-temp-buffer
87525
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
169 (apply 'vc-git-command (current-buffer) nil nil "ls-files" "-z" args)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
170 (goto-char (point-min))
87525
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
171 (let ((start (point)))
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
172 (while (search-forward "\0" nil t)
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
173 (let ((file (expand-file-name
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
174 (buffer-substring-no-properties start (1- (point))))))
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
175 (vc-file-setprop file 'vc-backend (if state 'Git 'none))
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
176 (vc-file-setprop file 'vc-state state))
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
177 (setq start (point))))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
178
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
179 (defun vc-git-dir-state (dir)
87450
71fc7b1db920 * vc-hooks.el (vc-state): Document new 'ignored and 'unregistered
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 87442
diff changeset
180 "Git-specific version of `dir-state'."
87525
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
181 (vc-git--ls-files-state 'up-to-date "-c")
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
182 (vc-git--ls-files-state 'edited "-m")
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
183 (vc-git--ls-files-state 'removed "-d")
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
184 (vc-git--ls-files-state 'ignored "-o" "-i" "--exclude-standard")
77d4b0e5e5d2 * vc-git.el (vc-git--ls-files-state): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87516
diff changeset
185 (vc-git--ls-files-state nil "-o" "--exclude-standard"))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
186
85139
8ba0e30716a5 Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 85114
diff changeset
187 (defun vc-git-working-revision (file)
8ba0e30716a5 Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 85114
diff changeset
188 "Git-specific version of `vc-working-revision'."
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
189 (let ((str (with-output-to-string
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
190 (with-current-buffer standard-output
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
191 (vc-git--out-ok "symbolic-ref" "HEAD")))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
192 (if (string-match "^\\(refs/heads/\\)?\\(.+\\)$" str)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
193 (match-string 2 str)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
194 str)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
195
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
196 (defun vc-git-checkout-model (file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
197 'implicit)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
198
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
199 (defun vc-git-workfile-unchanged-p (file)
78687
429a17d4958d * vc-git.el (vc-git-state): Call git-add --refresh to update the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78404
diff changeset
200 (eq 'up-to-date (vc-git-state file)))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
201
82843
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
202 (defun vc-git-mode-line-string (file)
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
203 "Return string for placement into the modeline for FILE."
85139
8ba0e30716a5 Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 85114
diff changeset
204 (let* ((branch (vc-git-working-revision file))
82843
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
205 (def-ml (vc-default-mode-line-string 'Git file))
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
206 (help-echo (get-text-property 0 'help-echo def-ml)))
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
207 (if (zerop (length branch))
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
208 (propertize
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
209 (concat def-ml "!")
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
210 'help-echo (concat help-echo "\nNo current branch (detached HEAD)"))
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
211 (propertize def-ml
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
212 'help-echo (concat help-echo "\nCurrent branch: " branch)))))
768766d373a7 * vc-git.el (vc-git-mode-line-string): New function.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 82245
diff changeset
213
93426
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
214 (defstruct (vc-git-extra-fileinfo
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
215 (:copier nil)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
216 (:constructor vc-git-create-extra-fileinfo (old-perm new-perm &optional rename-state orig-name))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
217 (:conc-name vc-git-extra-fileinfo->))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
218 old-perm new-perm ;; permission flags
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
219 rename-state ;; rename or copy state
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
220 orig-name) ;; original name for renames or copies
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
221
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
222 (defun vc-git-escape-file-name (name)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
223 "Escape a file name if necessary."
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
224 (if (string-match "[\n\t\"\\]" name)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
225 (concat "\""
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
226 (mapconcat (lambda (c)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
227 (case c
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
228 (?\n "\\n")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
229 (?\t "\\t")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
230 (?\\ "\\\\")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
231 (?\" "\\\"")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
232 (t (char-to-string c))))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
233 name "")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
234 "\"")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
235 name))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
236
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
237 (defun vc-git-file-type-as-string (old-perm new-perm)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
238 "Return a string describing the file type based on its permissions."
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
239 (let* ((old-type (lsh (or old-perm 0) -9))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
240 (new-type (lsh (or new-perm 0) -9))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
241 (str (case new-type
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
242 (?\100 ;; file
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
243 (case old-type
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
244 (?\100 nil)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
245 (?\120 " (type change symlink -> file)")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
246 (?\160 " (type change subproject -> file)")))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
247 (?\120 ;; symlink
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
248 (case old-type
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
249 (?\100 " (type change file -> symlink)")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
250 (?\160 " (type change subproject -> symlink)")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
251 (t " (symlink)")))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
252 (?\160 ;; subproject
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
253 (case old-type
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
254 (?\100 " (type change file -> subproject)")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
255 (?\120 " (type change symlink -> subproject)")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
256 (t " (subproject)")))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
257 (?\110 nil) ;; directory (internal, not a real git state)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
258 (?\000 ;; deleted or unknown
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
259 (case old-type
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
260 (?\120 " (symlink)")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
261 (?\160 " (subproject)")))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
262 (t (format " (unknown type %o)" new-type)))))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
263 (cond (str (propertize str 'face 'font-lock-comment-face))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
264 ((eq new-type ?\110) "/")
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
265 (t ""))))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
266
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
267 (defun vc-git-rename-as-string (state extra)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
268 "Return a string describing the copy or rename associated with INFO, or an empty string if none."
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
269 (let ((rename-state (when extra
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
270 (vc-git-extra-fileinfo->rename-state extra))))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
271 (if rename-state
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
272 (propertize
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
273 (concat " ("
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
274 (if (eq rename-state 'copy) "copied from "
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
275 (if (eq state 'added) "renamed from "
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
276 "renamed to "))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
277 (vc-git-escape-file-name (vc-git-extra-fileinfo->orig-name extra))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
278 ")") 'face 'font-lock-comment-face)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
279 "")))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
280
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
281 (defun vc-git-permissions-as-string (old-perm new-perm)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
282 "Format a permission change as string."
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
283 (propertize
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
284 (if (or (not old-perm)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
285 (not new-perm)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
286 (eq 0 (logand ?\111 (logxor old-perm new-perm))))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
287 " "
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
288 (if (eq 0 (logand ?\111 old-perm)) "+x" "-x"))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
289 'face 'font-lock-type-face))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
290
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
291 (defun vc-git-status-printer (info)
94107
5d2bbe3fd618 Rename vc-status to vc-dir.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94060
diff changeset
292 "Pretty-printer for the vc-dir-fileinfo structure."
94290
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
293 (let* ((state (if (vc-dir-fileinfo->directory info)
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
294 'DIRECTORY
55b13d307a7a (vc-git-status-printer): Deal with directories.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94107
diff changeset
295 (vc-dir-fileinfo->state info)))
94107
5d2bbe3fd618 Rename vc-status to vc-dir.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94060
diff changeset
296 (extra (vc-dir-fileinfo->extra info))
93426
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
297 (old-perm (when extra (vc-git-extra-fileinfo->old-perm extra)))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
298 (new-perm (when extra (vc-git-extra-fileinfo->new-perm extra))))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
299 (insert
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
300 " "
94107
5d2bbe3fd618 Rename vc-status to vc-dir.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94060
diff changeset
301 (propertize (format "%c" (if (vc-dir-fileinfo->marked info) ?* ? ))
93426
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
302 'face 'font-lock-type-face)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
303 " "
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
304 (propertize
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
305 (format "%-12s" state)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
306 'face (cond ((eq state 'up-to-date) 'font-lock-builtin-face)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
307 ((eq state 'missing) 'font-lock-warning-face)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
308 (t 'font-lock-variable-name-face))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
309 'mouse-face 'highlight)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
310 " " (vc-git-permissions-as-string old-perm new-perm)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
311 " "
94107
5d2bbe3fd618 Rename vc-status to vc-dir.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94060
diff changeset
312 (propertize (vc-git-escape-file-name (vc-dir-fileinfo->name info))
93426
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
313 'face 'font-lock-function-name-face
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
314 'mouse-face 'highlight)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
315 (vc-git-file-type-as-string old-perm new-perm)
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
316 (vc-git-rename-as-string state extra))))
912e50ecb992 * vc-git.el: Make vc-status display information about copies,
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93382
diff changeset
317
94060
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
318 (defun vc-git-after-dir-status-stage (stage files update-function)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
319 "Process sentinel for the various dir-status stages."
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
320 (let (remaining next-stage result)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
321 (goto-char (point-min))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
322 (case stage
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
323 ('update-index
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
324 (setq next-stage (if (vc-git--empty-db-p) 'ls-files-added
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
325 (if files 'ls-files-up-to-date 'diff-index))))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
326 ('ls-files-added
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
327 (setq next-stage 'ls-files-unknown)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
328 (while (re-search-forward "\\([0-7]\\{6\\}\\) [0-9a-f]\\{40\\} 0\t\\([^\0]+\\)\0" nil t)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
329 (let ((new-perm (string-to-number (match-string 1) 8))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
330 (name (match-string 2)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
331 (push (list name 'added (vc-git-create-extra-fileinfo 0 new-perm)) result))))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
332 ('ls-files-up-to-date
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
333 (setq next-stage 'diff-index)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
334 (while (re-search-forward "\\([0-7]\\{6\\}\\) [0-9a-f]\\{40\\} 0\t\\([^\0]+\\)\0" nil t)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
335 (let ((perm (string-to-number (match-string 1) 8))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
336 (name (match-string 2)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
337 (push (list name 'up-to-date (vc-git-create-extra-fileinfo perm perm)) result))))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
338 ('ls-files-unknown
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
339 (when files (setq next-stage 'ls-files-ignored))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
340 (while (re-search-forward "\\([^\0]*?\\)\0" nil t 1)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
341 (push (list (match-string 1) 'unregistered (vc-git-create-extra-fileinfo 0 0)) result)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
342 ('ls-files-ignored
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
343 (while (re-search-forward "\\([^\0]*?\\)\0" nil t 1)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
344 (push (list (match-string 1) 'ignored (vc-git-create-extra-fileinfo 0 0)) result)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
345 ('diff-index
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
346 (setq next-stage 'ls-files-unknown)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
347 (while (re-search-forward
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
348 ":\\([0-7]\\{6\\}\\) \\([0-7]\\{6\\}\\) [0-9a-f]\\{40\\} [0-9a-f]\\{40\\} \\(\\([ADMUT]\\)\0\\([^\0]+\\)\\|\\([CR]\\)[0-9]*\0\\([^\0]+\\)\0\\([^\0]+\\)\\)\0"
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
349 nil t 1)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
350 (let ((old-perm (string-to-number (match-string 1) 8))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
351 (new-perm (string-to-number (match-string 2) 8))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
352 (state (or (match-string 4) (match-string 6)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
353 (name (or (match-string 5) (match-string 7)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
354 (new-name (match-string 8)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
355 (if new-name ; copy or rename
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
356 (if (eq ?C (string-to-char state))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
357 (push (list new-name 'added (vc-git-create-extra-fileinfo old-perm new-perm 'copy name)) result)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
358 (push (list name 'removed (vc-git-create-extra-fileinfo 0 0 'rename new-name)) result)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
359 (push (list new-name 'added (vc-git-create-extra-fileinfo old-perm new-perm 'rename name)) result))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
360 (push (list name (vc-git--state-code state) (vc-git-create-extra-fileinfo old-perm new-perm)) result))))))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
361 (when result
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
362 (setq result (nreverse result))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
363 (when files
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
364 (dolist (entry result) (setq files (delete (car entry) files)))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
365 (unless files (setq next-stage nil))))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
366 (when (or result (not next-stage)) (funcall update-function result next-stage))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
367 (when next-stage (vc-git-dir-status-goto-stage next-stage files update-function))))
93123
38f18130d057 (vc-git-status-result): New variable.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93122
diff changeset
368
94060
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
369 (defun vc-git-dir-status-goto-stage (stage files update-function)
93123
38f18130d057 (vc-git-status-result): New variable.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93122
diff changeset
370 (erase-buffer)
94060
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
371 (case stage
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
372 ('update-index
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
373 (if files
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
374 (vc-git-command (current-buffer) 'async files "add" "--refresh" "--")
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
375 (vc-git-command (current-buffer) 'async nil "update-index" "--refresh")))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
376 ('ls-files-added
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
377 (vc-git-command (current-buffer) 'async files "ls-files" "-z" "-c" "-s" "--"))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
378 ('ls-files-up-to-date
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
379 (vc-git-command (current-buffer) 'async files "ls-files" "-z" "-c" "-s" "--"))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
380 ('ls-files-unknown
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
381 (vc-git-command (current-buffer) 'async files "ls-files" "-z" "-o"
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
382 "--directory" "--no-empty-directory" "--exclude-standard" "--"))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
383 ('ls-files-ignored
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
384 (vc-git-command (current-buffer) 'async files "ls-files" "-z" "-o" "-i"
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
385 "--directory" "--no-empty-directory" "--exclude-standard" "--"))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
386 ('diff-index
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
387 (vc-git-command (current-buffer) 'async files "diff-index" "-z" "-M" "HEAD" "--")))
93123
38f18130d057 (vc-git-status-result): New variable.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93122
diff changeset
388 (vc-exec-after
94060
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
389 `(vc-git-after-dir-status-stage (quote ,stage) (quote ,files) (quote ,update-function))))
93146
c73e70274c0c (vc-git--empty-db-p)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93145
diff changeset
390
94003
2ecb2ea8d5b5 Change `dir-status' to not take (and pass) status-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 93426
diff changeset
391 (defun vc-git-dir-status (dir update-function)
94060
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
392 "Return a list of (FILE STATE EXTRA) entries for DIR."
93122
ab6a0ec29e00 (vc-git-after-dir-status): Remove.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93118
diff changeset
393 ;; Further things that would have to be fixed later:
ab6a0ec29e00 (vc-git-after-dir-status): Remove.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93118
diff changeset
394 ;; - how to handle unregistered directories
94107
5d2bbe3fd618 Rename vc-status to vc-dir.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94060
diff changeset
395 ;; - how to support vc-dir on a subdir of the project tree
94060
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
396 (vc-git-dir-status-goto-stage 'update-index nil update-function))
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
397
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
398 (defun vc-git-dir-status-files (dir files default-state update-function)
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
399 "Return a list of (FILE STATE EXTRA) entries for FILES in DIR."
6c138603231c (vc-git-after-dir-status-stage)
Alexandre Julliard <julliard@winehq.org>
parents: 94003
diff changeset
400 (vc-git-dir-status-goto-stage 'update-index files update-function))
91929
3299b785d830 (vc-git-after-dir-status, vc-git-dir-status): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 87649
diff changeset
401
93333
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
402 (defun vc-git-status-extra-headers (dir)
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
403 (let ((str (with-output-to-string
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
404 (with-current-buffer standard-output
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
405 (vc-git--out-ok "symbolic-ref" "HEAD")))))
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
406 (concat
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
407 (propertize "Branch : " 'face 'font-lock-type-face)
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
408 (propertize
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
409 (if (string-match "^\\(refs/heads/\\)?\\(.+\\)$" str)
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
410 (match-string 2 str)
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
411 "not (detached HEAD)")
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
412 'face 'font-lock-variable-name-face))))
53eee5c271f4 * vc.el: Add new backend function 'status-extra-headers.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93240
diff changeset
413
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
414 ;;; STATE-CHANGING FUNCTIONS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
415
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
416 (defun vc-git-create-repo ()
78404
27f00e50116a Change capitalization of VC backend names for new backends
Miles Bader <miles@gnu.org>
parents: 78359
diff changeset
417 "Create a new Git repository."
78687
429a17d4958d * vc-git.el (vc-git-state): Call git-add --refresh to update the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78404
diff changeset
418 (vc-git-command nil 0 nil "init"))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
419
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
420 (defun vc-git-register (files &optional rev comment)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
421 "Register FILE into the git version-control system."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
422 (vc-git-command nil 0 files "update-index" "--add" "--"))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
423
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
424 (defalias 'vc-git-responsible-p 'vc-git-root)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
425
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
426 (defun vc-git-unregister (file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
427 (vc-git-command nil 0 file "rm" "-f" "--cached" "--"))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
428
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
429
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
430 (defun vc-git-checkin (files rev comment)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
431 (let ((coding-system-for-write git-commits-coding-system))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
432 (vc-git-command nil 0 files "commit" "-m" comment "--only" "--")))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
433
85139
8ba0e30716a5 Terminology cleanup.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 85114
diff changeset
434 (defun vc-git-find-revision (file rev buffer)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
435 (let ((coding-system-for-read 'binary)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
436 (coding-system-for-write 'binary)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
437 (fullname (substring
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
438 (vc-git--run-command-string
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
439 file "ls-files" "-z" "--full-name" "--")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
440 0 -1)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
441 (vc-git-command
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
442 buffer 0
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
443 (concat (if rev rev "HEAD") ":" fullname) "cat-file" "blob")))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
444
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
445 (defun vc-git-checkout (file &optional editable rev)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
446 (vc-git-command nil 0 file "checkout" (or rev "HEAD")))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
447
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
448 (defun vc-git-revert (file &optional contents-done)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
449 "Revert FILE to the version stored in the git repository."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
450 (if contents-done
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
451 (vc-git-command nil 0 file "update-index" "--")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
452 (vc-git-command nil 0 file "checkout" "HEAD")))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
453
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
454 ;;; HISTORY FUNCTIONS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
455
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
456 (defun vc-git-print-log (files &optional buffer)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
457 "Get change log associated with FILES."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
458 (let ((coding-system-for-read git-commits-coding-system)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
459 ;; Support both the old print-log interface that passes a
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
460 ;; single file, and the new one that passes a file list.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
461 (flist (if (listp files) files (list files))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
462 ;; `vc-do-command' creates the buffer, but we need it before running
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
463 ;; the command.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
464 (vc-setup-buffer buffer)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
465 ;; If the buffer exists from a previous invocation it might be
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
466 ;; read-only.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
467 (let ((inhibit-read-only t))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
468 ;; XXX `log-view-mode' needs to have something to identify where
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
469 ;; the log for each individual file starts. It seems that by
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
470 ;; default git does not output this info. So loop here and call
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
471 ;; "git rev-list" on each file separately to make sure that each
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
472 ;; file gets a "File:" header before the corresponding
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
473 ;; log. Maybe there is a way to do this with one command...
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
474 (dolist (file flist)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
475 (with-current-buffer
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
476 buffer
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
477 (insert "File: " (file-name-nondirectory file) "\n"))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
478 (vc-git-command buffer 'async (file-relative-name file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
479 "rev-list" "--pretty" "HEAD" "--")))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
480
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
481 (defvar log-view-message-re)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
482 (defvar log-view-file-re)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
483 (defvar log-view-font-lock-keywords)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
484
78404
27f00e50116a Change capitalization of VC backend names for new backends
Miles Bader <miles@gnu.org>
parents: 78359
diff changeset
485 (define-derived-mode vc-git-log-view-mode log-view-mode "Git-Log-View"
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
486 (require 'add-log) ;; we need the faces add-log
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
487 ;; Don't have file markers, so use impossible regexp.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
488 (set (make-local-variable 'log-view-file-re) "^File:[ \t]+\\(.+\\)")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
489 (set (make-local-variable 'log-view-message-re)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
490 "^commit *\\([0-9a-z]+\\)")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
491 (set (make-local-variable 'log-view-font-lock-keywords)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
492 (append
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
493 `((,log-view-message-re (1 'change-log-acknowledgement))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
494 (,log-view-file-re (1 'change-log-file-face)))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
495 ;; Handle the case:
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
496 ;; user: foo@bar
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
497 '(("^Author:[ \t]+\\([A-Za-z0-9_.+-]+@[A-Za-z0-9_.-]+\\)"
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
498 (1 'change-log-email))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
499 ;; Handle the case:
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
500 ;; user: FirstName LastName <foo@bar>
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
501 ("^Author:[ \t]+\\([^<(]+?\\)[ \t]*[(<]\\([A-Za-z0-9_.+-]+@[A-Za-z0-9_.-]+\\)[>)]"
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
502 (1 'change-log-name)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
503 (2 'change-log-email))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
504 ("^ +\\(?:\\(?:[Aa]cked\\|[Ss]igned-[Oo]ff\\)-[Bb]y:\\)[ \t]+\\([A-Za-z0-9_.+-]+@[A-Za-z0-9_.-]+\\)"
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
505 (1 'change-log-name))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
506 ("^ +\\(?:\\(?:[Aa]cked\\|[Ss]igned-[Oo]ff\\)-[Bb]y:\\)[ \t]+\\([^<(]+?\\)[ \t]*[(<]\\([A-Za-z0-9_.+-]+@[A-Za-z0-9_.-]+\\)[>)]"
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
507 (1 'change-log-name)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
508 (2 'change-log-email))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
509 ("^Merge: \\([0-9a-z]+\\) \\([0-9a-z]+\\)"
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
510 (1 'change-log-acknowledgement)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
511 (2 'change-log-acknowledgement))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
512 ("^Date: \\(.+\\)" (1 'change-log-date))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
513 ("^summary:[ \t]+\\(.+\\)" (1 'log-view-message))))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
514
86397
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
515 (defun vc-git-show-log-entry (revision)
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
516 "Move to the log entry for REVISION.
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
517 REVISION may have the form BRANCH, BRANCH~N,
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
518 or BRANCH^ (where \"^\" can be repeated)."
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
519 (goto-char (point-min))
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
520 (search-forward "\ncommit" nil t
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
521 (cond ((string-match "~\\([0-9]\\)$" revision)
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
522 (1+ (string-to-number (match-string 1 revision))))
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
523 ((string-match "\\^+$" revision)
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
524 (1+ (length (match-string 0 revision))))
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
525 (t nil)))
38193bd1ab69 (vc-git-show-log-entry): New func.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 85462
diff changeset
526 (beginning-of-line))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
527
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
528 (defun vc-git-diff (files &optional rev1 rev2 buffer)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
529 (let ((buf (or buffer "*vc-diff*")))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
530 (if (and rev1 rev2)
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
531 (vc-git-command buf 1 files "diff-tree" "--exit-code" "-p"
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
532 rev1 rev2 "--")
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
533 (vc-git-command buf 1 files "diff-index" "--exit-code" "-p"
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
534 (or rev1 "HEAD") "--"))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
535
85459
dec6fdd5ddf4 (vc-git-revision-completion-table, vc-git-revision-table):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 85141
diff changeset
536 (defun vc-git-revision-table (files)
dec6fdd5ddf4 (vc-git-revision-completion-table, vc-git-revision-table):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 85141
diff changeset
537 ;; What about `files'?!? --Stef
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
538 (let ((table (list "HEAD")))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
539 (with-temp-buffer
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
540 (vc-git-command t nil nil "for-each-ref" "--format=%(refname)")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
541 (goto-char (point-min))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
542 (while (re-search-forward "^refs/\\(heads\\|tags\\)/\\(.*\\)$" nil t)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
543 (push (match-string 2) table)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
544 table))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
545
85459
dec6fdd5ddf4 (vc-git-revision-completion-table, vc-git-revision-table):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 85141
diff changeset
546 (defun vc-git-revision-completion-table (files)
dec6fdd5ddf4 (vc-git-revision-completion-table, vc-git-revision-table):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 85141
diff changeset
547 (lexical-let ((files files)
78359
2dd5d799a16d * vc-git.el: (vc-directory-exclusion-list, vc-handled-backends):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78356
diff changeset
548 table)
2dd5d799a16d * vc-git.el: (vc-directory-exclusion-list, vc-handled-backends):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78356
diff changeset
549 (setq table (lazy-completion-table
85459
dec6fdd5ddf4 (vc-git-revision-completion-table, vc-git-revision-table):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 85141
diff changeset
550 table (lambda () (vc-git-revision-table files))))
78359
2dd5d799a16d * vc-git.el: (vc-directory-exclusion-list, vc-handled-backends):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78356
diff changeset
551 table))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
552
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
553 (defun vc-git-annotate-command (file buf &optional rev)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
554 ;; FIXME: rev is ignored
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
555 (let ((name (file-relative-name file)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
556 (vc-git-command buf 0 name "blame" (if rev (concat "-r" rev)))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
557
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
558 (defun vc-git-annotate-time ()
86422
68e2cdfcf931 (vc-git-annotate-time): Handle optional field FILENAME.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86403
diff changeset
559 (and (re-search-forward "[0-9a-f]+[^()]+(.* \\([0-9]+\\)-\\([0-9]+\\)-\\([0-9]+\\) \\([0-9]+\\):\\([0-9]+\\):\\([0-9]+\\) \\([-+0-9]+\\) +[0-9]+) " nil t)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
560 (vc-annotate-convert-time
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
561 (apply #'encode-time (mapcar (lambda (match)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
562 (string-to-number (match-string match)))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
563 '(6 5 4 3 2 1 7))))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
564
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
565 (defun vc-git-annotate-extract-revision-at-line ()
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
566 (save-excursion
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
567 (move-beginning-of-line 1)
93145
9a34bf3a4363 (vc-git-annotate-extract-revision-at-line):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93124
diff changeset
568 (and (looking-at "[0-9a-f^][0-9a-f]+")
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
569 (buffer-substring-no-properties (match-beginning 0) (match-end 0)))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
570
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
571 ;;; SNAPSHOT SYSTEM
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
572
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
573 (defun vc-git-create-snapshot (dir name branchp)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
574 (let ((default-directory dir))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
575 (and (vc-git-command nil 0 nil "update-index" "--refresh")
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
576 (if branchp
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
577 (vc-git-command nil 0 nil "checkout" "-b" name)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
578 (vc-git-command nil 0 nil "tag" name)))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
579
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
580 (defun vc-git-retrieve-snapshot (dir name update)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
581 (let ((default-directory dir))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
582 (vc-git-command nil 0 nil "checkout" name)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
583 ;; FIXME: update buffers if `update' is true
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
584 ))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
585
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
586
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
587 ;;; MISCELLANEOUS
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
588
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
589 (defun vc-git-previous-revision (file rev)
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
590 "Git-specific version of `vc-previous-revision'."
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
591 (let ((default-directory (file-name-directory (expand-file-name file)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
592 (file (file-name-nondirectory file)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
593 (vc-git-symbolic-commit
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
594 (with-temp-buffer
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
595 (and
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
596 (vc-git--out-ok "rev-list" "-2" rev "--" file)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
597 (goto-char (point-max))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
598 (bolp)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
599 (zerop (forward-line -1))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
600 (not (bobp))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
601 (buffer-substring-no-properties
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
602 (point)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
603 (1- (point-max))))))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
604
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
605 (defun vc-git-next-revision (file rev)
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
606 "Git-specific version of `vc-next-revision'."
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
607 (let* ((default-directory (file-name-directory
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
608 (expand-file-name file)))
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
609 (file (file-name-nondirectory file))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
610 (current-rev
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
611 (with-temp-buffer
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
612 (and
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
613 (vc-git--out-ok "rev-list" "-1" rev "--" file)
86400
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
614 (goto-char (point-max))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
615 (bolp)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
616 (zerop (forward-line -1))
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
617 (bobp)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
618 (buffer-substring-no-properties
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
619 (point)
fdd891feb624 Refill; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86397
diff changeset
620 (1- (point-max)))))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
621 (and current-rev
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
622 (vc-git-symbolic-commit
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
623 (with-temp-buffer
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
624 (and
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
625 (vc-git--out-ok "rev-list" "HEAD" "--" file)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
626 (goto-char (point-min))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
627 (search-forward current-rev nil t)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
628 (zerop (forward-line -1))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
629 (buffer-substring-no-properties
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
630 (point)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
631 (progn (forward-line 1) (1- (point))))))))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
632
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
633 (defun vc-git-delete-file (file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
634 (vc-git-command nil 0 file "rm" "-f" "--"))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
635
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
636 (defun vc-git-rename-file (old new)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
637 (vc-git-command nil 0 (list old new) "mv" "-f" "--"))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
638
93240
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
639 (defvar vc-git-extra-menu-map
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
640 (let ((map (make-sparse-keymap)))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
641 (define-key map [git-grep]
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
642 '(menu-item "Git grep..." vc-git-grep
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
643 :help "Run the `git grep' command"))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
644 map))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
645
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
646 (defun vc-git-extra-menu () vc-git-extra-menu-map)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
647
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
648 (defun vc-git-extra-status-menu () vc-git-extra-menu-map)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
649
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
650 ;; Derived from `lgrep'.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
651 (defun vc-git-grep (regexp &optional files dir)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
652 "Run git grep, searching for REGEXP in FILES in directory DIR.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
653 The search is limited to file names matching shell pattern FILES.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
654 FILES may use abbreviations defined in `grep-files-aliases', e.g.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
655 entering `ch' is equivalent to `*.[ch]'.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
656
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
657 With \\[universal-argument] prefix, you can edit the constructed shell command line
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
658 before it is executed.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
659 With two \\[universal-argument] prefixes, directly edit and run `grep-command'.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
660
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
661 Collect output in a buffer. While git grep runs asynchronously, you
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
662 can use \\[next-error] (M-x next-error), or \\<grep-mode-map>\\[compile-goto-error] \
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
663 in the grep output buffer,
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
664 to go to the lines where grep found matches.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
665
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
666 This command shares argument histories with \\[rgrep] and \\[grep]."
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
667 (interactive
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
668 (progn
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
669 (grep-compute-defaults)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
670 (cond
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
671 ((equal current-prefix-arg '(16))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
672 (list (read-from-minibuffer "Run: " "git grep"
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
673 nil nil 'grep-history)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
674 nil))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
675 (t (let* ((regexp (grep-read-regexp))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
676 (files (grep-read-files regexp))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
677 (dir (read-directory-name "In directory: "
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
678 nil default-directory t)))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
679 (list regexp files dir))))))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
680 (require 'grep)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
681 (when (and (stringp regexp) (> (length regexp) 0))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
682 (let ((command regexp))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
683 (if (null files)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
684 (if (string= command "git grep")
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
685 (setq command nil))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
686 (setq dir (file-name-as-directory (expand-file-name dir)))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
687 (setq command
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
688 (grep-expand-template "git grep -n -e <R> -- <F>" regexp files))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
689 (when command
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
690 (if (equal current-prefix-arg '(4))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
691 (setq command
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
692 (read-from-minibuffer "Confirm: "
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
693 command nil nil 'grep-history))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
694 (add-to-history 'grep-history command))))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
695 (when command
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
696 (let ((default-directory dir)
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
697 (compilation-environment '("PAGER=")))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
698 ;; Setting process-setup-function makes exit-message-function work
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
699 ;; even when async processes aren't supported.
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
700 (compilation-start command 'grep-mode))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
701 (if (eq next-error-last-buffer (current-buffer))
231f72336aed (vc-git-extra-menu-map): New key map.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93173
diff changeset
702 (setq default-directory dir))))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
703
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
704 ;;; Internal commands
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
705
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
706 (defun vc-git-root (file)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
707 (vc-find-root file ".git"))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
708
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
709 (defun vc-git-command (buffer okstatus file-or-list &rest flags)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
710 "A wrapper around `vc-do-command' for use in vc-git.el.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
711 The difference to vc-do-command is that this function always invokes `git'."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
712 (apply 'vc-do-command buffer okstatus "git" file-or-list flags))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
713
93146
c73e70274c0c (vc-git--empty-db-p)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93145
diff changeset
714 (defun vc-git--empty-db-p ()
c73e70274c0c (vc-git--empty-db-p)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93145
diff changeset
715 "Check if the git db is empty (no commit done yet)."
c73e70274c0c (vc-git--empty-db-p)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93145
diff changeset
716 (not (eq 0 (vc-git--call nil "rev-parse" "--verify" "HEAD"))))
c73e70274c0c (vc-git--empty-db-p)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 93145
diff changeset
717
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
718 (defun vc-git--call (buffer command &rest args)
87648
7ae99e295dfd * vc-git.el (vc-git--call): Apply `process-file' instead of
Michael Albinus <michael.albinus@gmx.de>
parents: 87525
diff changeset
719 ;; We don't need to care the arguments. If there is a file name, it
7ae99e295dfd * vc-git.el (vc-git--call): Apply `process-file' instead of
Michael Albinus <michael.albinus@gmx.de>
parents: 87525
diff changeset
720 ;; is always a relative one. This works also for remote
7ae99e295dfd * vc-git.el (vc-git--call): Apply `process-file' instead of
Michael Albinus <michael.albinus@gmx.de>
parents: 87525
diff changeset
721 ;; directories.
7ae99e295dfd * vc-git.el (vc-git--call): Apply `process-file' instead of
Michael Albinus <michael.albinus@gmx.de>
parents: 87525
diff changeset
722 (apply 'process-file "git" nil buffer nil command args))
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
723
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
724 (defun vc-git--out-ok (command &rest args)
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
725 (zerop (apply 'vc-git--call '(t nil) command args)))
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
726
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
727 (defun vc-git--run-command-string (file &rest args)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
728 "Run a git command on FILE and return its output as string."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
729 (let* ((ok t)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
730 (str (with-output-to-string
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
731 (with-current-buffer standard-output
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
732 (unless (apply 'vc-git--out-ok
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
733 (append args (list (file-relative-name
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
734 file))))
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
735 (setq ok nil))))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
736 (and ok str)))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
737
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
738 (defun vc-git-symbolic-commit (commit)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
739 "Translate COMMIT string into symbolic form.
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
740 Returns nil if not possible."
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
741 (and commit
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
742 (with-temp-buffer
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
743 (and
86403
d2c8f5a27761 (vc-git--call, vc-git--out-ok): New funcs.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 86400
diff changeset
744 (vc-git--out-ok "name-rev" "--name-only" "--tags" commit)
78355
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
745 (goto-char (point-min))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
746 (= (forward-line 2) 1)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
747 (bolp)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
748 (buffer-substring-no-properties (point-min) (1- (point-max)))))))
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
749
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
750 (provide 'vc-git)
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
751
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
752 ;; arch-tag: bd10664a-0e5b-48f5-a877-6c17b135be12
c6e2dfb349be New File.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
diff changeset
753 ;;; vc-git.el ends here