Module: Nokogiri::XSLT
- Defined in:
- lib/nokogiri/xslt.rb,
lib/nokogiri/xslt/stylesheet.rb,
ext/nokogiri/nokogiri.c
Overview
See Nokogiri::XSLT::Stylesheet for creating and manipulating Stylesheet object.
Defined Under Namespace
Classes: Stylesheet
Class Method Summary collapse
-
.parse(string, modules = {}) ⇒ Object
:call-seq: parse(xsl) → Nokogiri::XSLT::Stylesheet parse(xsl, modules) → Nokogiri::XSLT::Stylesheet.
-
.quote_params(params) ⇒ Object
:call-seq: quote_params(params) → Array.
-
.register(uri, obj) ⇒ Object
docstring is in lib/nokogiri/xslt.rb.
Instance Method Summary collapse
-
#register(uri, custom_handler_class) ⇒ Object
call-seq: register(uri, custom_handler_class).
Class Method Details
.parse(string, modules = {}) ⇒ Object
:call-seq:
parse(xsl) → Nokogiri::XSLT::Stylesheet
parse(xsl, modules) → Nokogiri::XSLT::Stylesheet
Parse the stylesheet in xsl
, registering optional modules
as custom class handlers.
- Parameters
-
xsl
(String) XSL content to be parsed into a stylesheet -
modules
(Hash<String ⇒ Class>) A hash of URI-to-handler relations for linking a namespace to a custom function handler.
⚠ The XSLT handler classes are registered globally.
Also see Nokogiri::XSLT.register
Example
xml = Nokogiri.XML(<<~XML)
<nodes>
<node>Foo</node>
<node>Bar</node>
</nodes>
XML
handler = Class.new do
def reverse(node)
node.text.reverse
end
end
xsl = <<~XSL
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:myfuncs="http://nokogiri.org/xslt/myfuncs"
extension-element-prefixes="myfuncs">
<xsl:template match="/">
<reversed>
<xsl:for-each select="nodes/node">
<reverse><xsl:copy-of select="myfuncs:reverse(.)"/></reverse>
</xsl:for-each>
</reversed>
</xsl:template>
</xsl:stylesheet>
XSL
xsl = Nokogiri.XSLT(xsl, "http://nokogiri.org/xslt/myfuncs" => handler)
xsl.transform(xml).to_xml
# => "<?xml version=\"1.0\"?>\n" +
# "<reversed>\n" +
# " <reverse>ooF</reverse>\n" +
# " <reverse>raB</reverse>\n" +
# "</reversed>\n"
76 77 78 79 80 81 82 83 84 85 86 87 |
# File 'lib/nokogiri/xslt.rb', line 76 def parse(string, modules = {}) modules.each do |url, klass| XSLT.register(url, klass) end doc = XML::Document.parse(string, nil, nil, XML::ParseOptions::DEFAULT_XSLT) if Nokogiri.jruby? Stylesheet.parse_stylesheet_doc(doc, string) else Stylesheet.parse_stylesheet_doc(doc) end end |
.quote_params(params) ⇒ Object
:call-seq:
quote_params(params) → Array
Quote parameters in params
for stylesheet safety. See Nokogiri::XSLT::Stylesheet.transform for example usage.
- Parameters
-
params
(Hash, Array) XSLT parameters (key->value, or tuples of [key, value])
- Returns
-
Array of string parameters, with quotes correctly escaped for use with XSLT::Stylesheet.transform
100 101 102 103 104 105 106 107 108 109 110 111 |
# File 'lib/nokogiri/xslt.rb', line 100 def quote_params(params) params.flatten.each_slice(2).with_object([]) do |kv, quoted_params| key, value = kv.map(&:to_s) value = if value.include?("'") "concat('#{value.gsub(/'/, %q{', "'", '})}')" else "'#{value}'" end quoted_params << key quoted_params << value end end |
.register(uri, obj) ⇒ Object
docstring is in lib/nokogiri/xslt.rb
386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 |
# File 'ext/nokogiri/xslt_stylesheet.c', line 386
static VALUE
rb_xslt_s_register(VALUE self, VALUE uri, VALUE obj)
{
VALUE modules = rb_iv_get(self, "@modules");
if (NIL_P(modules)) {
rb_raise(rb_eRuntimeError, "internal error: @modules not set");
}
rb_hash_aset(modules, uri, obj);
xsltRegisterExtModule(
(unsigned char *)StringValueCStr(uri),
initFunc,
shutdownFunc
);
return self;
}
|
Instance Method Details
#register(uri, custom_handler_class) ⇒ Object
call-seq:
register(uri, custom_handler_class)
Register a class that implements custom XSLT transformation functions.
⚠ The XSLT handler classes are registered *globally*.
[Parameters}
- +uri+ (String) The namespace for the custom handlers
- +custom_handler_class+ (Class) A class with ruby methods that can be called during
transformation
See Nokogiri::XSLT.parse for usage.
127 128 129 130 |
# File 'lib/nokogiri/xslt.rb', line 127 def register(uri, custom_handler_class) # NOTE: this is implemented in the C extension, see ext/nokogiri/xslt_stylesheet.c raise NotImplementedError, "Nokogiri::XSLT.register is not implemented on JRuby" end |