2012-04-17 20:04:12 -04:00
|
|
|
# :stopdoc:
|
|
|
|
|
|
|
|
# Hack to handle syck's DefaultKey bug
|
|
|
|
#
|
|
|
|
# This file is always loaded AFTER either syck or psych are already
|
|
|
|
# loaded. It then looks at what constants are available and creates
|
|
|
|
# a consistent view on all rubys.
|
|
|
|
#
|
|
|
|
# All this is so that there is always a YAML::Syck::DefaultKey
|
|
|
|
# class no matter if the full yaml library has loaded or not.
|
|
|
|
#
|
|
|
|
|
2013-10-19 21:33:19 -04:00
|
|
|
module YAML # :nodoc:
|
2012-04-17 20:04:12 -04:00
|
|
|
# In newer 1.9.2, there is a Syck toplevel constant instead of it
|
2013-12-19 17:09:19 -05:00
|
|
|
# being underneath YAML. If so, reference it back under YAML as
|
2012-04-17 20:04:12 -04:00
|
|
|
# well.
|
|
|
|
if defined? ::Syck
|
|
|
|
# for tests that change YAML::ENGINE
|
2012-04-19 19:07:48 -04:00
|
|
|
# 1.8 does not support the second argument to const_defined?
|
|
|
|
remove_const :Syck rescue nil
|
|
|
|
|
2012-04-17 20:04:12 -04:00
|
|
|
Syck = ::Syck
|
|
|
|
|
|
|
|
# JRuby's "Syck" is called "Yecht"
|
|
|
|
elsif defined? YAML::Yecht
|
|
|
|
Syck = YAML::Yecht
|
|
|
|
|
|
|
|
# Otherwise, if there is no YAML::Syck, then we've got just psych
|
|
|
|
# loaded, so lets define a stub for DefaultKey.
|
|
|
|
elsif !defined? YAML::Syck
|
|
|
|
module Syck
|
2013-10-19 21:33:19 -04:00
|
|
|
class DefaultKey # :nodoc:
|
2012-04-17 20:04:12 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Now that we've got something that is always here, define #to_s
|
|
|
|
# so when code tries to use this, it at least just shows up like it
|
|
|
|
# should.
|
|
|
|
module Syck
|
|
|
|
class DefaultKey
|
2012-04-19 19:07:48 -04:00
|
|
|
remove_method :to_s rescue nil
|
|
|
|
|
2012-04-17 20:04:12 -04:00
|
|
|
def to_s
|
|
|
|
'='
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2012-11-29 01:52:18 -05:00
|
|
|
|
|
|
|
SyntaxError = Error unless defined? SyntaxError
|
2012-04-17 20:04:12 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
# Sometime in the 1.9 dev cycle, the Syck constant was moved from under YAML
|
|
|
|
# to be a toplevel constant. So gemspecs created under these versions of Syck
|
|
|
|
# will have references to Syck::DefaultKey.
|
|
|
|
#
|
|
|
|
# So we need to be sure that we reference Syck at the toplevel too so that
|
|
|
|
# we can always load these kind of gemspecs.
|
|
|
|
#
|
|
|
|
if !defined?(Syck)
|
|
|
|
Syck = YAML::Syck
|
|
|
|
end
|
|
|
|
|
|
|
|
# Now that we've got Syck setup in all the right places, store
|
|
|
|
# a reference to the DefaultKey class inside Gem. We do this so that
|
|
|
|
# if later on YAML, etc are redefined, we've still got a consistent
|
|
|
|
# place to find the DefaultKey class for comparison.
|
|
|
|
|
|
|
|
module Gem
|
|
|
|
# for tests that change YAML::ENGINE
|
|
|
|
remove_const :SyckDefaultKey if const_defined? :SyckDefaultKey
|
|
|
|
|
|
|
|
SyckDefaultKey = YAML::Syck::DefaultKey
|
|
|
|
end
|
|
|
|
|
|
|
|
# :startdoc:
|