Skip to content
This repository has been archived by the owner on Dec 11, 2022. It is now read-only.
/ excesselt Public archive
forked from DanielHeath/rslt

A ruby library that you could use instead of XSLT. Very clean syntax.

Notifications You must be signed in to change notification settings

jwark/excesselt

 
 

Repository files navigation

Excesselt

http://github.com/DanielHeath/excesselt

DESCRIPTION:

Excesselt is a ruby library that I built because I hate XSLT.

I've extracted it from an app I built for my work at Lonely Planet.

Excesselt solves the same problem as XSLT does (that is, how can I transform this xml document into some other format).

FEATURES/PROBLEMS:

Nice syntax. Testable, reusable xml transformation Tested on REE 1.8.7 - TODO test on more platforms and update this section

SYNOPSIS:

class MyStylesheet < Excesselt::Stylesheet
  def rules
    render('parent > child')     { builder.p(:style => "child_content" ) { child_content }  }
    render('parent')             { builder.p(:style => "parent_content") { child_content }  }
    render('text()')             { add element.to_xml.upcase                                }
  end
end

MyStylesheet.transform <<-XML
<parent>
  <child>Use Excesselt</child>
</parent>
XML
-> <p style="parent_content"><p style="child_content">USE EXCESSELT</p></p>

REQUIREMENTS:

  • Nokogiri, Builder

INSTALL:

  • gem install excesselt

LICENSE:

(The MIT License)

Copyright (c) 2010 Daniel Heath

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

About

A ruby library that you could use instead of XSLT. Very clean syntax.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 100.0%