From: Gabriel do Nascimento Ribeiro Date: Thu, 17 Nov 2022 00:59:17 +0000 (-0300) Subject: Handle error in bookmark-relocate when filename is nil X-Git-Tag: emacs-29.0.90~1616^2~20 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=fbad9c05ea1066c0ae48d40eca782bd406e4c42d;p=emacs.git Handle error in bookmark-relocate when filename is nil * lisp/bookmark.el (bookmark-relocate): Handle error when filename is nil. (Bug#59326) --- diff --git a/lisp/bookmark.el b/lisp/bookmark.el index 15e7273f917..7f3a264f53d 100644 --- a/lisp/bookmark.el +++ b/lisp/bookmark.el @@ -1396,20 +1396,25 @@ after a bookmark was set in it." (interactive (list (bookmark-completing-read "Bookmark to relocate"))) (bookmark-maybe-historicize-string bookmark-name) (bookmark-maybe-load-default-file) - (let* ((bmrk-filename (bookmark-get-filename bookmark-name)) - (newloc (abbreviate-file-name - (expand-file-name - (read-file-name - (format "Relocate %s to: " bookmark-name) - (file-name-directory bmrk-filename)))))) - (bookmark-set-filename bookmark-name newloc) - (bookmark-update-last-modified bookmark-name) - (setq bookmark-alist-modification-count - (1+ bookmark-alist-modification-count)) - (if (bookmark-time-to-save-p) + (let ((bmrk-filename (bookmark-get-filename bookmark-name))) + ;; FIXME: Make `bookmark-relocate' support bookmark Types + ;; besides files and directories. + (unless bmrk-filename + (user-error "Cannot relocate bookmark of type \"%s\"" + (bookmark-type-from-full-record + (bookmark-get-bookmark bookmark-name)))) + (let ((newloc (abbreviate-file-name + (expand-file-name + (read-file-name + (format "Relocate %s to: " bookmark-name) + (file-name-directory bmrk-filename)))))) + (bookmark-set-filename bookmark-name newloc) + (bookmark-update-last-modified bookmark-name) + (setq bookmark-alist-modification-count + (1+ bookmark-alist-modification-count)) + (when (bookmark-time-to-save-p) (bookmark-save)) - (bookmark-bmenu-surreptitiously-rebuild-list))) - + (bookmark-bmenu-surreptitiously-rebuild-list)))) ;;;###autoload (defun bookmark-insert-location (bookmark-name &optional no-history)