# HG changeset patch # User Dan Nicolaescu # Date 1205771113 0 # Node ID 5f4eb3149e6d10d6185dfd29f87a287e4f0a8966 # Parent a155e008f7c701aec96d3cd720f073bca85747ca * vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status): New functions to implement vc-status support. * vc.el (vc-default-extra-status-menu) (vc-add-to-vc-status-buffer): New functions. diff -r a155e008f7c7 -r 5f4eb3149e6d lisp/ChangeLog --- a/lisp/ChangeLog Mon Mar 17 16:19:05 2008 +0000 +++ b/lisp/ChangeLog Mon Mar 17 16:25:13 2008 +0000 @@ -1,5 +1,11 @@ 2008-03-17 Dan Nicolaescu + * vc-bzr.el (vc-bzr-dir-status, vc-bzr-after-dir-status): + New functions to implement vc-status support. + + * vc.el (vc-default-extra-status-menu) + (vc-add-to-vc-status-buffer): New functions. + * emacs-lisp/lisp-mode.el (emacs-lisp-mode-map): Add menu entries for eldoc and ielm. diff -r a155e008f7c7 -r 5f4eb3149e6d lisp/vc-bzr.el --- a/lisp/vc-bzr.el Mon Mar 17 16:19:05 2008 +0000 +++ b/lisp/vc-bzr.el Mon Mar 17 16:25:13 2008 +0000 @@ -464,45 +464,26 @@ Each line is tagged with the revision number, which has a `help-echo' property containing author and date information." (apply #'vc-bzr-command "annotate" buffer 0 file "--long" "--all" - (if revision (list "-r" revision))) - (with-current-buffer buffer - ;; Store the tags for the annotated source lines in a hash table - ;; to allow saving space by sharing the text properties. - (setq vc-bzr-annotation-table (make-hash-table :test 'equal)) - (goto-char (point-min)) - (while (re-search-forward "^\\( *[0-9]+\\) +\\(.+\\) +\\([0-9]\\{8\\}\\) |" - nil t) - (let* ((rev (match-string 1)) - (author (match-string 2)) - (date (match-string 3)) - (key (match-string 0)) - (tag (gethash key vc-bzr-annotation-table))) - (unless tag - (setq tag (propertize rev 'help-echo (concat "Author: " author - ", date: " date) - 'mouse-face 'highlight)) - (puthash key tag vc-bzr-annotation-table)) - (replace-match "") - (insert tag " |"))))) + (when revision (list "-r" revision)))) (defun vc-bzr-annotate-time () - (when (re-search-forward "^ *[0-9]+ |" nil t) - (let ((prop (get-text-property (line-beginning-position) 'help-echo))) - (string-match "[0-9]+\\'" prop) + (when (re-search-forward "^[0-9]+.* \\([0-9]+ | \\)" nil t) + (goto-char (match-end 1)) + (let ((str (buffer-substring-no-properties + (match-beginning 1) (match-end 1)))) (vc-annotate-convert-time (encode-time 0 0 0 - (string-to-number (substring (match-string 0 prop) 6 8)) - (string-to-number (substring (match-string 0 prop) 4 6)) - (string-to-number (substring (match-string 0 prop) 0 4)) - ))))) + (string-to-number (substring str 6 8)) + (string-to-number (substring str 4 6)) + (string-to-number (substring str 0 4))))))) (defun vc-bzr-annotate-extract-revision-at-line () "Return revision for current line of annoation buffer, or nil. Return nil if current line isn't annotated." (save-excursion (beginning-of-line) - (if (looking-at " *\\([0-9]+\\) | ") - (match-string-no-properties 1)))) + (when (looking-at "\\([0-9.]+\\) ") + (match-string-no-properties 1)))) (defun vc-bzr-command-discarding-stderr (command &rest args) "Execute shell command COMMAND (with ARGS); return its output and exitcode. @@ -608,6 +589,47 @@ ;; else fall back to default vc.el representation (vc-default-dired-state-info 'Bzr file))) +;; XXX Experimental function for the vc-dired replacement. +;; XXX: this needs testing, it's probably incomplete. +(defun vc-bzr-after-dir-status (update-function status-buffer) + (let ((status-str nil) + (file nil) + (translation '(("+N" . added) + ("-D" . removed) + (" M" . edited) + ;; XXX: what about ignored files? + (" D" . deleted) + ("? " . unregistered))) + (translated nil) + (result nil)) + (goto-char (point-min)) + (while (not (eobp)) + (setq status-str + (buffer-substring-no-properties (point) (+ (point) 2))) + (setq file + (buffer-substring-no-properties (+ (point) 4) + (line-end-position))) + (setq translated (assoc status-str translation)) + (push (cons file (cdr translated)) result) + (forward-line)) + ;; Remove the temporary buffer. + (kill-buffer (current-buffer)) + (funcall update-function result status-buffer))) + +;; XXX Experimental function for the vc-dired replacement. +;; XXX This probably needs some further refinement and testing. +(defun vc-bzr-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-bzr* tmp status" dir)) + (erase-buffer) + ;; XXX: Is this the right command to use? + (vc-bzr-command "status" (current-buffer) 'async dir "-v" "-S") + (vc-exec-after + `(vc-bzr-after-dir-status (quote ,update-function) ,status-buffer)) + (current-buffer))) + ;;; Revision completion (defun vc-bzr-complete-with-prefix (prefix action table string pred) diff -r a155e008f7c7 -r 5f4eb3149e6d lisp/vc.el --- a/lisp/vc.el Mon Mar 17 16:19:05 2008 +0000 +++ b/lisp/vc.el Mon Mar 17 16:25:13 2008 +0000 @@ -2800,6 +2800,9 @@ map) "Keymap for VC status") +(defun vc-default-extra-status-menu (backend) + nil) + (defun vc-status-menu-map-filter (orig-binding) (if (boundp 'vc-ignore-menu-filter) orig-binding @@ -2889,6 +2892,29 @@ ;; We are done, turn of the in progress message in the mode-line. (setq mode-line-process nil))) +(defun vc-add-to-vc-status-buffer (entry buffer) + ;; Add one ENTRY to the vc-status buffer BUFFER. + ;; This will be used to automatically add files with the "modified" + ;; state when saving them. + + ;; ENTRY is (FILENAME . STATE) + (with-current-buffer buffer + (let ((crt (ewoc-nth vc-status 0)) + (fname (car entry))) + ;; First try to see if there's already an entry with that name + ;; in the ewoc. + (while (and crt (not (string= (vc-status-fileinfo->name + (ewoc-data crt)) fname))) + (setq crt (ewoc-next vc-status crt))) + (if crt + (progn + ;; Found the file, just update the status. + (setf (vc-status-fileinfo->state (ewoc-data crt)) (cdr entry)) + (ewoc-invalidate vc-status crt)) + ;; Could not find the file, insert a new entry. + (ewoc-enter-last + vc-status (vc-status-create-fileinfo (cdr entry) (car entry))))))) + (defun vc-status-refresh () "Refresh the contents of the VC status buffer." (interactive)