mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* numeric.c (flo_eq): alway check if operands are NaN.
[ruby-list:39685] * lib/cgi/session.rb: use LOCK_SH to read, and a few other improvements. [ruby-core:02328] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@6372 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
5345d52ff6
commit
a6a8847190
8 changed files with 44 additions and 28 deletions
|
@ -364,16 +364,11 @@ class CGI
|
|||
unless check_id(id)
|
||||
raise ArgumentError, "session_id `%s' is invalid" % id
|
||||
end
|
||||
path = dir+"/"+prefix+id
|
||||
path.untaint
|
||||
unless File::exist? path
|
||||
@path = dir+"/"+prefix+id
|
||||
@path.untaint
|
||||
unless File::exist? @path
|
||||
@hash = {}
|
||||
end
|
||||
begin
|
||||
@f = open(path, "r+")
|
||||
rescue Errno::ENOENT
|
||||
@f = open(path, "w+")
|
||||
end
|
||||
end
|
||||
|
||||
# Restore session state from the session's FileStore file.
|
||||
|
@ -382,13 +377,17 @@ class CGI
|
|||
def restore
|
||||
unless @hash
|
||||
@hash = {}
|
||||
@f.flock File::LOCK_EX
|
||||
@f.rewind
|
||||
for line in @f
|
||||
line.chomp!
|
||||
k, v = line.split('=',2)
|
||||
@hash[CGI::unescape(k)] = CGI::unescape(v)
|
||||
end
|
||||
begin
|
||||
f = File.open(@path, 'r')
|
||||
f.flock File::LOCK_SH
|
||||
for line in f
|
||||
line.chomp!
|
||||
k, v = line.split('=',2)
|
||||
@hash[CGI::unescape(k)] = CGI::unescape(v)
|
||||
end
|
||||
ensure
|
||||
f.close unless f.nil?
|
||||
end
|
||||
end
|
||||
@hash
|
||||
end
|
||||
|
@ -396,25 +395,25 @@ class CGI
|
|||
# Save session state to the session's FileStore file.
|
||||
def update
|
||||
return unless @hash
|
||||
@f.rewind
|
||||
for k,v in @hash
|
||||
@f.printf "%s=%s\n", CGI::escape(k), CGI::escape(String(v))
|
||||
end
|
||||
@f.truncate @f.tell
|
||||
begin
|
||||
f = File.open(@path, 'w')
|
||||
f.flock File::LOCK_EX
|
||||
for k,v in @hash
|
||||
f.printf "%s=%s\n", CGI::escape(k), CGI::escape(String(v))
|
||||
end
|
||||
ensure
|
||||
f.close unless f.nil?
|
||||
end
|
||||
end
|
||||
|
||||
# Update and close the session's FileStore file.
|
||||
def close
|
||||
return if @f.closed?
|
||||
update
|
||||
@f.close
|
||||
end
|
||||
|
||||
# Close and delete the session's FileStore file.
|
||||
def delete
|
||||
path = @f.path
|
||||
@f.close
|
||||
File::unlink path
|
||||
File::unlink @path
|
||||
end
|
||||
end
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue