aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2006-08-20 05:28:47 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2006-08-20 05:28:47 +0000
commit04d2d5f2884677542b7062ece98bd91978e78b2b (patch)
tree5574a64e7bf36b7314eb8995eecd35bf861035ae /actionpack
parent70577d0dcab2f1756e05c98565acf525e55dc51f (diff)
downloadrails-04d2d5f2884677542b7062ece98bd91978e78b2b.tar.gz
rails-04d2d5f2884677542b7062ece98bd91978e78b2b.tar.bz2
rails-04d2d5f2884677542b7062ece98bd91978e78b2b.zip
Correct example in cookies docs. Closes #5832.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4793 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionpack')
-rw-r--r--actionpack/CHANGELOG2
-rw-r--r--actionpack/lib/action_controller/cookies.rb15
2 files changed, 10 insertions, 7 deletions
diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG
index 587032ab4b..f2f969a53f 100644
--- a/actionpack/CHANGELOG
+++ b/actionpack/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*
+* Correct example in cookies docs. #5832 [jessemerriman@warpmail.net]
+
* Updated to script.aculo.us 1.6.2 [Thomas Fuchs]
* Relax Routing's anchor pattern warning; it was preventing use of [^/] inside restrictions. [Nicholas Seckar]
diff --git a/actionpack/lib/action_controller/cookies.rb b/actionpack/lib/action_controller/cookies.rb
index 5785805b2b..f5484f3676 100644
--- a/actionpack/lib/action_controller/cookies.rb
+++ b/actionpack/lib/action_controller/cookies.rb
@@ -4,13 +4,14 @@ module ActionController #:nodoc:
# itself back -- just the value it holds). Examples for writing:
#
# cookies[:user_name] = "david" # => Will set a simple session cookie
- # cookies[:login] = { :value => "XJ-122", :expires => Time.now + 360} # => Will set a cookie that expires in 1 hour
- #
+ # cookies[:login] = { :value => "XJ-122", :expires => 1.hour.from_now }
+ # # => Will set a cookie that expires in 1 hour
+ #
# Examples for reading:
#
# cookies[:user_name] # => "david"
# cookies.size # => 2
- #
+ #
# Example for deleting:
#
# cookies.delete :user_name
@@ -35,7 +36,7 @@ module ActionController #:nodoc:
@response.headers["cookie"] << CGI::Cookie.new(*options)
end
end
-
+
class CookieJar < Hash #:nodoc:
def initialize(controller)
@controller, @cookies = controller, controller.instance_variable_get("@cookies")
@@ -48,7 +49,7 @@ module ActionController #:nodoc:
def [](name)
@cookies[name.to_s].value.first if @cookies[name.to_s] && @cookies[name.to_s].respond_to?(:value)
end
-
+
def []=(name, options)
if options.is_a?(Hash)
options = options.inject({}) { |options, pair| options[pair.first.to_s] = pair.last; options }
@@ -56,10 +57,10 @@ module ActionController #:nodoc:
else
options = { "name" => name.to_s, "value" => options }
end
-
+
set_cookie(options)
end
-
+
# Removes the cookie on the client machine by setting the value to an empty string
# and setting its expiration date into the past
def delete(name)