From 360cf7bc8899964e8699550eb3d755909f4af606 Mon Sep 17 00:00:00 2001 From: Stefan Monnier Date: Thu, 28 Jun 2007 02:01:54 +0000 Subject: [PATCH] (vc-functions): Clear up the cache when reloading the file. (vc-bzr-workfile-version, vc-bzr-could-register): Don't hardcode point-min == 1. --- lisp/ChangeLog | 10 ++++++++-- lisp/vc-bzr.el | 20 +++++++++++++------- 2 files changed, 21 insertions(+), 9 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index c20c546db3c..e7b0dee39e1 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,7 +1,13 @@ +2007-06-28 Stefan Monnier + + * vc-bzr.el (vc-functions): Clear up the cache when reloading the file. + (vc-bzr-workfile-version, vc-bzr-could-register): Don't hardcode + point-min == 1. + 2007-06-28 Nick Roberts - * pcvs-util.el (cvs-strings->string, cvs-string->strings): Rename - and move to... + * pcvs-util.el (cvs-strings->string, cvs-string->strings): + Rename and move to... * subr.el (strings->string, string->strings): ...here. diff --git a/lisp/vc-bzr.el b/lisp/vc-bzr.el index b6a432970b0..23ce0d9c17a 100644 --- a/lisp/vc-bzr.el +++ b/lisp/vc-bzr.el @@ -61,6 +61,10 @@ (require 'cl) (require 'vc)) ; for vc-exec-after +;; Clear up the cache to force vc-call to check again and discover +;; new functions when we reload this file. +(put 'BZR 'vc-functions nil) + (defgroup vc-bzr nil "VC bzr backend." ;; :version "22" @@ -194,15 +198,15 @@ Return nil if there isn't one." ;; the file to be up-to-date. (goto-char (point-min)) (when - (re-search-forward - (concat "^\\(" vc-bzr-state-words "\\):[ \t\n]+" + (re-search-forward + (concat "^\\(" vc-bzr-state-words "\\):[ \t\n]+" (file-name-nondirectory file) "[ \t\n]*$") (point-max) t) (let ((start (match-beginning 0)) (end (match-end 0))) (goto-char start) (setq state - (cond + (cond ((not (equal ret 0)) nil) ((looking-at "added\\|renamed\\|modified\\|removed") 'edited) ((looking-at "unknown\\|ignored") nil))) @@ -216,7 +220,7 @@ Return nil if there isn't one." ;; left in the buffer after removing the above status ;; keywords, let us just presume that any other message from ;; "bzr" is a user warning, and display it. - (message "Warnings in `bzr' output: %s" + (message "Warnings in `bzr' output: %s" (buffer-substring (point-min) (point-max)))) (when state (vc-file-setprop file 'vc-workfile-version @@ -228,10 +232,12 @@ Return nil if there isn't one." (eq 'up-to-date (vc-bzr-state file))) (defun vc-bzr-workfile-version (file) + ;; Looks like this could be obtained via counting lines in + ;; .bzr/branch/revision-history. (with-temp-buffer (vc-bzr-command "revno" t 0 file) - (goto-char 1) - (buffer-substring 1 (line-end-position)))) + (goto-char (point-min)) + (buffer-substring (point) (line-end-position)))) (defun vc-bzr-checkout-model (file) 'implicit) @@ -258,7 +264,7 @@ or a superior directory.") (vc-bzr-command "add" t 0 file "--dry-run") ;; The command succeeds with no output if file is ;; registered (in bzr 0.8). - (goto-char 1) + (goto-char (point-min)) (looking-at "added ")) (error)))) -- 2.39.2