aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/lib/active_support/core_ext/date/behavior.rb
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2009-03-21 03:43:43 -0700
committerJeremy Kemper <jeremy@bitsweat.net>2009-03-21 04:35:16 -0700
commitc43dec888a4823b36ee4369be0558b94d475d734 (patch)
tree42decf21f3734bd724db0fa15d8dcb766331c7d6 /activesupport/lib/active_support/core_ext/date/behavior.rb
parentbd28c7b1b8a569d431cc93924ad1ff5fdb59f401 (diff)
downloadrails-c43dec888a4823b36ee4369be0558b94d475d734.tar.gz
rails-c43dec888a4823b36ee4369be0558b94d475d734.tar.bz2
rails-c43dec888a4823b36ee4369be0558b94d475d734.zip
Convert date extension modules to class reopens
Diffstat (limited to 'activesupport/lib/active_support/core_ext/date/behavior.rb')
-rw-r--r--activesupport/lib/active_support/core_ext/date/behavior.rb42
1 files changed, 0 insertions, 42 deletions
diff --git a/activesupport/lib/active_support/core_ext/date/behavior.rb b/activesupport/lib/active_support/core_ext/date/behavior.rb
deleted file mode 100644
index bd378eb375..0000000000
--- a/activesupport/lib/active_support/core_ext/date/behavior.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-require 'date'
-
-module ActiveSupport #:nodoc:
- module CoreExtensions #:nodoc:
- module Date #:nodoc:
- module Behavior
- # Enable more predictable duck-typing on Date-like classes. See
- # Object#acts_like?.
- def acts_like_date?
- true
- end
-
- # Date memoizes some instance methods using metaprogramming to wrap
- # the methods with one that caches the result in an instance variable.
- #
- # If a Date is frozen but the memoized method hasn't been called, the
- # first call will result in a frozen object error since the memo
- # instance variable is uninitialized.
- #
- # Work around by eagerly memoizing before freezing.
- #
- # Ruby 1.9 uses a preinitialized instance variable so it's unaffected.
- # This hack is as close as we can get to feature detection:
- begin
- ::Date.today.freeze.jd
- rescue => frozen_object_error
- if frozen_object_error.message =~ /frozen/
- def freeze #:nodoc:
- self.class.private_instance_methods(false).each do |m|
- if m.to_s =~ /\A__\d+__\Z/
- instance_variable_set(:"@#{m}", [send(m)])
- end
- end
-
- super
- end
- end
- end
- end
- end
- end
-end