* bug#8035: Processing of .. in a file path after going thru symlink
@ 2011-02-14 3:05 spucci
2011-02-19 21:37 ` Glenn Morris
` (2 more replies)
0 siblings, 3 replies; 14+ messages in thread
From: spucci @ 2011-02-14 3:05 UTC (permalink / raw)
To: 8035
The behavior is general, but it's a particular problem with next-error:
When emacs attempts to find a file with "../" as a path component, it
appears to be "smart" about it and simply remove the previous directory path
(e.g., "foo/bar/../x" gets converted to "foo/x"). But if bar is a symlink,
then it doesn't properly find the file. So in compiler output, which
references such files, the next-error function fails to find the file with
the given name.
mkdir dest
mkdir dest/subdir
mkdir src
ln -s ../dest/subdir src/subdir
echo "#error This is an error" > dest/foo.c
Now M-x compile, and give it cc -c src/subdir/../foo.c
*compilation* buffer has:
cc -c src/subdir/../foo.c
src/subdir/../foo.c:1:2: error: #error This is an error
and do a next-error: Emacs complains it can't find the file. And if you try
to find-file that file path (src/subdir/../foo.c) it doesn't work either.
Nor does "emacsclient src/subdir/../foo.c. I couldn't find an option to
disable this behavior; it seems like there should be one even if the default
continues to be as it is today.
This is Gnu Emacs 23.2.1 I built myself on MacOS X 10.6.6.
Thanks,
Steve
--
View this message in context: http://old.nabble.com/Processing-of-..-in-a-file-path-after-going-thru-symlink-tp30918394p30918394.html
Sent from the Emacs - Bugs mailing list archive at Nabble.com.
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2011-02-14 3:05 bug#8035: Processing of .. in a file path after going thru symlink spucci
@ 2011-02-19 21:37 ` Glenn Morris
2011-02-20 2:35 ` Steve Pucci
2021-08-26 16:29 ` Lars Ingebrigtsen
2021-08-26 17:30 ` Lars Ingebrigtsen
2 siblings, 1 reply; 14+ messages in thread
From: Glenn Morris @ 2011-02-19 21:37 UTC (permalink / raw)
To: spucci; +Cc: 8035
spucci wrote:
> When emacs attempts to find a file with "../" as a path component, it
> appears to be "smart" about it and simply remove the previous directory path
> (e.g., "foo/bar/../x" gets converted to "foo/x"). But if bar is a symlink,
> then it doesn't properly find the file.
This appears to be a feature of expand-file-name (and possibly other
things). It does seem a little weird that there isn't even an option to
have a more thorough expansion...
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2011-02-19 21:37 ` Glenn Morris
@ 2011-02-20 2:35 ` Steve Pucci
2011-02-20 2:41 ` Steve Pucci
0 siblings, 1 reply; 14+ messages in thread
From: Steve Pucci @ 2011-02-20 2:35 UTC (permalink / raw)
To: Glenn Morris; +Cc: 8035
On Feb 19, 2011, at 1:37 PM, Glenn Morris wrote:
> This appears to be a feature of expand-file-name (and possibly other
> things). It does seem a little weird that there isn't even an option to
> have a more thorough expansion...
So I ran an experiment, redefining expand-file-name as follows to skip the ".." processing (except in default-directory) and otherwise do the rest:
(or (fboundp 'save-expand-file-name)
(fset 'save-expand-file-name (symbol-function 'expand-file-name)))
(defun expand-file-name (NAME &optional DEFAULT-DIRECTORY)
(cond ((string-match "^/" NAME)
NAME)
((string-match "^\\(~[^/]*\\)\\(.*\\)$" NAME)
(let ((userdir (match-string 1 NAME))
(rest (match-string 2 NAME)))
(concat (save-expand-file-name userdir) rest)))
(t (concat (save-expand-file-name (if DEFAULT-DIRECTORY
DEFAULT-DIRECTORY
default-directory))
NAME))))
While this does the trick (it expands only ~ and relative paths and properly leaves the OP path intact), it fails to fix the problem with next-error. So I conclude you're right there are other places that do the same thing, apparently.
My workaround now is to wrap my build script in a Perl script which rewrites all "../" paths it finds within its output. So I'm ok, though I'm surprised this hasn't come up before...
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2011-02-14 3:05 bug#8035: Processing of .. in a file path after going thru symlink spucci
2011-02-19 21:37 ` Glenn Morris
@ 2021-08-26 16:29 ` Lars Ingebrigtsen
2021-08-26 16:44 ` Eli Zaretskii
2021-08-26 16:53 ` Andreas Schwab
2021-08-26 17:30 ` Lars Ingebrigtsen
2 siblings, 2 replies; 14+ messages in thread
From: Lars Ingebrigtsen @ 2021-08-26 16:29 UTC (permalink / raw)
To: spucci; +Cc: 8035
spucci <slpnabble@blackberry-hill.com> writes:
> When emacs attempts to find a file with "../" as a path component, it
> appears to be "smart" about it and simply remove the previous directory path
> (e.g., "foo/bar/../x" gets converted to "foo/x"). But if bar is a symlink,
> then it doesn't properly find the file. So in compiler output, which
> references such files, the next-error function fails to find the file with
> the given name.
>
> mkdir dest
> mkdir dest/subdir
> mkdir src
> ln -s ../dest/subdir src/subdir
> echo "#error This is an error" > dest/foo.c
>
> Now M-x compile, and give it cc -c src/subdir/../foo.c
>
> *compilation* buffer has:
> cc -c src/subdir/../foo.c
> src/subdir/../foo.c:1:2: error: #error This is an error
>
> and do a next-error: Emacs complains it can't find the file.
This is an even more foundational problem:
(file-exists-p "/tmp/comp/src/subdir/../foo.c")
=> nil
(file-truename "/tmp/comp/src/subdir/../foo.c")
=> "/tmp/comp/dest/foo.c"
(file-exists-p (file-truename "/tmp/comp/src/subdir/../foo.c"))
=> t
And this is because:
static Lisp_Object
check_file_access (Lisp_Object file, Lisp_Object operation, int amode)
{
file = Fexpand_file_name (file, Qnil);
I'm guessing it's calling expand-file-name here to resolve "~"? It's
also a micro-optimisation, I guess -- collapsing "parent/.." textually
without checking the file system is very cheap.
But... this does mean that `file-exists-p' and friends are unreliable
in the presence of symlinks, which is pretty depressing. I think that
`expand-file-name' call in check_file_access should be changed to
something that just does the "~" expansion.
Any opinions?
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 16:29 ` Lars Ingebrigtsen
@ 2021-08-26 16:44 ` Eli Zaretskii
2021-08-26 17:03 ` Lars Ingebrigtsen
2021-08-26 16:53 ` Andreas Schwab
1 sibling, 1 reply; 14+ messages in thread
From: Eli Zaretskii @ 2021-08-26 16:44 UTC (permalink / raw)
To: Lars Ingebrigtsen; +Cc: 8035, slpnabble
> From: Lars Ingebrigtsen <larsi@gnus.org>
> Date: Thu, 26 Aug 2021 18:29:54 +0200
> Cc: 8035@debbugs.gnu.org
>
> (file-exists-p "/tmp/comp/src/subdir/../foo.c")
> => nil
> (file-truename "/tmp/comp/src/subdir/../foo.c")
> => "/tmp/comp/dest/foo.c"
> (file-exists-p (file-truename "/tmp/comp/src/subdir/../foo.c"))
> => t
>
> And this is because:
>
> static Lisp_Object
> check_file_access (Lisp_Object file, Lisp_Object operation, int amode)
> {
> file = Fexpand_file_name (file, Qnil);
>
> I'm guessing it's calling expand-file-name here to resolve "~"?
No, because we always must call expand-file-name before invoking a
libc function that accesses files -- to support file names relative to
their buffer's default-directory.
> I think that `expand-file-name' call in check_file_access should be
> changed to something that just does the "~" expansion.
I don't think we can do that, for the reason explained above.
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 16:44 ` Eli Zaretskii
@ 2021-08-26 17:03 ` Lars Ingebrigtsen
2021-08-26 17:08 ` Eli Zaretskii
0 siblings, 1 reply; 14+ messages in thread
From: Lars Ingebrigtsen @ 2021-08-26 17:03 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: 8035, slpnabble
Eli Zaretskii <eliz@gnu.org> writes:
>> I'm guessing it's calling expand-file-name here to resolve "~"?
>
> No, because we always must call expand-file-name before invoking a
> libc function that accesses files -- to support file names relative to
> their buffer's default-directory.
These are absolute file names, though. I can understand expanding if
they're not.
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 17:03 ` Lars Ingebrigtsen
@ 2021-08-26 17:08 ` Eli Zaretskii
2021-08-26 17:24 ` Lars Ingebrigtsen
0 siblings, 1 reply; 14+ messages in thread
From: Eli Zaretskii @ 2021-08-26 17:08 UTC (permalink / raw)
To: Lars Ingebrigtsen; +Cc: 8035, slpnabble
> From: Lars Ingebrigtsen <larsi@gnus.org>
> Cc: slpnabble@blackberry-hill.com, 8035@debbugs.gnu.org
> Date: Thu, 26 Aug 2021 19:03:24 +0200
>
> Eli Zaretskii <eliz@gnu.org> writes:
>
> >> I'm guessing it's calling expand-file-name here to resolve "~"?
> >
> > No, because we always must call expand-file-name before invoking a
> > libc function that accesses files -- to support file names relative to
> > their buffer's default-directory.
>
> These are absolute file names, though. I can understand expanding if
> they're not.
You asked why expand-file-name is there in general, so I gave a
general explanation.
expand-file-name also normalizes file names, though. Which is also
needed in some use cases, e.g. when the /foo/bar/ isn't accessible,
but /foo/ is, in which case failing to normalize /foo/bar/../quux
could fail some file I/O function.
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 17:08 ` Eli Zaretskii
@ 2021-08-26 17:24 ` Lars Ingebrigtsen
2021-08-26 17:30 ` Eli Zaretskii
0 siblings, 1 reply; 14+ messages in thread
From: Lars Ingebrigtsen @ 2021-08-26 17:24 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: 8035, slpnabble
Eli Zaretskii <eliz@gnu.org> writes:
> expand-file-name also normalizes file names, though. Which is also
> needed in some use cases, e.g. when the /foo/bar/ isn't accessible,
> but /foo/ is, in which case failing to normalize /foo/bar/../quux
> could fail some file I/O function.
Hm, yes, that's a point...
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 17:24 ` Lars Ingebrigtsen
@ 2021-08-26 17:30 ` Eli Zaretskii
0 siblings, 0 replies; 14+ messages in thread
From: Eli Zaretskii @ 2021-08-26 17:30 UTC (permalink / raw)
To: Lars Ingebrigtsen; +Cc: 8035, slpnabble
> From: Lars Ingebrigtsen <larsi@gnus.org>
> Cc: slpnabble@blackberry-hill.com, 8035@debbugs.gnu.org
> Date: Thu, 26 Aug 2021 19:24:28 +0200
>
> Eli Zaretskii <eliz@gnu.org> writes:
>
> > expand-file-name also normalizes file names, though. Which is also
> > needed in some use cases, e.g. when the /foo/bar/ isn't accessible,
> > but /foo/ is, in which case failing to normalize /foo/bar/../quux
> > could fail some file I/O function.
>
> Hm, yes, that's a point...
The OP's use case is clearly documented in the ELisp manual:
Note also that ‘expand-file-name’ does not follow symbolic links at
any level. This results in a difference between the way
‘file-truename’ and ‘expand-file-name’ treat ‘..’. Assuming that
‘/tmp/bar’ is a symbolic link to the directory ‘/tmp/foo/bar’ we
get:
(file-truename "/tmp/bar/../myfile")
⇒ "/tmp/foo/myfile"
(expand-file-name "/tmp/bar/../myfile")
⇒ "/tmp/myfile"
If you may need to follow symbolic links preceding ‘..’, you should
make sure to call ‘file-truename’ without prior direct or indirect
calls to ‘expand-file-name’. *Note Truenames::.
So I think we need to use file-truename if we want to support such
uses of symlinks in "M-x compile" etc.
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 16:29 ` Lars Ingebrigtsen
2021-08-26 16:44 ` Eli Zaretskii
@ 2021-08-26 16:53 ` Andreas Schwab
2021-08-26 17:04 ` Lars Ingebrigtsen
1 sibling, 1 reply; 14+ messages in thread
From: Andreas Schwab @ 2021-08-26 16:53 UTC (permalink / raw)
To: Lars Ingebrigtsen; +Cc: 8035, spucci
On Aug 26 2021, Lars Ingebrigtsen wrote:
> But... this does mean that `file-exists-p' and friends are unreliable
> in the presence of symlinks,
This is not true. It is consistent with all other file handling
functions in Emacs.
Andreas.
--
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510 2552 DF73 E780 A9DA AEC1
"And now for something completely different."
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 16:53 ` Andreas Schwab
@ 2021-08-26 17:04 ` Lars Ingebrigtsen
2021-08-26 17:19 ` Andreas Schwab
0 siblings, 1 reply; 14+ messages in thread
From: Lars Ingebrigtsen @ 2021-08-26 17:04 UTC (permalink / raw)
To: Andreas Schwab; +Cc: 8035, spucci
Andreas Schwab <schwab@linux-m68k.org> writes:
> On Aug 26 2021, Lars Ingebrigtsen wrote:
>
>> But... this does mean that `file-exists-p' and friends are unreliable
>> in the presence of symlinks,
>
> This is not true. It is consistent with all other file handling
> functions in Emacs.
I don't see a contradiction between `file-exists-p' being unreliable
and being consistent with all other file handling functions in Emacs.
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2021-08-26 17:04 ` Lars Ingebrigtsen
@ 2021-08-26 17:19 ` Andreas Schwab
0 siblings, 0 replies; 14+ messages in thread
From: Andreas Schwab @ 2021-08-26 17:19 UTC (permalink / raw)
To: Lars Ingebrigtsen; +Cc: 8035, spucci
On Aug 26 2021, Lars Ingebrigtsen wrote:
> Andreas Schwab <schwab@linux-m68k.org> writes:
>
>> On Aug 26 2021, Lars Ingebrigtsen wrote:
>>
>>> But... this does mean that `file-exists-p' and friends are unreliable
>>> in the presence of symlinks,
>>
>> This is not true. It is consistent with all other file handling
>> functions in Emacs.
>
> I don't see a contradiction between `file-exists-p' being unreliable
> and being consistent with all other file handling functions in Emacs.
It would be unreliable if it were inconsistent.
Andreas.
--
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510 2552 DF73 E780 A9DA AEC1
"And now for something completely different."
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#8035: Processing of .. in a file path after going thru symlink
2011-02-14 3:05 bug#8035: Processing of .. in a file path after going thru symlink spucci
2011-02-19 21:37 ` Glenn Morris
2021-08-26 16:29 ` Lars Ingebrigtsen
@ 2021-08-26 17:30 ` Lars Ingebrigtsen
2 siblings, 0 replies; 14+ messages in thread
From: Lars Ingebrigtsen @ 2021-08-26 17:30 UTC (permalink / raw)
To: spucci; +Cc: 8035
spucci <slpnabble@blackberry-hill.com> writes:
> mkdir dest
> mkdir dest/subdir
> mkdir src
> ln -s ../dest/subdir src/subdir
> echo "#error This is an error" > dest/foo.c
>
> Now M-x compile, and give it cc -c src/subdir/../foo.c
This should now be fixed in Emacs 28.
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
^ permalink raw reply [flat|nested] 14+ messages in thread
end of thread, other threads:[~2021-08-26 17:30 UTC | newest]
Thread overview: 14+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-02-14 3:05 bug#8035: Processing of .. in a file path after going thru symlink spucci
2011-02-19 21:37 ` Glenn Morris
2011-02-20 2:35 ` Steve Pucci
2011-02-20 2:41 ` Steve Pucci
2021-08-26 16:29 ` Lars Ingebrigtsen
2021-08-26 16:44 ` Eli Zaretskii
2021-08-26 17:03 ` Lars Ingebrigtsen
2021-08-26 17:08 ` Eli Zaretskii
2021-08-26 17:24 ` Lars Ingebrigtsen
2021-08-26 17:30 ` Eli Zaretskii
2021-08-26 16:53 ` Andreas Schwab
2021-08-26 17:04 ` Lars Ingebrigtsen
2021-08-26 17:19 ` Andreas Schwab
2021-08-26 17:30 ` Lars Ingebrigtsen
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.