GNU bug report logs -
#28264
Accessing source directory through symlink produces false warnings
Previous Next
Reported by: Glenn Morris <rgm <at> gnu.org>
Date: Mon, 28 Aug 2017 18:26:01 UTC
Severity: normal
Found in version 26.0.50
Done: Paul Eggert <eggert <at> cs.ucla.edu>
Bug is archived. No further changes may be made.
Full log
Message #16 received at 28264 <at> debbugs.gnu.org (full text, mbox):
[Message part 1 (text/plain, inline)]
Michael Albinus wrote:
> This special problem does not seem to affect Tramp, tramp-tests tell.
The problem I was thinking of does not seem to be covered by Tramp tests. If,
for example, I do these shell commands:
$ ln -s "../penguin:motd" /tmp/foo
$ ls -l /tmp/foo
lrwxrwxrwx 1 eggert eggert 15 Aug 29 19:00 /tmp/foo -> ../penguin:motd
then (file-truename "/tmp/foo") returns "/penguin:motd" which is not /tmp/foo's
true name as far as Emacs file-oriented commands are concerned. Admittedly this
is an improvement over Emacs 25.2 where the same file-truename call ssh'es into
penguin to resolve the name, which is a clear security issue. Still, it doesn't
seem right, if file-truename is expected to quote its result if necessary.
Sorry about all this confusion, but I do not know the general principle that
Emacs is supposed to be using with file names, and to some extent I fear that
there isn't one alas.
> However, the following code is unclear to me:
>
>> + (concat "/:" file))
>
> What, if file is already quoted? Shouldn't this be
>
> (file-name-quote file)
Quite possibly, and I'll take your word for it. I installed the attached.
[0001-Prefer-file-name-quote-to-concat.patch (text/x-patch, attachment)]
This bug report was last modified 7 years and 350 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.