* bug#63661: 29.0.91; Emacs hangs trying to save encrypted file
@ 2023-05-23 10:36 Roman Rudakov
2023-05-23 13:28 ` Robert Pluim
0 siblings, 1 reply; 3+ messages in thread
From: Roman Rudakov @ 2023-05-23 10:36 UTC (permalink / raw)
To: 63661
Steps to reproduce:
- Create/open a file with .gpg extension (C-x C-f ~/test.gpg)
- Edit file content
- Save file (C-x C-s)
- If it's a new file, select a key to encrypt this file
Expected result: file is saved and encrypted.
Actual result: emacs is not responding.
Additional info:
If I run `toggle-debug-on-quit` and press `C-g`, I can see that the
latest called function in a backtrace is `epg-wait-for-status`.
After debugging I also figured out that the code:
(accept-process-output (epg-context-process context) 1)
always returns `nil` so while loop runs forever.
I tried to run gpg command directly in terminal and it works fine:
/opt/homebrew/bin/gpg --no-tty --status-fd 1 --yes
--enable-progress-filter --command-fd 0 --output test.gpg --encrypt -r
FB43E281457C5165
Output:
[GNUPG:] KEY_CONSIDERED E66810C6F226B2BD08D67F00FB43E281457C5165 0
Hello
This text is encrypted!
[GNUPG:] PROGRESS stdin ? 0 0 B
[GNUPG:] BEGIN_ENCRYPTION 2 9
[GNUPG:] PROGRESS stdin ? 30 0 B
[GNUPG:] END_ENCRYPTION
In GNU Emacs 29.0.91 (build 1, aarch64-apple-darwin22.5.0, NS
appkit-2299.60 Version 13.4 (Build 22F66)) of 2023-05-23 built on
Romans-MacBook-Pro.local
Windowing system distributor 'Apple', version 10.3.2299
System Description: macOS 13.4
Configured using:
'configure --disable-dependency-tracking --disable-silent-rules
--enable-locallisppath=/opt/homebrew/share/emacs/site-lisp
--infodir=/opt/homebrew/Cellar/emacs-plus@29/29.0.90/share/info/emacs
--prefix=/opt/homebrew/Cellar/emacs-plus@29/29.0.90 --with-xml2
--with-gnutls --with-native-compilation --without-compress-install
--without-dbus --without-imagemagick --with-modules --with-rsvg
--without-pop --with-xwidgets --with-ns --disable-ns-self-contained
'CFLAGS=-Os -w -pipe -mmacosx-version-min=13
-isysroot/Library/Developer/CommandLineTools/SDKs/MacOSX13.sdk
-DFD_SETSIZE=10000 -DDARWIN_UNLIMITED_SELECT'
'CPPFLAGS=-I/opt/homebrew/opt/zlib/include
-I/opt/homebrew/opt/jpeg/include -I/opt/homebrew/opt/readline/include
-I/opt/homebrew/opt/icu4c/include
-I/opt/homebrew/opt/openssl@1.1/include -isystem/opt/homebrew/include
-F/opt/homebrew/Frameworks
-isysroot/Library/Developer/CommandLineTools/SDKs/MacOSX13.sdk'
'LDFLAGS=-L/opt/homebrew/opt/zlib/lib -L/opt/homebrew/opt/jpeg/lib
-L/opt/homebrew/opt/readline/lib -L/opt/homebrew/opt/icu4c/lib
-L/opt/homebrew/opt/openssl@1.1/lib -L/opt/homebrew/lib
-F/opt/homebrew/Frameworks -Wl,-headerpad_max_install_names
-isysroot/Library/Developer/CommandLineTools/SDKs/MacOSX13.sdk
-L/opt/homebrew/opt/libgccjit/lib''
Configured features:
ACL GIF GLIB GMP GNUTLS JPEG JSON LCMS2 LIBXML2 MODULES NATIVE_COMP
NOTIFY KQUEUE NS PDUMPER PNG RSVG SQLITE3 THREADS TIFF
TOOLKIT_SCROLL_BARS TREE_SITTER WEBP XIM XWIDGETS ZLIB
Important settings:
value of $LC_CTYPE: UTF-8
locale-coding-system: utf-8
Major mode: Authinfo
Minor modes in effect:
reveal-mode: t
pdf-occur-global-minor-mode: t
corfu-popupinfo-mode: t
erc-list-mode: t
erc-menu-mode: t
erc-autojoin-mode: t
erc-ring-mode: t
erc-track-mode: t
erc-match-mode: t
erc-netsplit-mode: t
erc-autoaway-mode: t
mu4e-modeline-mode: t
auto-insert-mode: t
smartparens-global-strict-mode: t
smartparens-strict-mode: t
smartparens-mode: t
persp-mode: t
projectile-mode: t
magit-todos-mode: t
global-diff-hl-mode: t
diff-hl-mode: t
global-git-commit-mode: t
magit-auto-revert-mode: t
winum-mode: t
org-roam-db-autosync-mode: t
global-corfu-mode: t
corfu-mode: t
vertico-multiform-mode: t
vertico-mode: t
minions-mode: t
save-place-mode: t
savehist-mode: t
global-auto-revert-mode: t
global-hl-line-mode: t
delete-selection-mode: t
override-global-mode: t
erc-button-mode: t
erc-fill-mode: t
erc-stamp-mode: t
erc-irccontrols-mode: t
erc-noncommands-mode: t
erc-move-to-prompt-mode: t
erc-readonly-mode: t
erc-networks-mode: t
TeX-PDF-mode: t
recentf-mode: t
windmove-mode: t
shell-dirtrack-mode: t
csv-field-index-mode: t
global-eldoc-mode: t
show-paren-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
blink-cursor-mode: t
window-divider-mode: t
column-number-mode: t
line-number-mode: t
transient-mark-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
Load-path shadows:
/Users/rrudakov/.emacs.d/elpa/hydra-0.15.0/lv hides
/Users/rrudakov/.emacs.d/elpa/lv-0.15.0/lv
/Users/rrudakov/.emacs.d/elpa/password-store-20230503.619/password-store
hides /opt/homebrew/share/emacs/site-lisp/pass/password-store
/Users/rrudakov/.emacs.d/elpa/transient-0.4.0/transient hides
/opt/homebrew/Cellar/emacs-plus@29/29.0.90/share/emacs/29.0.91/lisp/transient
Features:
(shadow consult-org consult-imenu mailalias gnus-cite smiley qp
mail-extr textsec uni-scripts idna-mapping uni-confusable
textsec-check
display-line-numbers shortdoc consult-xref vc-git help-fns cl-print
cus-start emacsbug reveal epa-file cursor-sensor pdf-occur
corfu-popupinfo org-duration org-eldoc oc-basic bibtex init
literate-calc-mode gif-screencast google-translate-smooth-ui
password-store-otp nov ob-restclient erc-list erc-menu erc-join
erc-ring
erc-pcomplete erc-track erc-match erc-netsplit erc-autoaway mu4e
mu4e-org mu4e-notification mu4e-main mu4e-view mu4e-headers
mu4e-compose
mu4e-draft mu4e-actions smtpmail mu4e-search mu4e-lists mu4e-bookmarks
mu4e-mark mu4e-message flow-fill mu4e-contacts mu4e-update
mu4e-folders
mu4e-context mu4e-query-items mu4e-server mu4e-modeline mu4e-vars
mu4e-helpers mu4e-config mu4e-window mu4e-obsolete rust-ts-mode
dockerfile-ts-mode smartparens-lua lua-mode yaml-ts-mode font-latex
pip-requirements py-yapf blacken pyvenv web-mode-expansions web-mode
disp-table typescript-mode add-node-modules-path prettier-js
java-ts-mode c-ts-common google-java-format pkgbuild-mode logview
vlf-setup nginx-mode vimrc-mode ssh-config-mode xml-format
nxml-mode-expansions rng-nxml rng-valid nxml-mode nxml-outln nxml-rap
edit-indirect eglot external-completion array jsonrpc google-c-style
bicycle autoinsert flymake-kondor idle-highlight-mode rainbow-mode
smartscan deadgrep rg rg-info-hack rg-menu rg-ibuffer rg-result
wgrep-rg
wgrep rg-history rg-header avy flyspell-correct expand-region
subword-mode-expansions text-mode-expansions cc-mode-expansions
the-org-mode-expansions python-el-fgallina-expansions
latex-mode-expansions html-mode-expansions clojure-mode-expansions
er-basic-expansions expand-region-core expand-region-custom
multiple-cursors mc-hide-unmatched-lines-mode mc-separate-operations
rectangular-region-mode mc-mark-pop mc-mark-more mc-cycle-cursors
mc-edit-lines smartparens-rust smartparens-org smartparens-config
smartparens-text smartparens-python smartparens-markdown
smartparens-latex smartparens-html smartparens-haskell
smartparens-clojure smartparens perspective consult projectile
git-link
gitignore-templates magit-todos pcre2el rxt hl-todo f f-shortdoc grep
diff-hl log-view vc-dir vc vc-dispatcher magit-bookmark
magit-submodule
magit-obsolete magit-blame magit-stash magit-reflog magit-bisect
magit-push magit-pull magit-fetch magit-clone magit-remote
magit-commit
magit-sequence magit-notes magit-worktree magit-tag magit-merge
magit-branch magit-reset magit-files magit-refs magit-status magit
magit-repos magit-apply magit-wip magit-log which-func magit-diff
smerge-mode diff diff-mode git-commit log-edit pcvs-util add-log
magit-core magit-autorevert magit-margin magit-transient magit-process
magit-mode transient magit-git magit-utils winum org-roam-migrate
org-roam-log org-roam-mode org-roam-capture org-roam-id org-roam-node
org-roam-db emacsql-sqlite-builtin sqlite org-roam-utils
org-roam-compat
org-roam org-capture org-attach emacsql-sqlite emacsql-sqlite-common
emacsql emacsql-compiler magit-section org-tree-slide face-remap
org-timer async ob-async ob-plantuml ob-ditaa ob-clojure ob-haskell
ob-sqlite ob-shell ob-sql ob-python python org-mime ox-org org-clock
appt diary-lib diary-loaddefs ox-jira ox-confluence org-contrib
ox-slack
ox-gfm ox-md ox-odt rng-loc rng-uri rng-parse rng-match rng-dt
rng-util
rng-pttrn nxml-parse nxml-ns nxml-enc xmltok nxml-util ox-latex
ox-icalendar ox-html table ox-ascii ox-publish ox org-agenda ol-info
ol-gnus nnselect gnus-art mm-uu mml2015 mm-view mml-smime smime dig
gnus-sum gnus-group gnus-undo gnus-start gnus-dbus gnus-cloud nnimap
nnmail mail-source utf7 nnoo gnus-spec gnus-int gnus-range gnus-win
alert log4e notifications gntp exec-path-from-shell cape corfu
orderless
vertico-directory vertico-multiform vertico minions
modus-vivendi-tinted-theme modus-themes hippie-exp re-builder flyspell
dired-subtree dired-hacks-utils dired-git-info image-dired
image-dired-tags image-dired-external image-dired-util dired-aux
shr-tag-pre-highlight saveplace savehist autorevert filenotify
conf-mode
hl-line delsel novice mysecret use-package use-package-ensure
use-package-delight use-package-diminish use-package-bind-key bind-key
use-package-core emacs-everywhere-autoloads lua-mode-autoloads
git-link-autoloads erc-hl-nicks erc-button erc-fill erc-stamp
erc-goodies erc erc-backend erc-networks erc-common erc-compat
erc-loaddefs erc-hl-nicks-autoloads timezone texinfo texinfo-loaddefs
toolbar-x reporter desktop frameset context plain-tex latex
latex-flymake tex-ispell tex-style tex crm dbus texmathp
auctex-autoloads tex-site language-detection
shr-tag-pre-highlight-autoloads language-detection-autoloads
org-element
org-persist org-id org-refile calc calc-loaddefs calc-macs
literate-calc-mode-autoloads gif-screencast-autoloads
google-translate-default-ui google-translate-core-ui ido
google-translate-core google-translate-backend
google-translate-autoloads popup popup-autoloads password-store
password-store-otp-autoloads auth-source-pass with-editor server
password-store-autoloads recentf tree-widget esxml-query nov-autoloads
esxml-autoloads kv-autoloads pdf-virtual pdf-sync pdf-loader pdf-links
ibuf-ext ibuffer ibuffer-loaddefs pdf-tools pdf-isearch let-alist
tablist pdf-misc pdf-view jka-compr pdf-cache pdf-info tq pdf-util
pdf-macs image-mode exif pdf-tools-autoloads tablist-filter
semantic/wisent/comp semantic/wisent semantic/wisent/wisent
semantic/util-modes semantic/util semantic semantic/tag semantic/lex
semantic/fw mode-local cedet tablist-autoloads restclient
ob-restclient-autoloads restclient-autoloads elfeed-show elfeed-search
elfeed-csv elfeed elfeed-curl xml-query bookmark elfeed-log elfeed-db
elfeed-lib avl-tree elfeed-autoloads plantuml-mode-autoloads
groovy-mode
groovy-mode-autoloads inf-haskell haskell-indent haskell-completions
haskell-c2hs haskell-decl-scan quail highlight-uses-mode
haskell-modules
haskell-sandbox haskell-navigate-imports haskell-repl haskell-svg
haskell-collapse haskell-debug haskell-interactive-mode
haskell-presentation-mode haskell-compile haskell-process
haskell-session haskell-hoogle haskell-mode haskell-cabal
haskell-utils
haskell-font-lock haskell-indentation haskell-string
haskell-sort-imports haskell-lexeme haskell-align-imports
haskell-complete-module haskell-ghc-support etags fileloop dabbrev
haskell-customize haskell-mode-autoloads pip-requirements-autoloads
py-yapf-autoloads blacken-autoloads eshell esh-cmd esh-ext esh-opt
esh-proc esh-io esh-arg esh-module esh-groups esh-util
pyvenv-autoloads
web-mode-autoloads cc-mode cc-fonts cc-guess cc-menus cc-cmds
cc-styles
cc-align cc-engine cc-vars typescript-mode-autoloads
add-node-modules-path-autoloads prettier-js-autoloads clj-refactor
cap-words superword subword inflections sgml-mode facemenu cider
multiple-cursors-core paredit edmacro kmacro clj-refactor-autoloads
inflections-autoloads hydra-examples windmove rect hydra lv
hydra-autoloads lv-autoloads tramp-sh cider-debug cider-repl-history
cider-scratch cider-mode cider-completion cider-profile
cider-inspector
cider-eval cider-repl cider-test cider-stacktrace cider-overlays
cider-jar cider-browse-ns cider-eldoc apropos cider-find cider-resolve
cider-doc cider-browse-spec cider-clojuredocs cider-client
cider-connection sesman-browser nrepl-client queue parseedn
cider-popup
cider-common xref cider-util clojure-mode nrepl-dict cider-autoloads
parseedn-autoloads parseclj-ast parseclj-parser parseclj-lex
parseclj-alist parseclj-autoloads generator queue-autoloads sesman
sesman-autoloads align imenu clojure-mode-autoloads sql-indent sql
view
sql-indent-autoloads tramp tramp-loaddefs trampver tramp-integration
files-x tramp-compat shell parse-time iso8601 ls-lisp sh-script smie
treesit executable pkgbuild-mode-autoloads pulse datetime
logview-autoloads extmap datetime-autoloads bindat extmap-autoloads
ediff ediff-merg ediff-mult ediff-wind ediff-diff ediff-help
ediff-init
ediff-util vlf comp comp-cstr vlf-base vlf-tune vlf-autoloads csv-mode
sort csv-mode-autoloads nginx-mode-autoloads vimrc-mode-autoloads
generic ssh-config-mode-autoloads reformatter xml-format-autoloads
reformatter-autoloads edit-indirect-autoloads eww xdg url-queue shr
pixel-fill kinsoku url-file svg xml dom mm-url gnus nnheader range
ispell markdown-mode checkdoc markdown-mode-autoloads cc-defs
google-c-style-autoloads hideshow compat bicycle-autoloads
flymake-proc
flymake flymake-kondor-autoloads thingatpt pcase
idle-highlight-mode-autoloads benchmark dtrt-indent
dtrt-indent-autoloads rainbow-mode-autoloads smartscan-autoloads cl
warnings org ob ob-tangle ob-ref ob-lob ob-table ob-exp org-macro
org-src ob-comint org-pcomplete pcomplete org-list org-footnote
org-faces org-entities noutline outline ob-emacs-lisp ob-core ob-eval
org-cycle org-table ol org-fold org-fold-core org-keys oc org-loaddefs
cal-menu calendar cal-loaddefs org-version org-compat org-macs
format-spec ert-x ert ewoc advice edebug debug backtrace find-func
color
yasnippet cl-extra help-mode yasnippet-autoloads easy-mmode tar-mode
arc-mode archive-mode rx project spinner dash s compile comint
ansi-osc
ansi-color ring deadgrep-autoloads loaddefs-gen lisp-mnt radix-tree
mm-archive message sendmail yank-media dired dired-loaddefs rfc822 mml
mml-sec epa derived epg rfc6068 epg-config gnus-util
text-property-search time-date mailabbrev gmm-utils mailheader
mm-decode
mm-bodies mm-encode mail-utils gnutls network-stream url-cache
url-http
url-auth mail-parse rfc2231 rfc2047 rfc2045 mm-util ietf-drums
mail-prsvr url-gw nsm puny finder-inf cus-edit pp cus-load icons
wid-edit org-tree-slide-autoloads flyspell-correct-autoloads
avy-autoloads dired-git-info-autoloads consult-autoloads
paredit-autoloads org-roam-autoloads orderless-autoloads
zenburn-theme-autoloads emacsql-autoloads perspective-autoloads
dired-subtree-autoloads dired-hacks-utils-autoloads spinner-autoloads
projectile-autoloads alert-autoloads ox-slack-autoloads
ob-async-autoloads org-contrib-autoloads vertico-autoloads
org-mime-autoloads gitignore-templates-autoloads gntp-autoloads
multiple-cursors-autoloads cape-autoloads expand-region-autoloads
corfu-autoloads modus-themes-autoloads log4e-autoloads rg-autoloads
ox-jira-autoloads diff-hl-autoloads wgrep-autoloads ox-gfm-autoloads
minions-autoloads magit-todos-autoloads magit-autoloads
magit-section-autoloads git-commit-autoloads with-editor-autoloads
transient-autoloads hl-todo-autoloads compat-autoloads f-autoloads
s-autoloads async-autoloads winum-autoloads info dash-autoloads
smartparens-autoloads exec-path-from-shell-autoloads pcre2el-autoloads
package browse-url url url-proxy url-privacy url-expand url-methods
url-history url-cookie generate-lisp-file url-domsuf url-util mailcap
url-handlers url-parse auth-source cl-seq eieio eieio-core cl-macs
password-cache json subr-x map byte-opt gv bytecomp byte-compile
url-vars cl-loaddefs cl-lib rmc iso-transl tooltip cconv eldoc paren
electric uniquify ediff-hook vc-hooks lisp-float-type elisp-mode
mwheel
term/ns-win ns-win ucs-normalize mule-util term/common-win tool-bar
dnd
fontset image regexp-opt fringe tabulated-list replace newcomment
text-mode lisp-mode prog-mode register page tab-bar menu-bar
rfn-eshadow
isearch easymenu timer select scroll-bar mouse jit-lock font-lock
syntax
font-core term/tty-colors frame minibuffer nadvice seq simple
cl-generic
indonesian philippine cham georgian utf-8-lang misc-lang vietnamese
tibetan thai tai-viet lao korean japanese eucjp-ms cp51932 hebrew
greek
romanian slovak czech european ethiopic indian cyrillic chinese
composite emoji-zwj charscript charprop case-table epa-hook
jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button
loaddefs
theme-loaddefs faces cus-face macroexp files window text-properties
overlay sha1 md5 base64 format env code-pages mule custom widget
keymap
hashtable-print-readable backquote threads xwidget-internal kqueue
cocoa
ns lcms2 multi-tty make-network-process native-compile emacs)
Memory information:
((conses 16 2143246 339464)
(symbols 48 94996 15)
(strings 32 572919 28667)
(string-bytes 1 18251781)
(vectors 16 633685)
(vector-slots 8 6186275 1024946)
(floats 8 183470 3099)
(intervals 56 16287 4741)
(buffers 984 71))
--
Best regards, Roman
^ permalink raw reply [flat|nested] 3+ messages in thread
* bug#63661: 29.0.91; Emacs hangs trying to save encrypted file
2023-05-23 10:36 bug#63661: 29.0.91; Emacs hangs trying to save encrypted file Roman Rudakov
@ 2023-05-23 13:28 ` Robert Pluim
2023-05-23 13:38 ` Roman Rudakov
0 siblings, 1 reply; 3+ messages in thread
From: Robert Pluim @ 2023-05-23 13:28 UTC (permalink / raw)
To: Roman Rudakov; +Cc: 63661
merge 63256 63661
quit
>>>>> On Tue, 23 May 2023 12:36:42 +0200, "Roman Rudakov" <rrudakov@fastmail.com> said:
Roman> Steps to reproduce:
Roman> - Create/open a file with .gpg extension (C-x C-f ~/test.gpg)
Roman> - Edit file content
Roman> - Save file (C-x C-s)
Roman> - If it's a new file, select a key to encrypt this file
Roman> Expected result: file is saved and encrypted.
Roman> Actual result: emacs is not responding.
Roman> Additional info:
This is a duplicate of 63256
Short version: downgrade to gnupg < 2.4.1 (I havenʼt succeeded in
persuading homebrew to go to 2.4.0, so Iʼm back at 2.2.41)
Robert
--
^ permalink raw reply [flat|nested] 3+ messages in thread
* bug#63661: 29.0.91; Emacs hangs trying to save encrypted file
2023-05-23 13:28 ` Robert Pluim
@ 2023-05-23 13:38 ` Roman Rudakov
0 siblings, 0 replies; 3+ messages in thread
From: Roman Rudakov @ 2023-05-23 13:38 UTC (permalink / raw)
To: Robert Pluim; +Cc: 63661
Robert Pluim <rpluim@gmail.com> writes:
> merge 63256 63661
> quit
>
>>>>>> On Tue, 23 May 2023 12:36:42 +0200, "Roman Rudakov"
>>>>>> <rrudakov@fastmail.com> said:
>
> Roman> Steps to reproduce:
> Roman> - Create/open a file with .gpg extension (C-x C-f
> ~/test.gpg)
> Roman> - Edit file content
> Roman> - Save file (C-x C-s)
> Roman> - If it's a new file, select a key to encrypt this file
>
> Roman> Expected result: file is saved and encrypted.
>
> Roman> Actual result: emacs is not responding.
>
> Roman> Additional info:
>
> This is a duplicate of 63256
>
> Short version: downgrade to gnupg < 2.4.1 (I havenʼt succeeded in
> persuading homebrew to go to 2.4.0, so Iʼm back at 2.2.41)
>
> Robert
It works! Thank you, Robert!
Sorry for a duplicate.
--
Best regards, Roman
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2023-05-23 13:38 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-05-23 10:36 bug#63661: 29.0.91; Emacs hangs trying to save encrypted file Roman Rudakov
2023-05-23 13:28 ` Robert Pluim
2023-05-23 13:38 ` Roman Rudakov
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).