summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/tempfile.rb18
-rw-r--r--test/test_tempfile.rb12
2 files changed, 18 insertions, 12 deletions
diff --git a/lib/tempfile.rb b/lib/tempfile.rb
index bb05080cec..2f8a39cfe5 100644
--- a/lib/tempfile.rb
+++ b/lib/tempfile.rb
@@ -556,7 +556,7 @@ end
# Related: Tempfile.new.
#
def Tempfile.create(basename="", tmpdir=nil, mode: 0, anonymous: false, **options, &block)
- if anonymous && RUBY_VERSION >= '3.2'
+ if anonymous
create_anonymous(basename, tmpdir, mode: mode, **options, &block)
else
create_with_filename(basename, tmpdir, mode: mode, **options, &block)
@@ -593,6 +593,18 @@ private def create_with_filename(basename="", tmpdir=nil, mode: 0, **options)
end
end
+File.open(IO::NULL) do |f|
+ File.new(f.fileno, autoclose: false, path: "").path
+rescue IOError
+ module PathAttr # :nodoc:
+ attr_reader :path
+
+ def self.set_path(file, path)
+ file.extend(self).instance_variable_set(:@path, path)
+ end
+ end
+end
+
private def create_anonymous(basename="", tmpdir=nil, mode: 0, **options, &block)
tmpfile = nil
tmpdir = Dir.tmpdir() if tmpdir.nil?
@@ -608,12 +620,14 @@ private def create_anonymous(basename="", tmpdir=nil, mode: 0, **options, &block
mode |= File::SHARE_DELETE | File::BINARY # Windows needs them to unlink the opened file.
tmpfile = create_with_filename(basename, tmpdir, mode: mode, **options)
File.unlink(tmpfile.path)
+ tmppath = tmpfile.path
end
path = File.join(tmpdir, '')
- if tmpfile.path != path
+ unless tmppath == path
# clear path.
tmpfile.autoclose = false
tmpfile = File.new(tmpfile.fileno, mode: File::RDWR, path: path)
+ PathAttr.set_path(tmpfile, path) if defined?(PathAttr)
end
if block
begin
diff --git a/test/test_tempfile.rb b/test/test_tempfile.rb
index 931b512ee0..8077cc3603 100644
--- a/test/test_tempfile.rb
+++ b/test/test_tempfile.rb
@@ -488,11 +488,7 @@ puts Tempfile.new('foo').path
Dir.mktmpdir {|d|
t = Tempfile.create("", d, anonymous: true)
t.close
- if RUBY_VERSION >= '3.2'
- assert_equal([], Dir.children(d))
- else
- refute_equal([], Dir.children(d))
- end
+ assert_equal([], Dir.children(d))
}
end
@@ -500,11 +496,7 @@ puts Tempfile.new('foo').path
Dir.mktmpdir {|d|
begin
t = Tempfile.create("", d, anonymous: true)
- if RUBY_VERSION >= '3.2'
- assert_equal(File.join(d, ""), t.path)
- else
- refute_equal(File.join(d, ""), t.path)
- end
+ assert_equal(File.join(d, ""), t.path)
ensure
t.close if t
end