2005-02-15 11:21:56 -05:00
|
|
|
#--
|
|
|
|
# Copyright (c) 2005 David Heinemeier Hansson
|
|
|
|
#
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
# a copy of this software and associated documentation files (the
|
|
|
|
# "Software"), to deal in the Software without restriction, including
|
|
|
|
# without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
# permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
# the following conditions:
|
|
|
|
#
|
|
|
|
# The above copyright notice and this permission notice shall be
|
|
|
|
# included in all copies or substantial portions of the Software.
|
|
|
|
#
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
|
|
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
|
|
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
|
|
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
#++
|
|
|
|
|
2008-11-23 19:11:32 -05:00
|
|
|
module ActiveSupport
|
2009-05-20 20:11:41 -04:00
|
|
|
class << self
|
|
|
|
attr_accessor :load_all_hooks
|
|
|
|
def on_load_all(&hook) load_all_hooks << hook end
|
|
|
|
def load_all!; load_all_hooks.each { |hook| hook.call } end
|
|
|
|
end
|
|
|
|
self.load_all_hooks = []
|
|
|
|
|
|
|
|
on_load_all do
|
|
|
|
[Dependencies, Deprecation, Gzip, MessageVerifier, Multibyte, SecureRandom]
|
2008-11-24 12:35:21 -05:00
|
|
|
end
|
2008-11-23 19:11:32 -05:00
|
|
|
end
|
|
|
|
|
2009-12-03 12:06:01 -05:00
|
|
|
require "active_support/dependencies/autoload"
|
|
|
|
|
|
|
|
module ActiveSupport
|
|
|
|
extend ActiveSupport::Autoload
|
|
|
|
|
2009-12-22 18:27:37 -05:00
|
|
|
# TODO: Narrow this list down
|
|
|
|
eager_autoload do
|
|
|
|
autoload :BacktraceCleaner
|
|
|
|
autoload :Base64
|
|
|
|
autoload :BasicObject
|
|
|
|
autoload :Benchmarkable
|
|
|
|
autoload :BufferedLogger
|
|
|
|
autoload :Cache
|
|
|
|
autoload :Callbacks
|
|
|
|
autoload :Concern
|
|
|
|
autoload :Configurable
|
|
|
|
autoload :Deprecation
|
|
|
|
autoload :Gzip
|
|
|
|
autoload :Inflector
|
|
|
|
autoload :Memoizable
|
|
|
|
autoload :MessageEncryptor
|
|
|
|
autoload :MessageVerifier
|
|
|
|
autoload :Multibyte
|
|
|
|
autoload :OptionMerger
|
|
|
|
autoload :OrderedHash
|
|
|
|
autoload :OrderedOptions
|
|
|
|
autoload :Notifications
|
|
|
|
autoload :Rescuable
|
|
|
|
autoload :SecureRandom
|
|
|
|
autoload :StringInquirer
|
|
|
|
autoload :XmlMini
|
|
|
|
end
|
2010-01-04 17:22:39 -05:00
|
|
|
|
For performance reasons, you can no longer call html_safe! on Strings. Instead, all Strings are always not html_safe?. Instead, you can get a SafeBuffer from a String by calling #html_safe, which will SafeBuffer.new(self).
* Additionally, instead of doing concat("</form>".html_safe), you can do
safe_concat("</form>"), which will skip both the flag set, and the flag
check.
* For the first pass, I converted virtually all #html_safe!s to #html_safe,
and the tests pass. A further optimization would be to try to use
#safe_concat as much as possible, reducing the performance impact if
we know up front that a String is safe.
2010-01-31 22:17:42 -05:00
|
|
|
autoload :SafeBuffer, "active_support/core_ext/string/output_safety"
|
2010-01-04 17:22:39 -05:00
|
|
|
autoload :TestCase
|
2009-12-03 12:06:01 -05:00
|
|
|
end
|