mirror of
https://github.com/ruby/ruby.git
synced 2025-09-20 11:03:58 +02:00
merge revision(s) 34413:
* lib/tempfile.rb (Tempfile#unlink, Tempfile::Remover#call): Just call File.unlink and ignore ENOENT because existence check before unlinking does not help in terms of race condition. * lib/tempfile.rb (Tempfile#unlink, Tempfile::Remover#call): My comment about thread safeness is obsolete. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_3@34572 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
c9fac6977b
commit
66f39c771a
3 changed files with 27 additions and 17 deletions
|
@ -1,3 +1,12 @@
|
|||
Sun Feb 12 16:53:18 2012 Akinori MUSHA <knu@iDaemons.org>
|
||||
|
||||
* lib/tempfile.rb (Tempfile#unlink, Tempfile::Remover#call): Just
|
||||
call File.unlink and ignore ENOENT because existence check
|
||||
before unlinking does not help in terms of race condition.
|
||||
|
||||
* lib/tempfile.rb (Tempfile#unlink, Tempfile::Remover#call): My
|
||||
comment about thread safeness is obsolete.
|
||||
|
||||
Sun Feb 12 16:50:28 2012 Akinori MUSHA <knu@iDaemons.org>
|
||||
|
||||
* lib/shellwords.rb: Fix rdoc markups.
|
||||
|
|
|
@ -227,18 +227,17 @@ class Tempfile < DelegateClass(File)
|
|||
# # to do so again.
|
||||
# end
|
||||
def unlink
|
||||
# keep this order for thread safeness
|
||||
return unless @tmpname
|
||||
begin
|
||||
if File.exist?(@tmpname)
|
||||
File.unlink(@tmpname)
|
||||
rescue Errno::ENOENT
|
||||
rescue Errno::EACCES
|
||||
# may not be able to unlink on Windows; just ignore
|
||||
return
|
||||
end
|
||||
# remove tmpname from remover
|
||||
@data[0] = @data[1] = nil
|
||||
@tmpname = nil
|
||||
rescue Errno::EACCES
|
||||
# may not be able to unlink on Windows; just ignore
|
||||
end
|
||||
end
|
||||
alias delete unlink
|
||||
|
||||
|
@ -270,22 +269,24 @@ class Tempfile < DelegateClass(File)
|
|||
end
|
||||
|
||||
def call(*args)
|
||||
if @pid == $$
|
||||
return if @pid != $$
|
||||
|
||||
path, tmpfile = *@data
|
||||
|
||||
STDERR.print "removing ", path, "..." if $DEBUG
|
||||
|
||||
tmpfile.close if tmpfile
|
||||
|
||||
# keep this order for thread safeness
|
||||
if path
|
||||
File.unlink(path) if File.exist?(path)
|
||||
begin
|
||||
File.unlink(path)
|
||||
rescue Errno::ENOENT
|
||||
end
|
||||
end
|
||||
|
||||
STDERR.print "done\n" if $DEBUG
|
||||
end
|
||||
end
|
||||
end
|
||||
# :startdoc:
|
||||
|
||||
class << self
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
#define RUBY_VERSION "1.9.3"
|
||||
#define RUBY_PATCHLEVEL 100
|
||||
#define RUBY_PATCHLEVEL 101
|
||||
|
||||
#define RUBY_RELEASE_DATE "2012-02-12"
|
||||
#define RUBY_RELEASE_YEAR 2012
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue