Sha256: 7e353c1212c2284dfedccc1c0c257f5104e57702379ae247054815c7d4c275d9

Contents?: true

Size: 1.33 KB

Versions: 3

Compression:

Stored size: 1.33 KB

Contents

module Nanoc::Helpers

  # Nanoc::Helpers::Text contains several useful text-related helper functions.
  module Text

    # Returns an excerpt for the given string. HTML tags are ignored, so if
    # you don't want them to turn up, they should be stripped from the string
    # before passing it to the excerpt function.
    #
    # +params+ is a hash where the following keys can be set:
    #
    # +length+:: The maximum number of characters this excerpt can contain,
    #            including the omission. Defaults to 25.
    #
    # +omission+:: The string to append to the excerpt when the excerpt is
    #              shorter than the original string. Defaults to '...' (but in
    #              HTML, you may want to use something more fancy, like
    #              '…').
    def excerptize(string, params={})
      # Initialize params
      params[:length]   ||= 25
      params[:omission] ||= '...'

      # Get excerpt
      length = params[:length] - params[:omission].length
      length = 0 if length < 0
      (string.length > params[:length] ? string[0...length] + params[:omission] : string)
    end

    # Strips all HTML tags out of the given string.
    def strip_html(string)
      # FIXME will need something more sophisticated than this, because it sucks
      string.gsub(/<[^>]*(>+|\s*\z)/m, '').strip
    end

  end

end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
nanoc-2.2 lib/nanoc/helpers/text.rb
nanoc-2.2.1 lib/nanoc/helpers/text.rb
nanoc-2.2.2 lib/nanoc/helpers/text.rb