]> git.eshelyaron.com Git - emacs.git/commitdiff
(vc-git-after-dir-status, vc-git-dir-status): New funcs.
authorThien-Thi Nguyen <ttn@gnuvola.org>
Mon, 18 Feb 2008 07:46:44 +0000 (07:46 +0000)
committerThien-Thi Nguyen <ttn@gnuvola.org>
Mon, 18 Feb 2008 07:46:44 +0000 (07:46 +0000)
lisp/ChangeLog
lisp/vc-git.el

index ee3be593fb26ce7d0eac3a9ba26ccb6d45ff29d9..0092c50471faf97a825076e4ac5ca3254f9d058c 100644 (file)
@@ -1,3 +1,7 @@
+2008-02-18  Thien-Thi Nguyen  <ttn@gnuvola.org>
+
+       * vc-git.el (vc-git-after-dir-status, vc-git-dir-status): New funcs.
+
 2008-02-18  Stefan Monnier  <monnier@iro.umontreal.ca>
 
        * image-mode.el (image-get-display-property): New fun.
index 7920fec0289083644e1131904d1f6143aa5589c9..c8c63a22181535f0d48ea1ec250a8a66e3c77b4d 100644 (file)
       ;; fall back to the default VC representation
       (vc-default-dired-state-info 'Git file))))
 
+;;; vc-dir-status support (EXPERIMENTAL)
+;;; If vc-directory (which is not half bad under Git, w/ some tweaking)
+;;; is to go away, vc-dir-status must at least support the same operations.
+;;; At the moment, vc-dir-status design is still fluid (a kind way to say
+;;; half-baked, undocumented, and spottily-supported), so the following
+;;; should be considered likewise ripe for sudden unannounced change.
+;;; YHBW, HAND.  --ttn
+
+(defun vc-git-after-dir-status (callback buffer)
+  (sort-regexp-fields t "^. \\(.+\\)$" "\\1" (point-min) (point-max))
+  (let ((map '((?H . cached)
+               (?M . unmerged)
+               (?R . removed)
+               (?C . edited)
+               (?K . removed)           ; ??? "to be killed"
+               (?? . unregistered)))
+        status filename result)
+    (goto-char (point-min))
+    (while (> (point-max) (point))
+      (setq status (string-to-char (buffer-substring (point) (1+ (point))))
+            status (cdr (assq status map))
+            filename (buffer-substring (+ 2 (point)) (line-end-position)))
+      ;; TODO: Add dynamic selection of which status(es) to display, and
+      ;; bubble that up to vc-dir-status.  For now, we consider `cached'
+      ;; to be uninteresting, to mimic vc-directory (somewhat).
+      (unless (eq 'cached status)
+        (push (cons filename status) result))
+      (forward-line 1))
+    (funcall callback result buffer)))
+
+(defun vc-git-dir-status (dir update-function status-buffer)
+  "Return a list of conses (file . state) for DIR."
+  (with-current-buffer
+      (get-buffer-create
+       (expand-file-name " *VC-Git* tmp status" dir))
+    (erase-buffer)
+    (vc-git-command (current-buffer) 'async dir "ls-files" "-t"
+                    "-c"                ; cached
+                    "-d"                ; deleted
+                    "-k"                ; killed
+                    "-m"                ; modified
+                    "-o"                ; others
+                    "--directory"
+                    "--exclude-per-directory=.gitignore")
+    (vc-exec-after
+     `(vc-git-after-dir-status (quote ,update-function) ,status-buffer))))
+
 ;;; STATE-CHANGING FUNCTIONS
 
 (defun vc-git-create-repo ()