gems.multi_json-1.12.1.lib.multi_json.rb Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sass-maven-plugin Show documentation
Show all versions of sass-maven-plugin Show documentation
A Maven Plugin that compiles Sass files.
require 'multi_json/options'
require 'multi_json/version'
require 'multi_json/adapter_error'
require 'multi_json/parse_error'
require 'multi_json/options_cache'
module MultiJson
include Options
extend self
def default_options=(value)
Kernel.warn "MultiJson.default_options setter is deprecated\n" \
'Use MultiJson.load_options and MultiJson.dump_options instead'
self.load_options = self.dump_options = value
end
def default_options
Kernel.warn "MultiJson.default_options is deprecated\n" \
'Use MultiJson.load_options or MultiJson.dump_options instead'
load_options
end
%w(cached_options reset_cached_options!).each do |method_name|
define_method method_name do |*|
Kernel.warn "MultiJson.#{method_name} method is deprecated and no longer used."
end
end
ALIASES = {'jrjackson' => 'jr_jackson'}
REQUIREMENT_MAP = [
[:oj, 'oj'],
[:yajl, 'yajl'],
[:jr_jackson, 'jrjackson'],
[:json_gem, 'json/ext'],
[:gson, 'gson'],
[:json_pure, 'json/pure'],
]
# The default adapter based on what you currently
# have loaded and installed. First checks to see
# if any adapters are already loaded, then checks
# to see which are installed if none are loaded.
def default_adapter
return :oj if defined?(::Oj)
return :yajl if defined?(::Yajl)
return :jr_jackson if defined?(::JrJackson)
return :json_gem if defined?(::JSON::JSON_LOADED)
return :gson if defined?(::Gson)
REQUIREMENT_MAP.each do |adapter, library|
begin
require library
return adapter
rescue ::LoadError
next
end
end
Kernel.warn '[WARNING] MultiJson is using the default adapter (ok_json). ' \
'We recommend loading a different JSON library to improve performance.'
:ok_json
end
alias_method :default_engine, :default_adapter
# Get the current adapter class.
def adapter
return @adapter if defined?(@adapter) && @adapter
use nil # load default adapter
@adapter
end
alias_method :engine, :adapter
# Set the JSON parser utilizing a symbol, string, or class.
# Supported by default are:
#
# * :oj
# * :json_gem
# * :json_pure
# * :ok_json
# * :yajl
# * :nsjsonserialization (MacRuby only)
# * :gson (JRuby only)
# * :jr_jackson (JRuby only)
def use(new_adapter)
@adapter = load_adapter(new_adapter)
ensure
OptionsCache.reset
end
alias_method :adapter=, :use
alias_method :engine=, :use
def load_adapter(new_adapter)
case new_adapter
when String, Symbol
load_adapter_from_string_name new_adapter.to_s
when NilClass, FalseClass
load_adapter default_adapter
when Class, Module
new_adapter
else
fail ::LoadError, new_adapter
end
rescue ::LoadError => exception
raise AdapterError.build(exception)
end
# Decode a JSON string into Ruby.
#
# Options
#
# :symbolize_keys :: If true, will use symbols instead of strings for the keys.
# :adapter :: If set, the selected adapter will be used for this call.
def load(string, options = {})
adapter = current_adapter(options)
begin
adapter.load(string, options)
rescue adapter::ParseError => exception
raise ParseError.build(exception, string)
end
end
alias_method :decode, :load
def current_adapter(options = {})
if (new_adapter = options[:adapter])
load_adapter(new_adapter)
else
adapter
end
end
# Encodes a Ruby object as JSON.
def dump(object, options = {})
current_adapter(options).dump(object, options)
end
alias_method :encode, :dump
# Executes passed block using specified adapter.
def with_adapter(new_adapter)
old_adapter = adapter
self.adapter = new_adapter
yield
ensure
self.adapter = old_adapter
end
alias_method :with_engine, :with_adapter
private
def load_adapter_from_string_name(name)
name = ALIASES.fetch(name, name)
require "multi_json/adapters/#{name.downcase}"
klass_name = name.to_s.split('_').map(&:capitalize) * ''
MultiJson::Adapters.const_get(klass_name)
end
end
© 2015 - 2025 Weber Informatics LLC | Privacy Policy