GNU bug report logs -
#70526
29.2; package-vc-upgrade failed with error message "File is not under version control"
Previous Next
Reported by: "Yi Yue" <include_yy <at> qq.com>
Date: Tue, 23 Apr 2024 05:16:02 UTC
Severity: normal
Found in version 29.2
Done: Philip Kaludercic <philipk <at> posteo.net>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
[Message part 1 (text/plain, inline)]
Your bug report
#70526: 29.2; package-vc-upgrade failed with error message "File is not under version control"
which was filed against the emacs package, has been closed.
The explanation is attached below, along with your original report.
If you require more details, please reply to 70526 <at> debbugs.gnu.org.
--
70526: https://debbugs.gnu.org/cgi/bugreport.cgi?bug=70526
GNU Bug Tracking System
Contact help-debbugs <at> gnu.org with problems
[Message part 2 (message/rfc822, inline)]
"o0o0o耗子" <include_yy <at> qq.com> writes:
> > As the buffer is hidden, I didn't see the need to clean it up.
> It can > be re-used later on and might help with debugging. I think
> you are right. Now we fix this bug. Regards
I have pushed the changes, and will therefore close this bug report.
Thank you for your help!
--
Philip Kaludercic on peregrine
[Message part 3 (message/rfc822, inline)]
[Message part 4 (text/plain, inline)]
Hi all:
I encountered the following Backtrace information when invoking
`package-vc-upgrade'.
Debugger entered--Lisp error: (error "File is not under version control")
error("File is not under version control")
vc-deduce-fileset-1(t nil nil)
vc-deduce-fileset(t)
vc-pull()
......
After some edebug debugging and reading the source code, I found that
this error occurs if the buffer where `package-vc-upgrade' is called is
not under a git repository. Additionally, if the current buffer of the
command invocation does not correspond to a specific file, then the
command can execute normally.
After reading the implementation of `package-vc-upgrade', I found that it
binds `default-directory' to the package's path. However, the internally
called `vc-pull' function, which uses `vc-deduce-fileset-1', first
utilizes `buffer-file-name' instead of `default-directory' to fetch
version control backend related information, which leads to this error.
In my past usage, I did not encounter this error, probably because I
usually invoked it within a file buffer under a git repository, or used
the command in a buffer provided by `list-packages'. Here is one
solution I used:
(when (eq emacs-major-version 29)
(defun yy/package-vc-upgrade-advice (upfun pkg-desc)
(with-temp-buffer
(funcall upfun pkg-desc)))
(advice-add 'package-vc-upgrade :around 'yy/package-vc-upgrade-advice))
In a minimal environment with emacs -Q, the following steps can
reproduce my issue:
;; a simple package by purcell
(package-vc-install "https://github.com/purcell/unfill")
;; then try to upgrade it in a buffer that buffer-file-name is not nil
;; and the file is not under Git version control system.
M-x package-vc-upgrade unfill RET
;; now the error may occurs
Regards
YI YUE
[Message part 5 (text/html, inline)]
This bug report was last modified 1 year and 24 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.