1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

* lib/pathname.rb (realpath_rec): fix handling of symlink to absolute

path.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4741 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
akr 2003-10-11 05:37:41 +00:00
parent 764722dc27
commit 6fc32eb8bb
2 changed files with 13 additions and 6 deletions

View file

@ -1,3 +1,8 @@
Sat Oct 11 14:35:14 2003 Tanaka Akira <akr@m17n.org>
* lib/pathname.rb (realpath_rec): fix handling of symlink to absolute
path.
Sat Oct 11 10:19:39 2003 Shugo Maeda <shugo@ruby-lang.org>
* lib/monitor.rb: handle exceptions correctly. Thanks, Gennady

View file

@ -111,11 +111,7 @@ class Pathname
# it may return relative pathname.
# Otherwise it returns absolute pathname.
def realpath(force_absolute=true)
if relative? && force_absolute
path = File.join Dir.pwd, @path
else
path = @path
end
path = @path
stats = {}
if %r{\A/} =~ path || realpath_root?('.', stats)
resolved = '/'
@ -123,7 +119,12 @@ class Pathname
resolved = '.'
end
resolved = realpath_rec(resolved, path, stats)
Pathname.new(resolved)
if %r{\A/} !~ resolved && force_absolute
# Note that Dir.pwd and resolved has no symlinks.
Pathname.new(File.join(Dir.pwd, resolved)).cleanpath
else
Pathname.new(resolved)
end
end
def realpath_root?(path, stats) # :nodoc:
@ -156,6 +157,7 @@ class Pathname
if File.lstat(path).symlink?
raise Errno::ELOOP.new(path) if rec.include? path
link = File.readlink path
resolved = '/' if %r{\A/} =~ link
begin
rec[path] = true
resolved = realpath_rec(resolved, link, stats, rec)