= Ruby/XSLT

== About

Ruby/XSLT is a simple XSLT class based on libxml <http://xmlsoft.org/> and libxslt <http://xmlsoft.org/XSLT/>

== Licence

Copyright (C) 2003, 2004, 2005 Gregoire Lejeune <gregoire dot lejeune at free dot fr>

Ruby/XSLT is freely distributable according to the terms of the
GNU General Public License (see the file 'COPYING').

This program is distributed without any warranty. See the file
'COPYING' for details.

== DOWNLOAD

=== Last version
* version 0.9.2[http://gregoire.lejeune.free.fr/ruby-xslt_0.9.2.tar.gz]

=== Old versions
* version 0.9.1[http://gregoire.lejeune.free.fr/ruby-xslt_0.9.1.tar.gz] 
* version 0.8.2[http://gregoire.lejeune.free.fr/ruby-xslt_0.8.2.tar.gz]
* version 0.8.1[http://gregoire.lejeune.free.fr/ruby-xslt_0.8.1.tar.gz]
* version 0.8.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.8.0.tar.gz]
* version 0.7.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.7.0.tar.gz]
* version 0.6.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.6.0.tar.gz]
* version 0.5.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.5.0.tar.gz]
* version 0.4.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.4.0.tar.gz]
* version 0.3.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.3.0.tar.gz]
* version 0.2.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.2.0.tar.gz]
* version 0.1.0[http://gregoire.lejeune.free.fr/ruby-xslt_0.1.0.tar.gz]

=== CVS access
The CVS repository is available at rubyforge.org[http://rubyforge.org/projects/ruby-asp]. You can browse[http://rubyforge.org/cgi-bin/viewcvs.cgi/ruby-xslt/?cvsroot=ruby-asp] it or access it via anonymous access :

  cvs -d :pserver:anonymous@rubyforge.org:/var/cvs/ruby-asp login
  cvs -d :pserver:anonymous@rubyforge.org:/var/cvs/ruby-asp checkout ruby-xslt

See this page[http://rubyforge.org/scm/?group_id=423] for more informations

== INSTALLATION

	ruby extconf.rb # see CONFIGURATION for more options
	make
	make test
	make doc
	sudo make install

=== CONFIGURATION

  --help                   display this help and exit
  
  --with-xslt-lib=PATH
  --with-xslt-include=PATH
  --with-xslt-dir=PATH     specify the directory name for the libxslt include 
                           files and/or library 
  
  --enable-error-handler   enables a VERY crude error handler. Error messages 
                           are appended to the class variable XML::XSLT and can
                           be accessed with the class method XML::XSLT.errors 
                           (will change in a future version)
  --disable-exslt          disables libexslt support <http://exslt.org/>
  
  --enable-debug           compile with memwatch 
                           <http://www.linkdata.se/sourcecode.html>

== EXAMPLES

=== Simple example
	require 'xml/xslt'

	xslt = XML::XSLT.new()
	xslt.xml = "text.xml"
	xslt.xsl = "test.xsl"

	out = xslt.serve()
	print out;

=== REXML support
	require 'rexml/document'
	require 'xml/xslt'

	xslt = XML::XSLT.new()

	xslt.xml = REXML::Document.new File.open( "test.xml" )
	xslt.xsl = REXML::Document.new File.open( "test.xsl" )

	out = xslt.serve()
	print out;

=== XML::Smart support
	require 'xml/smart'
	require 'xml/xslt'

	xslt = XML::XSLT.new()

	xslt.xml = XML::Smart.open( "test.xml" )
	xslt.xsl = XML::Smart.open( "test.xsl" )

	out = xslt.serve()
	print out;
	
=== Parameters support
	require "xml/xslt"

	xslt = XML::XSLT.new()
	xslt.xsl = "parameter.xsl"
	xslt.xml = "test.xml"
	xslt.parameters = { "p1" => "the first parameter ...",
	                    "p2" => "'and the second one!'" }
	xslt.save("test1.html")
	
	xslt.parameters = { "p1" => "Ruby...",
	                    "p2" => "'...is cool !'" }
	xslt.save("test2.html")

=== External functions support
	require "xml/xslt"

	class XML::XSLT
	  def round_trip( arg )
	    arg
	  end
	  def type( arg )
	    arg.class.to_s
	  end
	end

	xslt = XML::XSLT.new()
	xslt.xsl = "functions.xsl"
	xslt.xml = "test.xml"
	XML::XSLT.extFunction("round-trip", "http://test.none", xslt)
	XML::XSLT.extFunction("type", "http://test.none", xslt)

	print xslt.serve
