Sha256: 66c106b53a26c110c34d19c55a0895177d7e091f704d25c601932f8115280dac

Contents?: true

Size: 1.5 KB

Versions: 39

Compression:

Stored size: 1.5 KB

Contents

module Nanoc::Filters
  # @since 3.3.0
  #
  # @api private
  class XSL < Nanoc::Filter
    requires 'nokogiri'

    # Runs the item content through an [XSLT](http://www.w3.org/TR/xslt)
    # stylesheet using  [Nokogiri](http://nokogiri.org/).
    #
    # This filter can only be run for layouts, because it will need both the
    # XML to convert (= the item content) as well as the XSLT stylesheet (=
    # the layout content).
    #
    # Additional parameters can be passed to the layout call. These parameters
    # will be turned into `xsl:param` elements.
    #
    # @example Invoking the filter as a layout
    #
    #     compile '/reports/*/' do
    #       layout 'xsl-report'
    #     end
    #
    #     layout 'xsl-report', :xsl, :awesome => 'definitely'
    #
    # @param [String] _content Ignored. As the filter can be run only as a
    #   layout, the value of the `:content` parameter passed to the class at
    #   initialization is used as the content to transform.
    #
    # @param [Hash] params The parameters that will be stored in corresponding
    #   `xsl:param` elements.
    #
    # @return [String] The transformed content
    def run(_content, params = {})
      Nanoc::Extra::JRubyNokogiriWarner.check_and_warn

      if assigns[:layout].nil?
        raise 'The XSL filter can only be run as a layout'
      end

      xml = ::Nokogiri::XML(assigns[:content])
      xsl = ::Nokogiri::XSLT(assigns[:layout].raw_content)

      xsl.apply_to(xml, ::Nokogiri::XSLT.quote_params(params))
    end
  end
end

Version data entries

39 entries across 39 versions & 1 rubygems

Version Path
nanoc-4.4.4 lib/nanoc/filters/xsl.rb
nanoc-4.4.3 lib/nanoc/filters/xsl.rb
nanoc-4.4.2 lib/nanoc/filters/xsl.rb
nanoc-4.4.1 lib/nanoc/filters/xsl.rb
nanoc-4.4.0 lib/nanoc/filters/xsl.rb
nanoc-4.3.8 lib/nanoc/filters/xsl.rb
nanoc-4.3.7 lib/nanoc/filters/xsl.rb
nanoc-4.3.6 lib/nanoc/filters/xsl.rb
nanoc-4.3.5 lib/nanoc/filters/xsl.rb
nanoc-4.3.4 lib/nanoc/filters/xsl.rb
nanoc-4.3.3 lib/nanoc/filters/xsl.rb
nanoc-4.3.2 lib/nanoc/filters/xsl.rb
nanoc-4.3.1 lib/nanoc/filters/xsl.rb
nanoc-4.3.0 lib/nanoc/filters/xsl.rb
nanoc-4.2.4 lib/nanoc/filters/xsl.rb
nanoc-4.2.3 lib/nanoc/filters/xsl.rb
nanoc-4.2.2 lib/nanoc/filters/xsl.rb
nanoc-4.2.1 lib/nanoc/filters/xsl.rb
nanoc-4.2.0 lib/nanoc/filters/xsl.rb
nanoc-4.1.6 lib/nanoc/filters/xsl.rb