Class DefaultPassageFormatter


  • public class DefaultPassageFormatter
    extends PassageFormatter
    Creates a formatted snippet from the top passages.

    The default implementation marks the query terms as bold, and places ellipses between unconnected passages.

    • Field Detail

      • preTag

        protected final String preTag
        text that will appear before highlighted terms
      • postTag

        protected final String postTag
        text that will appear after highlighted terms
      • ellipsis

        protected final String ellipsis
        text that will appear between two unconnected passages
      • escape

        protected final boolean escape
        true if we should escape for html
    • Constructor Detail

      • DefaultPassageFormatter

        public DefaultPassageFormatter()
        Creates a new DefaultPassageFormatter with the default tags.
      • DefaultPassageFormatter

        public DefaultPassageFormatter​(String preTag,
                                       String postTag,
                                       String ellipsis,
                                       boolean escape)
        Creates a new DefaultPassageFormatter with custom tags.
        Parameters:
        preTag - text which should appear before a highlighted term.
        postTag - text which should appear after a highlighted term.
        ellipsis - text which should be used to connect two unconnected passages.
        escape - true if text should be html-escaped
    • Method Detail

      • format

        public String format​(Passage[] passages,
                             String content)
        Description copied from class: PassageFormatter
        Formats the top passages from content into a human-readable text snippet.
        Specified by:
        format in class PassageFormatter
        Parameters:
        passages - top-N passages for the field. Note these are sorted in the order that they appear in the document for convenience.
        content - content for the field.
        Returns:
        formatted highlight. Note that for the non-expert APIs in UnifiedHighlighter that return String, the toString method on the Object returned by this method is used to compute the string.
      • append

        protected void append​(StringBuilder dest,
                              String content,
                              int start,
                              int end)
        Appends original text to the response.
        Parameters:
        dest - resulting text, possibly transformed or encoded
        content - original text content
        start - index of the first character in content
        end - index of the character following the last character in content