aboutsummaryrefslogtreecommitdiffstats
path: root/lib/cgi
diff options
context:
space:
mode:
authorryan <ryan@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-11-16 03:01:59 +0000
committerryan <ryan@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-11-16 03:01:59 +0000
commit36ed53ff93d728a31764ebb0e553d5b8432eba3b (patch)
tree3817c92f576b95e394c5ce5b360710769548370e /lib/cgi
parent8c3f13f98d8d2280f1799d5e2e58260bb9eb71c1 (diff)
downloadruby-36ed53ff93d728a31764ebb0e553d5b8432eba3b.tar.gz
Minor cleanup to improve hash use
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25792 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/cgi')
-rw-r--r--lib/cgi/core.rb7
1 files changed, 3 insertions, 4 deletions
diff --git a/lib/cgi/core.rb b/lib/cgi/core.rb
index 3930663331..e216cafe08 100644
--- a/lib/cgi/core.rb
+++ b/lib/cgi/core.rb
@@ -426,7 +426,7 @@ class CGI
raise EOFError.new("no content body") unless status
raise EOFError.new("bad content body") unless first_line == status
## parse and set params
- params = {}
+ params = Hash.new { |h,k| h[k] = [] }
@files = {}
boundary_rexp = /--#{Regexp.quote(boundary)}(#{EOL}|--)/
boundary_size = "#{EOL}--#{boundary}#{EOL}".bytesize
@@ -496,7 +496,7 @@ class CGI
name = $1 || $2 || ''
if body.original_filename.empty?
value=body.read.dup.force_encoding(@accept_charset)
- (params[name] ||= []) << value
+ params[name] << value
unless value.valid_encoding?
if @accept_charset_error_block
@accept_charset_error_block.call(name,value)
@@ -510,7 +510,7 @@ class CGI
define_method(:content_type){""}
end
else
- (params[name] ||= []) << body
+ params[name] << body
@files[name]=body
end
## break loop
@@ -518,7 +518,6 @@ class CGI
break if content_length == -1
end
raise EOFError, "bad boundary end of body part" unless boundary_end =~ /--/
- params.default = []
params
end # read_multipart
private :read_multipart