aboutsummaryrefslogtreecommitdiffstats
path: root/config/initializers
diff options
context:
space:
mode:
Diffstat (limited to 'config/initializers')
-rw-r--r--config/initializers/rails2314_ruby193_monkey_patches.rb1
-rw-r--r--config/initializers/utf8_monkey_patches.rb90
2 files changed, 91 insertions, 0 deletions
diff --git a/config/initializers/rails2314_ruby193_monkey_patches.rb b/config/initializers/rails2314_ruby193_monkey_patches.rb
new file mode 100644
index 000000000..8bc433b13
--- /dev/null
+++ b/config/initializers/rails2314_ruby193_monkey_patches.rb
@@ -0,0 +1 @@
+# # -*- encoding : utf-8 -*- # # This little guy is needed unless you want to define a helper for every single one of your controllers # MissingSourceFile::REGEXPS << [/^cannot load such file -- (.+)$/i, 1] # # # TZInfo needs to be patched. In particular, you'll need to re-implement the datetime_new! method: # require 'tzinfo' # # module TZInfo # # # Methods to support different versions of Ruby. # module RubyCoreSupport #:nodoc: # # Ruby 1.8.6 introduced new! and deprecated new0. # # Ruby 1.9.0 removed new0. # # Ruby trunk revision 31668 removed the new! method. # # Still support new0 for better performance on older versions of Ruby (new0 indicates # # that the rational has already been reduced to its lowest terms). # # Fallback to jd with conversion from ajd if new! and new0 are unavailable. # if DateTime.respond_to? :new! # def self.datetime_new!(ajd = 0, of = 0, sg = Date::ITALY) # DateTime.new!(ajd, of, sg) # end # elsif DateTime.respond_to? :new0 # def self.datetime_new!(ajd = 0, of = 0, sg = Date::ITALY) # DateTime.new0(ajd, of, sg) # end # else # HALF_DAYS_IN_DAY = rational_new!(1, 2) # # def self.datetime_new!(ajd = 0, of = 0, sg = Date::ITALY) # # Convert from an Astronomical Julian Day number to a civil Julian Day number. # jd = ajd + of + HALF_DAYS_IN_DAY # # # Ruby trunk revision 31862 changed the behaviour of DateTime.jd so that it will no # # longer accept a fractional civil Julian Day number if further arguments are specified. # # Calculate the hours, minutes and seconds to pass to jd. # # jd_i = jd.to_i # jd_i -= 1 if jd < 0 # hours = (jd - jd_i) * 24 # hours_i = hours.to_i # minutes = (hours - hours_i) * 60 # minutes_i = minutes.to_i # seconds = (minutes - minutes_i) * 60 # # DateTime.jd(jd_i, hours_i, minutes_i, seconds, of, sg) # end # end # end # end # # # Finally, we have this innocuous looking patch. Without it, queries like this: current_account.tickets.recent.count # # would instantiate AR objects all (!!) tickets in the account, not merely return a count of the recent ones. # # See https://rails.lighthouseapp.com/projects/8994/tickets/5410-multiple-database-queries-when-chaining-named-scopes-with-rails-238-and-ruby-192 # # (The patch in that lighthouse bug was not, in fact, merged in). # module ActiveRecord # module Associations # class AssociationProxy # def respond_to_missing?(meth, incl_priv) # false # end # end # end # end \ No newline at end of file
diff --git a/config/initializers/utf8_monkey_patches.rb b/config/initializers/utf8_monkey_patches.rb
new file mode 100644
index 000000000..2cead82ef
--- /dev/null
+++ b/config/initializers/utf8_monkey_patches.rb
@@ -0,0 +1,90 @@
+# if RUBY_VERSION.to_f >= 1.9
+# # -*- encoding : utf-8 -*-
+# # Make sure the logger supports encodings properly.
+# module ActiveSupport
+# class BufferedLogger
+# def add(severity, message = nil, progname = nil, &block)
+# return if @level > severity
+# message = (message || (block && block.call) || progname).to_s
+#
+# # If a newline is necessary then create a new message ending with a newline.
+# # Ensures that the original message is not mutated.
+# message = "#{message}\n" unless message[-1] == ?\n
+# buffer << message.force_encoding(Encoding.default_external)
+# auto_flush
+# message
+# end
+# end
+# end
+#
+# # This makes it so all parameters get converted to UTF-8 before they hit your app. If someone sends invalid UTF-8 to your server, raise an exception.
+# # At UserVoice, we rescue this exception and show a custom error page.
+# class ActionController::InvalidByteSequenceErrorFromParams < Encoding::InvalidByteSequenceError; end
+# class ActionController::Base
+#
+# def force_utf8_params
+# traverse = lambda do |object, block|
+# if object.kind_of?(Hash)
+# object.each_value { |o| traverse.call(o, block) }
+# elsif object.kind_of?(Array)
+# object.each { |o| traverse.call(o, block) }
+# else
+# block.call(object)
+# end
+# object
+# end
+# force_encoding = lambda do |o|
+# if o.respond_to?(:force_encoding)
+# o.force_encoding(Encoding::UTF_8)
+# raise ActionController::InvalidByteSequenceErrorFromParams unless o.valid_encoding?
+# end
+# if o.respond_to?(:original_filename)
+# o.original_filename.force_encoding(Encoding::UTF_8)
+# raise ActionController::InvalidByteSequenceErrorFromParams unless o.original_filename.valid_encoding?
+# end
+# end
+# traverse.call(params, force_encoding)
+# path_str = request.path.to_s
+# if path_str.respond_to?(:force_encoding)
+# path_str.force_encoding(Encoding::UTF_8)
+# raise ActionController::InvalidByteSequenceErrorFromParams unless path_str.valid_encoding?
+# end
+# end
+# before_filter :force_utf8_params
+# end
+#
+#
+# # Serialized columns in AR don't support UTF-8 well, so set the encoding on those as well.
+# class ActiveRecord::Base
+# def unserialize_attribute_with_utf8(attr_name)
+# traverse = lambda do |object, block|
+# if object.kind_of?(Hash)
+# object.each_value { |o| traverse.call(o, block) }
+# elsif object.kind_of?(Array)
+# object.each { |o| traverse.call(o, block) }
+# else
+# block.call(object)
+# end
+# object
+# end
+# force_encoding = lambda do |o|
+# o.force_encoding(Encoding::UTF_8) if o.respond_to?(:force_encoding)
+# end
+# value = unserialize_attribute_without_utf8(attr_name)
+# traverse.call(value, force_encoding)
+# end
+# alias_method_chain :unserialize_attribute, :utf8
+# end
+#
+# # Make sure the flash sets the encoding to UTF-8 as well.
+# module ActionController
+# module Flash
+# class FlashHash
+# def [](k)
+# v = super
+# v.is_a?(String) ? v.force_encoding("UTF-8") : v
+# end
+# end
+# end
+# end
+# end \ No newline at end of file