This is a Ruby implementation of the KDL Document Language
Add this line to your application's Gemfile:
gem 'kdl'And then execute:
$ bundle install
Or install it yourself as:
$ gem install kdl
require 'kdl'
KDL.parse(a_string) #=> KDL::Document
KDL.load_file('path/to/file') #=> KDL::DocumentYou can optionally provide your own type annotation handlers:
class Foo < KDL::Value::Custom
end
KDL.parse(a_string, type_parsers: {
  'foo' => Foo
})The foo custom type will be called with instances of Value or Node with the type annotation (foo).
Custom types are expected to have a call method that takes the Value or Node, and the type annotation itself, as arguments, and is expected to return either an instance of KDL::Value::Custom or KDL::Node::Custom (depending on the input type) or nil to return the original value as is. Take a look at the built in custom types as a reference.
You can also disable type annotation parsing entirely (including the built in ones):
KDL.parse(a_string, parse_types: false)kdl-rb maintains backwards compatibility with the KDL v1 spec. By default, KDL will attempt to parse a file with the v1 parser if it fails to parse with v2. This behaviour can be changed by specifying the version option:
KDL.parse(a_string, version: 2)The resulting document will also serialize back to the same version it was parsed as. For example, if you parse a v2 document and call to_s on it, it will output a v2 document, and similarly with v1. This behaviour can be changed by specifying the output_version option:
KDL.parse(a_string, output_version: 2)This allows you to to convert documents between versions:
KDL.parse('foo "bar" true', version: 1, output_version: 2).to_s #=> 'foo bar #true'You can also convert an already parsed document between versions with to_v1 and to_v2:
doc = KDL.parse('foo "bar" true', version: 1)
doc.version #=> 1
doc.to_v2.to_s #=> 'foo bar #true'You can also set the default version globally:
KDL.default_version = 2
KDL.default_output_version = 2You can still force automatic version detection with auto_parse:
KDL.default_version = 2
KDL.parse('foo "bar" true') #=> Error
KDL.auto_parse('foo "bar" true') #=> KDL::V1::DocumentVersion directives are also respected:
KDL.parse("/- kdl-version 2\nfoo bar", version: 1)
#=> Version mismatch, document specified v2, but this is a v1 parser (Racc::ParseError)After checking out the repo, run bin/setup to install dependencies. Then, run rake test to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.
Bug reports and pull requests are welcome on GitHub at https://github.com/danini-the-panini/kdl-rb.
The gem is available as open source under the terms of the MIT License.