unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
@ 2024-11-03 15:42 Thierry Volpiatto
  2024-11-03 16:28 ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
  2024-11-03 16:30 ` Eli Zaretskii
  0 siblings, 2 replies; 8+ messages in thread
From: Thierry Volpiatto @ 2024-11-03 15:42 UTC (permalink / raw)
  To: 74191


In Emacs-29:

(let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
=>nil

In Emacs-30+:

(let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
=> t

which is wrong obviously.




In GNU Emacs 31.0.50 (build 3, x86_64-pc-linux-gnu, GTK+ Version
 3.24.33, cairo version 1.16.0) of 2024-09-16 built on IPad-S340
Repository revision: f27553c30a772a0103d2e6762e4d7f588f302e4b
Repository branch: master
Windowing system distributor 'The X.Org Foundation', version 11.0.12101004
System Description: Linux Mint 21.3

Configured using:
 'configure CFLAGS=-O8 --bindir=/usr/local/sbin/emacs-31.0.50
 --with-cairo --with-modules --without-tree-sitter
 --without-native-compilation'

Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG
LCMS2 LIBOTF LIBSELINUX LIBSYSTEMD LIBXML2 M17N_FLT MODULES NOTIFY
INOTIFY PDUMPER PNG RSVG SECCOMP SOUND SQLITE3 THREADS TIFF
TOOLKIT_SCROLL_BARS X11 XDBE XIM XINPUT2 XPM GTK3 ZLIB

Important settings:
  value of $LANG: fr_FR.UTF-8
  locale-coding-system: utf-8-unix

Major mode: 

Minor modes in effect:
  server-mode: t
  psession-mode: t
  psession-savehist-mode: t
  global-git-gutter-mode: t
  display-time-mode: t
  winner-mode: t
  tv-save-place-mode: t
  helm-epa-mode: t
  helm-descbinds-mode: t
  helm-top-poll-mode: t
  helm-adaptive-mode: t
  helm-mode: t
  helm-minibuffer-history-mode: t
  helm-ff-icon-mode: t
  helm-popup-tip-mode: t
  async-bytecomp-package-mode: t
  dired-async-mode: t
  minibuffer-depth-indicate-mode: t
  gcmh-mode: t
  tooltip-mode: t
  global-eldoc-mode: t
  eldoc-mode: t
  show-paren-mode: t
  mouse-wheel-mode: t
  file-name-shadow-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  minibuffer-regexp-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:
None found.

Features:
(shadow sort epa-mail face-remap mail-extr addressbook-bookmark
tv-mu4e-config advice gnus-and-mu4e mu4e-patch mu4e-contrib eshell
esh-cmd esh-ext esh-proc esh-opt esh-io esh-arg esh-module
esh-module-loaddefs esh-util mu4e mu4e-org mu4e-notification
notifications mu4e-main smtpmail mu4e-view mu4e-mime-parts mu4e-headers
mu4e-thread mu4e-actions mu4e-compose mu4e-draft gnus-msg mu4e-search
mu4e-lists mu4e-bookmarks mu4e-mark mu4e-message flow-fill hl-line
mu4e-contacts mu4e-update mu4e-folders mu4e-context mu4e-query-items
mu4e-server mu4e-modeline mu4e-vars mu4e-helpers mu4e-config mu4e-window
bookmark ido mu4e-obsolete helm-dabbrev emacsbug tramp-archive
tramp-gvfs tramp-cache time-stamp zeroconf helm-command helm-elisp
helm-eval edebug debug backtrace helm-info helm-ls-git vc-git diff-mode
track-changes emacs-news-mode vc vc-dispatcher flymake-shellcheck
flymake project warnings markdown-mode color org-indent oc-basic
org-element org-persist org-id org-refile org-element-ast inline
avl-tree generator ol-eww eww url-queue mm-url ol-rmail ol-mhe ol-irc
ol-info ol-gnus nnselect gnus-art mm-uu mml2015 mm-view mml-smime smime
gnutls dig gnus-sum shr pixel-fill kinsoku url-file svg dom gnus-group
gnus-undo gnus-start gnus-dbus dbus xml gnus-cloud nnimap nnmail
mail-source utf7 nnoo gnus-spec gnus-int gnus-range message sendmail
yank-media puny rfc822 mml mml-sec mm-decode mm-bodies mm-encode
mail-parse rfc2231 rfc2047 rfc2045 ietf-drums mailabbrev gmm-utils
mailheader gnus-win gnus nnheader gnus-util mail-utils range mm-util
mail-prsvr ol-docview doc-view jka-compr ol-bibtex bibtex ol-bbdb ol-w3m
ol-doi org-link-doi org-config ob-gnuplot org-crypt org-protocol org ob
ob-tangle ob-ref ob-lob ob-table ob-exp org-macro org-src sh-script smie
treesit executable ob-comint org-pcomplete org-list org-footnote
org-faces org-entities noutline outline org-version ob-emacs-lisp
ob-core ob-eval org-cycle org-table ol org-fold org-fold-core org-keys
oc org-loaddefs find-func org-compat org-macs bug-reference thingatpt
cus-start naquadah-theme solar cal-dst holidays holiday-loaddefs appt
diary-lib diary-loaddefs cal-menu calendar cal-loaddefs server bm
cl-extra imenu tv-utils psession frameset pcase git-gutter mule-util
dired-extension time winner describe-variable help-fns radix-tree
tv-save-place.el init-helm epa derived epg rfc6068 epg-config helm-epa
helm-descbinds cus-edit pp wid-edit helm-sys helm-adaptive helm-mode
helm-misc helm-files image-dired image-dired-tags image-dired-external
image-dired-util image-mode exif filenotify tramp rx trampver
tramp-integration files-x tramp-message help-mode tramp-compat xdg shell
pcomplete parse-time iso8601 time-date tramp-loaddefs helm-buffers
all-the-icons all-the-icons-faces data-material data-weathericons
data-octicons data-fileicons data-faicons data-alltheicons helm-occur
helm-tags helm-locate helm-grep wgrep-helm wgrep grep compile
text-property-search comint ansi-osc ring helm-regexp format-spec
ansi-color helm-utils helm-help helm-types helm-extensions-autoloads
helm-autoloads helm helm-global-bindings helm-easymenu edmacro kmacro
helm-core async-bytecomp helm-source helm-multi-match helm-lib
dired-async async dired-aux dired dired-loaddefs isl-autoloads mb-depth
avoid cus-load gcmh easy-mmode all-the-icons-autoloads info
ledger-mode-autoloads markdown-mode-autoloads w3m-load w3m-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 icons
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/x-win x-win term/common-win x-dnd touch-screen 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 dbusbind inotify lcms2
dynamic-setting system-font-setting font-render-setting cairo gtk
x-toolkit xinput2 x multi-tty move-toolbar make-network-process emacs)

Memory information:
((conses 16 801031 433487) (symbols 48 36570 3)
 (strings 32 208077 20114) (string-bytes 1 5167548) (vectors 16 66951)
 (vector-slots 8 631529 601667) (floats 8 2302 1172)
 (intervals 56 75673 125) (buffers 984 145))
<#secure method=pgpmime mode=sign>

-- 
Thierry





^ permalink raw reply	[flat|nested] 8+ messages in thread

* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
  2024-11-03 15:42 bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil Thierry Volpiatto
@ 2024-11-03 16:28 ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
  2024-11-03 19:43   ` Thierry Volpiatto
  2024-11-03 16:30 ` Eli Zaretskii
  1 sibling, 1 reply; 8+ messages in thread
From: Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-11-03 16:28 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: 74191

Thierry Volpiatto <thievol@posteo.net> writes:

Hi Thierry,

> In Emacs-29:
>
> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
> =>nil
>
> In Emacs-30+:
>
> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
> => t
>
> which is wrong obviously.

No, it isn't. It is intended.

It is due to implementation of method, user and host name completion for
remote files.

Best regards, Michael.





^ permalink raw reply	[flat|nested] 8+ messages in thread

* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
  2024-11-03 15:42 bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil Thierry Volpiatto
  2024-11-03 16:28 ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-11-03 16:30 ` Eli Zaretskii
  2024-11-03 19:46   ` Thierry Volpiatto
  1 sibling, 1 reply; 8+ messages in thread
From: Eli Zaretskii @ 2024-11-03 16:30 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: 74191

> From: Thierry Volpiatto <thievol@posteo.net>
> Date: Sun, 03 Nov 2024 15:42:09 +0000
> 
> 
> In Emacs-29:
> 
> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
> =>nil
> 
> In Emacs-30+:
> 
> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
> => t
> 
> which is wrong obviously.

Do you have a directory called "/ssh" on your system?

For me, (file-directory-p "/ssh") yields nil even without let-binding
minibuffer-completing-file-name, so I'm not sure I understand the
issue you want to raise.

I also get the same behavior in Emacs 29, btw.





^ permalink raw reply	[flat|nested] 8+ messages in thread

* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
  2024-11-03 16:28 ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-11-03 19:43   ` Thierry Volpiatto
  2024-11-04  7:54     ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
  0 siblings, 1 reply; 8+ messages in thread
