Skip to content

Commit

Permalink
lib/*: remove closed checks
Browse files Browse the repository at this point in the history
Follow r56795.  Since Ruby 2.2, calling #close on a closed
socket no longer raises exceptions.

* lib/cgi/session.rb (update): remove closed? check
* lib/net/http.rb (finish, transport_request): ditto
* lib/net/imap.rb (disconnect): ditto
* lib/net/pop.rb (do_start, do_finish): ditto
* lib/net/smtp.rb (do_start, do_finish): ditto
* lib/open3.rb (popen_run, pipeline_run): ditto
* lib/pstore.rb (transaction): ditto
* lib/shell/process-controller.rb (sfork):
* lib/tempfile (_close, call, Tempfile.create): ditto
* lib/webrick/httpauth/htdigest.rb (flush): ditto
* lib/webrick/httpauth/htpasswd.rb (flush): ditto
* lib/webrick/server.rb (start_thread, cleanup_shutdown_pipe): ditto

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56865 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
normal committed Nov 21, 2016
1 parent 8e4c8e9 commit f845a9e
Show file tree
Hide file tree
Showing 12 changed files with 23 additions and 27 deletions.
2 changes: 1 addition & 1 deletion lib/cgi/session.rb
Original file line number Diff line number Diff line change
Expand Up @@ -426,7 +426,7 @@ def update
f.close
File.rename @path+".new", @path
ensure
f.close if f and !f.closed?
f.close if f
lockf.close if lockf
end
end
Expand Down
8 changes: 4 additions & 4 deletions lib/net/http.rb
Original file line number Diff line number Diff line change
Expand Up @@ -978,7 +978,7 @@ def finish

def do_finish
@started = false
@socket.close if @socket and not @socket.closed?
@socket.close if @socket
@socket = nil
end
private :do_finish
Expand Down Expand Up @@ -1463,20 +1463,20 @@ def transport_request(req)
Timeout::Error => exception
if count == 0 && IDEMPOTENT_METHODS_.include?(req.method)
count += 1
@socket.close if @socket and not @socket.closed?
@socket.close if @socket
D "Conn close because of error #{exception}, and retry"
retry
end
D "Conn close because of error #{exception}"
@socket.close if @socket and not @socket.closed?
@socket.close if @socket
raise
end

end_transport req, res
res
rescue => exception
D "Conn close because of error #{exception}"
@socket.close if @socket and not @socket.closed?
@socket.close if @socket
raise exception
end

Expand Down
4 changes: 1 addition & 3 deletions lib/net/imap.rb
Original file line number Diff line number Diff line change
Expand Up @@ -329,9 +329,7 @@ def disconnect
end
@receiver_thread.join
synchronize do
unless @sock.closed?
@sock.close
end
@sock.close
end
raise e if e
end
Expand Down
4 changes: 2 additions & 2 deletions lib/net/pop.rb
Original file line number Diff line number Diff line change
Expand Up @@ -570,7 +570,7 @@ def do_start(account, password) # :nodoc:
ensure
# Authentication failed, clean up connection.
unless @started
s.close if s and not s.closed?
s.close if s
@socket = nil
@command = nil
end
Expand Down Expand Up @@ -601,7 +601,7 @@ def do_finish # :nodoc:
ensure
@started = false
@command = nil
@socket.close if @socket and not @socket.closed?
@socket.close if @socket
@socket = nil
end
private :do_finish
Expand Down
4 changes: 2 additions & 2 deletions lib/net/smtp.rb
Original file line number Diff line number Diff line change
Expand Up @@ -567,7 +567,7 @@ def do_start(helo_domain, user, secret, authtype)
ensure
unless @started
# authentication failed, cancel connection.
s.close if s and not s.closed?
s.close if s
@socket = nil
end
end
Expand Down Expand Up @@ -613,7 +613,7 @@ def do_finish
ensure
@started = false
@error_occurred = false
@socket.close if @socket and not @socket.closed?
@socket.close if @socket
@socket = nil
end

Expand Down
4 changes: 2 additions & 2 deletions lib/open3.rb
Original file line number Diff line number Diff line change
Expand Up @@ -204,7 +204,7 @@ def popen_run(cmd, opts, child_io, parent_io) # :nodoc:
begin
return yield(*result)
ensure
parent_io.each{|io| io.close unless io.closed?}
parent_io.each{|io| io.close }
wait_thr.join
end
end
Expand Down Expand Up @@ -655,7 +655,7 @@ def pipeline_run(cmds, pipeline_opts, child_io, parent_io) # :nodoc:
begin
return yield(*result)
ensure
parent_io.each{|io| io.close unless io.closed?}
parent_io.each{|io| io.close }
wait_thrs.each {|t| t.join }
end
end
Expand Down
2 changes: 1 addition & 1 deletion lib/pstore.rb
Original file line number Diff line number Diff line change
Expand Up @@ -335,7 +335,7 @@ def transaction(read_only = false) # :yields: pstore
save_data(checksum, original_data_size, file)
end
ensure
file.close if !file.closed?
file.close
end
else
# This can only occur if read_only == true.
Expand Down
2 changes: 1 addition & 1 deletion lib/shell/process-controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -260,7 +260,7 @@ def sfork(command)

ObjectSpace.each_object(IO) do |io|
if ![STDIN, STDOUT, STDERR].include?(io)
io.close unless io.closed?
io.close
end
end

Expand Down
6 changes: 3 additions & 3 deletions lib/tempfile.rb
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ def open
end

def _close # :nodoc:
@tmpfile.close unless @tmpfile.closed?
@tmpfile.close
end
protected :_close

Expand Down Expand Up @@ -252,7 +252,7 @@ def call(*args)

warn "removing #{@tmpfile.path}..." if $DEBUG

@tmpfile.close unless @tmpfile.closed?
@tmpfile.close
begin
File.unlink(@tmpfile.path)
rescue Errno::ENOENT
Expand Down Expand Up @@ -334,7 +334,7 @@ def Tempfile.create(basename="", tmpdir=nil, mode: 0, **options)
begin
yield tmpfile
ensure
tmpfile.close if !tmpfile.closed?
tmpfile.close
File.unlink tmpfile
end
else
Expand Down
2 changes: 1 addition & 1 deletion lib/webrick/httpauth/htdigest.rb
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ def flush(output=nil)
File::rename(tmp.path, output)
renamed = true
ensure
tmp.close if !tmp.closed?
tmp.close
File.unlink(tmp.path) if !renamed
end
end
Expand Down
2 changes: 1 addition & 1 deletion lib/webrick/httpauth/htpasswd.rb
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ def flush(output=nil)
File::rename(tmp.path, output)
renamed = true
ensure
tmp.close if !tmp.closed?
tmp.close
File.unlink(tmp.path) if !renamed
end
end
Expand Down
10 changes: 4 additions & 6 deletions lib/webrick/server.rb
Original file line number Diff line number Diff line change
Expand Up @@ -309,7 +309,7 @@ def start_thread(sock, &block)
else
@logger.debug "close: <address unknown>"
end
sock.close unless sock.closed?
sock.close
end
}
end
Expand All @@ -334,11 +334,9 @@ def cleanup_shutdown_pipe(shutdown_pipe)
@shutdown_pipe = nil
return if !shutdown_pipe
shutdown_pipe.each {|io|
if !io.closed?
begin
io.close
rescue IOError # another thread closed io.
end
begin
io.close
rescue IOError # another thread closed io.
end
}
end
Expand Down

0 comments on commit f845a9e

Please sign in to comment.