module ActiveSupport::XmlMini
def _dasherize(key)
def _dasherize(key) # $2 must be a non-greedy regex for this to work left, middle, right = /\A(_*)(.*?)(_*)\Z/.match(key.strip)[1, 3] "#{left}#{middle.tr('_ ', '--')}#{right}" end
def _parse_binary(bin, entity)
def _parse_binary(bin, entity) case entity["encoding"] when "base64" ::Base64.decode64(bin) else bin end end
def _parse_file(file, entity)
def _parse_file(file, entity) f = StringIO.new(::Base64.decode64(file)) f.extend(FileLike) f.original_filename = entity["name"] f.content_type = entity["content_type"] f end
def backend
def backend current_thread_backend || @backend end
def backend=(name)
def backend=(name) backend = name && cast_backend_name_to_module(name) self.current_thread_backend = backend if current_thread_backend @backend = backend end
def cast_backend_name_to_module(name)
def cast_backend_name_to_module(name) if name.is_a?(Module) name else require "active_support/xml_mini/#{name.downcase}" ActiveSupport.const_get("XmlMini_#{name}") end end
def current_thread_backend
def current_thread_backend IsolatedExecutionState[:xml_mini_backend] end
def current_thread_backend=(name)
def current_thread_backend=(name) IsolatedExecutionState[:xml_mini_backend] = name && cast_backend_name_to_module(name) end
def rename_key(key, options = {})
def rename_key(key, options = {}) camelize = options[:camelize] dasherize = !options.has_key?(:dasherize) || options[:dasherize] if camelize key = true == camelize ? key.camelize : key.camelize(camelize) end key = _dasherize(key) if dasherize key end
def to_tag(key, value, options)
def to_tag(key, value, options) type_name = options.delete(:type) merged_options = options.merge(root: key, skip_instruct: true) if value.is_a?(::Method) || value.is_a?(::Proc) if value.arity == 1 value.call(merged_options) else value.call(merged_options, key.to_s.singularize) end elsif value.respond_to?(:to_xml) value.to_xml(merged_options) else type_name ||= TYPE_NAMES[value.class.name] type_name ||= value.class.name if value && !value.respond_to?(:to_str) type_name = type_name.to_s if type_name type_name = "dateTime" if type_name == "datetime" key = rename_key(key.to_s, options) attributes = options[:skip_types] || type_name.nil? ? {} : { type: type_name } attributes[:nil] = true if value.nil? encoding = options[:encoding] || DEFAULT_ENCODINGS[type_name] attributes[:encoding] = encoding if encoding formatted_value = FORMATTING[type_name] && !value.nil? ? FORMATTING[type_name].call(value) : value options[:builder].tag!(key, formatted_value, attributes) end end
def with_backend(name)
def with_backend(name) old_backend = current_thread_backend self.current_thread_backend = name && cast_backend_name_to_module(name) yield ensure self.current_thread_backend = old_backend end