From: Thierry Volpiatto @ 2024-11-03 19:43 UTC (permalink / raw)
  To: Michael Albinus; +Cc: Thierry Volpiatto, 74191

[-- Attachment #1: Type: text/plain, Size: 637 bytes --]


Hi Michael,

Michael Albinus <michael.albinus@gmx.de> writes:

> Thierry Volpiatto <thievol@posteo.net> writes:
>
> Hi Thierry,
>
>> In Emacs-29:
>>
>> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
>> =>nil
>>
>> In Emacs-30+:
>>
>> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
>> => t
>>
>> which is wrong obviously.
>
> No, it isn't. It is intended.

Hmm, It is perhaps intended and I believe it fixes some problem, but it is
wrong anyway, "/ssh" is NOT a directory.

Can I use file-attributes instead or it is affected as well?

Thanks.


-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
  2024-11-03 16:30 ` Eli Zaretskii
@ 2024-11-03 19:46   ` Thierry Volpiatto
  0 siblings, 0 replies; 8+ messages in thread
From: Thierry Volpiatto @ 2024-11-03 19:46 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: Thierry Volpiatto, 74191

[-- Attachment #1: Type: text/plain, Size: 742 bytes --]

Eli Zaretskii <eliz@gnu.org> writes:

>> From: Thierry Volpiatto <thievol@posteo.net>
>> Date: Sun, 03 Nov 2024 15:42:09 +0000
>> 
>> 
>> In Emacs-29:
>> 
>> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
>> =>nil
>> 
>> In Emacs-30+:
>> 
>> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
>> => t
>> 
>> which is wrong obviously.
>
> Do you have a directory called "/ssh" on your system?

No.

> For me, (file-directory-p "/ssh") yields nil even without let-binding
> minibuffer-completing-file-name,

Of course, here as well, the point is that file-directory-p is not
working anymore when wrapped inside a minibuffer-completing-file-name
let-binding.

-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
  2024-11-03 19:43   ` Thierry Volpiatto
@ 2024-11-04  7:54     ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
  2024-11-04 10:06       ` Thierry Volpiatto
  0 siblings, 1 reply; 8+ messages in thread
From: Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-11-04  7:54 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: 74191

Thierry Volpiatto <thievol@posteo.net> writes:

> Hi Michael,

Hi Thierry,

>>> In Emacs-30+:
>>>
>>> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
>>> => t
>>>
>>> which is wrong obviously.
>>
>> No, it isn't. It is intended.
>
> Hmm, It is perhaps intended and I believe it fixes some problem, but it is
> wrong anyway, "/ssh" is NOT a directory.

Nobody says so. Remember, we're in file name completion, and Tramp must
trigger some action from the completion machinery. A non-nil return of
file-directory-p is such a trigger.

> Can I use file-attributes instead or it is affected as well?

Should work. Check tramp-completion-file-name-handler-alist. It cares
only about

--8<---------------cut here---------------start------------->8---
((expand-file-name . tramp-completion-handle-expand-file-name)
 (file-directory-p . tramp-completion-handle-file-directory-p)
 (file-exists-p . tramp-completion-handle-file-exists-p)
 (file-name-all-completions . tramp-completion-handle-file-name-all-completions)
 (file-name-completion . tramp-completion-handle-file-name-completion)
 (file-name-directory . tramp-completion-handle-file-name-directory)
 (file-name-nondirectory . tramp-completion-handle-file-name-nondirectory))
--8<---------------cut here---------------end--------------->8---

Alternatively, you could bind temporarily tramp-mode to nil. See
tramp-completion-file-name-handler:

--8<---------------cut here---------------start------------->8---
  (if-let*
      ((fn (and tramp-mode minibuffer-completing-file-name
		(assoc operation tramp-completion-file-name-handler-alist))))
      (save-match-data (apply (cdr fn) args))
    (tramp-run-real-handler operation args)))
--8<---------------cut here---------------end--------------->8---

> Thanks.

Best regards, Michael.





^ permalink raw reply	[flat|nested] 8+ messages in thread

* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
  2024-11-04  7:54     ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-11-04 10:06       ` Thierry Volpiatto
  2024-11-04 13:04         ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
  0 siblings, 1 reply; 8+ messages in thread
From: Thierry Volpiatto @ 2024-11-04 10:06 UTC (permalink / raw)
  To: Michael Albinus; +Cc: Thierry Volpiatto, 74191

[-- Attachment #1: Type: text/plain, Size: 2133 bytes --]


Thanks Michael, I finally use a new variable
helm--minibuffer-completing-file-name which doesn't affect
file-directory-p.

Michael Albinus <michael.albinus@gmx.de> writes:

> Thierry Volpiatto <thievol@posteo.net> writes:
>
>> Hi Michael,
>
> Hi Thierry,
>
>>>> In Emacs-30+:
>>>>
>>>> (let ((minibuffer-completing-file-name t)) (file-directory-p "/ssh"))
>>>> => t
>>>>
>>>> which is wrong obviously.
>>>
>>> No, it isn't. It is intended.
>>
>> Hmm, It is perhaps intended and I believe it fixes some problem, but it is
>> wrong anyway, "/ssh" is NOT a directory.
>
> Nobody says so. Remember, we're in file name completion, and Tramp must
> trigger some action from the completion machinery. A non-nil return of
> file-directory-p is such a trigger.
>
>> Can I use file-attributes instead or it is affected as well?
>
> Should work. Check tramp-completion-file-name-handler-alist. It cares
> only about
>
> --8<---------------cut here---------------start------------->8---
> ((expand-file-name . tramp-completion-handle-expand-file-name)
>  (file-directory-p . tramp-completion-handle-file-directory-p)
>  (file-exists-p . tramp-completion-handle-file-exists-p)
>  (file-name-all-completions . tramp-completion-handle-file-name-all-completions)
>  (file-name-completion . tramp-completion-handle-file-name-completion)
>  (file-name-directory . tramp-completion-handle-file-name-directory)
>  (file-name-nondirectory . tramp-completion-handle-file-name-nondirectory))
> --8<---------------cut here---------------end--------------->8---
>
> Alternatively, you could bind temporarily tramp-mode to nil. See
> tramp-completion-file-name-handler:
>
> --8<---------------cut here---------------start------------->8---
>   (if-let*
>       ((fn (and tramp-mode minibuffer-completing-file-name
> 		(assoc operation tramp-completion-file-name-handler-alist))))
>       (save-match-data (apply (cdr fn) args))
>     (tramp-run-real-handler operation args)))
> --8<---------------cut here---------------end--------------->8---
>
>> Thanks.
>
> Best regards, Michael.

-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil
  2024-11-04 10:06       ` Thierry Volpiatto
@ 2024-11-04 13:04         ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
  0 siblings, 0 replies; 8+ messages in thread
From: Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-11-04 13:04 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: 74191-done

Thierry Volpiatto <thievol@posteo.net> writes:

Hi Thierry,

> Thanks Michael, I finally use a new variable
> helm--minibuffer-completing-file-name which doesn't affect
> file-directory-p.

So I close the bug. Nothing left to do.

Best regards, Michael.





^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2024-11-04 13:04 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-11-03 15:42 bug#74191: 31.0.50; file-directory-p broken when minibuffer-completing-file-name is non nil Thierry Volpiatto
2024-11-03 16:28 ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-03 19:43   ` Thierry Volpiatto
2024-11-04  7:54     ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-04 10:06       ` Thierry Volpiatto
2024-11-04 13:04         ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-03 16:30 ` Eli Zaretskii
2024-11-03 19:46   ` Thierry Volpiatto

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).