From: Eric S. Raymond Date: Wed, 2 Jan 2008 00:42:37 +0000 (+0000) Subject: * vc-svn.el (vc-svn-modify-change comment): New function. X-Git-Tag: emacs-pretest-23.0.90~8742 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=42a0a13593c252378b8d6eecd97b7971ebd6808a;p=emacs.git * vc-svn.el (vc-svn-modify-change comment): New function. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 5589f73a817..ac027b954c2 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,7 @@ +2008-01-02 Eric S. Raymond + + * vc-svn.el (vc-svn-modify-change comment): New function. + 2008-01-01 Dan Nicolaescu * vc-git.el (vc-git-dir-state): Set the vc-backend property. Do diff --git a/lisp/vc-svn.el b/lisp/vc-svn.el index 923613f5b04..385260b3d87 100644 --- a/lisp/vc-svn.el +++ b/lisp/vc-svn.el @@ -366,6 +366,30 @@ The changes are between FIRST-VERSION and SECOND-VERSION." (error "Couldn't analyze svn update result"))) (message "Merging changes into %s...done" file)))) +(defun vc-svn-modify-change-comment (files rev comment) + "Modify the change comments for a specified REV. +You must have ssh access to the repository host, and the directory Emacs +uses locally for temp files must also be writeable by you on that host." + (vc-do-command nil 0 "svn" nil "info") + (set-buffer "*vc*") + (goto-char (point-min)) + (unless (re-search-forward "Repository Root: svn\\+ssh://\\([^/]+\\)\\(/.*\\)" nil t) + (error "Repository information is unavailable.")) + (let* ((tempfile (make-temp-file user-mail-address)) + (host (match-string 1)) + (directory (match-string 2)) + (remotefile (concat host ":" tempfile))) + (with-temp-buffer + (insert comment) + (write-region (point-min) (point-max) tempfile)) + (unless (vc-do-command nil 0 "scp" nil "-q" tempfile remotefile) + (error "Copy of comment to %s failed" remotefile)) + (unless (vc-do-command nil 0 "ssh" nil + "-q" host + (format "svnadmin setlog --bypass-hooks %s -r %s %s; rm %s" + directory rev tempfile tempfile)) + (error "Log edit failed")) + )) ;;; ;;; History functions