XmlDataBuilder renders Ruby data structures as XML using Builder.
Switch branches/tags
Nothing to show
Pull request Compare This branch is even with traveliq:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
lib
spec
test
.document
.gitignore
Gemfile
Gemfile.lock
LICENSE.txt
README.rdoc
Rakefile
VERSION
xml_data_builder.gemspec

README.rdoc

xml_data_builder

XmlDataBuilder renders Ruby data structures as XML using Builder. It is designed to use the lowest common denominator between JSON and XML. When using arrays as input XmlDataBuilder uses the key of the outer hash as a grouping tag and wraps the values in singularized tags. Symbols and Strings are equivalent.

Usage is simple: You initialize XmlDataBuilder with ruby data structure and call #document:

>> puts XmlDataBuilder.new({}).document
<?xml version="1.0" encoding="UTF-8"?>

>> puts XmlDataBuilder.new({:data => 1}).document
<?xml version="1.0" encoding="UTF-8"?>
<data>1</data>

>> puts XmlDataBuilder.new({:outer => {:inner => 'data'}}).document
<?xml version="1.0" encoding="UTF-8"?>
<outer>
  <inner>data</inner>
</outer>

>> puts XmlDataBuilder.new({:outer => {:inner => 'data'}}, :indent => 0).document
<?xml version="1.0" encoding="UTF-8"?><outer><inner>data</inner></outer>

>> puts XmlDataBuilder.new({:numbers => [1, 2, 3]}).document
<?xml version="1.0" encoding="UTF-8"?>
<numbers>
  <number>1</number>
  <number>2</number>
  <number>3</number>
</numbers>

>> puts XmlDataBuilder.new({:numbers => [{:value => 1, :type => 'odd'}, {:value => 2, :type => 'even'}]}).document
<?xml version="1.0" encoding="UTF-8"?>
<numbers>
  <number>
    <type>odd</type>
    <value>1</value>
  </number>
  <number>
    <type>even</type>
    <value>2</value>
  </number>
</numbers>

>> puts XmlDataBuilder.new({:verbatim => XmlDataBuilder::CDATA.new('eßcape thïs!')}).document
<?xml version="1.0" encoding="UTF-8"?>
<verbatim>
  <![CDATA[eßcape thïs!]]>
</verbatim>

Caveat

The root element has to be a Hash and at least every second level has to be a Hash. XML attributes are not supported.

Installation

(sudo) gem install xml_data_builder

Authors

Dr. Florian Odronitz (odo@mac.com)

Contact

For questions, contact the authors or developer@traveliq.net

Copyright

Copyright © 2011 www.travel-iq.com. See LICENSE.txt for further details.