2008-09-21 11:21:30 -04:00
|
|
|
# encoding: utf-8
|
|
|
|
|
2009-04-22 20:41:28 -04:00
|
|
|
require 'active_support/core_ext/module/attribute_accessors'
|
|
|
|
|
2008-09-21 11:21:30 -04:00
|
|
|
module ActiveSupport #:nodoc:
|
2008-09-21 11:28:05 -04:00
|
|
|
module Multibyte
|
2008-09-21 11:21:30 -04:00
|
|
|
# A list of all available normalization forms. See http://www.unicode.org/reports/tr15/tr15-29.html for more
|
|
|
|
# information about normalization.
|
2008-10-06 13:42:51 -04:00
|
|
|
NORMALIZATION_FORMS = [:c, :kc, :d, :kd]
|
2006-10-03 19:45:32 -04:00
|
|
|
|
2008-09-21 11:21:30 -04:00
|
|
|
# The Unicode version that is supported by the implementation
|
|
|
|
UNICODE_VERSION = '5.1.0'
|
|
|
|
|
|
|
|
# The default normalization used for operations that require normalization. It can be set to any of the
|
2008-10-06 13:42:51 -04:00
|
|
|
# normalizations in NORMALIZATION_FORMS.
|
2008-09-21 11:21:30 -04:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
# ActiveSupport::Multibyte.default_normalization_form = :c
|
|
|
|
mattr_accessor :default_normalization_form
|
|
|
|
self.default_normalization_form = :kc
|
|
|
|
|
|
|
|
# The proxy class returned when calling mb_chars. You can use this accessor to configure your own proxy
|
|
|
|
# class so you can support other encodings. See the ActiveSupport::Multibyte::Chars implementation for
|
|
|
|
# an example how to do this.
|
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
# ActiveSupport::Multibyte.proxy_class = CharsForUTF32
|
2009-08-31 15:16:22 -04:00
|
|
|
def self.proxy_class=(klass)
|
|
|
|
@proxy_class = klass
|
|
|
|
end
|
|
|
|
|
|
|
|
# Returns the currect proxy class
|
|
|
|
def self.proxy_class
|
|
|
|
@proxy_class ||= ActiveSupport::Multibyte::Chars
|
|
|
|
end
|
|
|
|
|
|
|
|
# Regular expressions that describe valid byte sequences for a character
|
|
|
|
VALID_CHARACTER = {
|
|
|
|
# Borrowed from the Kconv library by Shinji KONO - (also as seen on the W3C site)
|
|
|
|
'UTF-8' => /\A(?:
|
|
|
|
[\x00-\x7f] |
|
|
|
|
[\xc2-\xdf] [\x80-\xbf] |
|
|
|
|
\xe0 [\xa0-\xbf] [\x80-\xbf] |
|
|
|
|
[\xe1-\xef] [\x80-\xbf] [\x80-\xbf] |
|
|
|
|
\xf0 [\x90-\xbf] [\x80-\xbf] [\x80-\xbf] |
|
|
|
|
[\xf1-\xf3] [\x80-\xbf] [\x80-\xbf] [\x80-\xbf] |
|
|
|
|
\xf4 [\x80-\x8f] [\x80-\xbf] [\x80-\xbf])\z /xn,
|
|
|
|
# Quick check for valid Shift-JIS characters, disregards the odd-even pairing
|
|
|
|
'Shift_JIS' => /\A(?:
|
|
|
|
[\x00-\x7e \xa1-\xdf] |
|
|
|
|
[\x81-\x9f \xe0-\xef] [\x40-\x7e \x80-\x9e \x9f-\xfc])\z /xn
|
|
|
|
}
|
2008-09-21 11:21:30 -04:00
|
|
|
end
|
2008-09-21 11:28:05 -04:00
|
|
|
end
|
2009-08-31 15:16:22 -04:00
|
|
|
|
|
|
|
require 'active_support/multibyte/chars'
|
|
|
|
require 'active_support/multibyte/exceptions'
|
|
|
|
require 'active_support/multibyte/unicode_database'
|
|
|
|
require 'active_support/multibyte/utils'
|