Uploaded image for project: 'Solr'
  1. Solr
  2. SOLR-24

Add Highlighting to standard request handler

    XMLWordPrintableJSON

Details

    • New Feature
    • Status: Closed
    • Major
    • Resolution: Fixed
    • None
    • 1.1.0
    • search
    • None

    Description

      This patch adds highlighting functionality to solr request handlers it also refactors StandardRequestHandler to use the common functionality provided in SolrPluginUtils. I'd have preferred to do two separate patches, but creating two mutually-dependent patches on a repo without being able to commit a revision was daunting.

      -----------------------------------
      Refactoring StandardRequestHandler:

      1. Moved solr.util.CommonParams to its own class. Removed DisMax-specific parameters, and placed in a subclass.
      2. StandardRequestHandler uses CommonParams to store config-time parameter values (new feature)
      3. StandardRequestHandler uses SolrPluginUtils methods for duplicate functionality
      4. Some of said SPU methods have grown a "params" parameter to enable them to use default values. (Note: instead of passing this around, something like a RequestHelper class which carries the SolrRequest and Param values would be useful. This class could house the utility methods that require Request parameters).
      5. SolrPluginUtils.getParam() only uses the default parameter if it is null, not blank.

      --------------------------------------
      Highlighting:

      1. Highlighting is controlled by three request parameters:
      highlight: list of fields to highlight, or highlight the default field if at all present
      maxSnippets: maximum number of snippets to return for each field
      highlightFormatterClass: 'solr.<classname>' or full package path of highlight.Formatter subclass to use in highlighting.
      2. Default formatter is to use <em> tags. There are issues with this approach, but are mitigated with the ability to specify a custom Formatter. Definately should consider alternatives (a custom xml approach to denote highlit regions will require some Highlighter package hackery).
      3. Document summaries are returned as a separate element under <response> format is still up for discussion.

      Attachments

        1. highlight_v5.patch
          53 kB
          Mike Klaas
        2. highlight_patch_v4.diff
          48 kB
          Mike Klaas
        3. highlight_patch_v3.diff
          51 kB
          Mike Klaas
        4. highlight_patch_v2.diff
          51 kB
          Mike Klaas
        5. highlight_patch_v1.diff
          40 kB
          Mike Klaas

        Activity

          People

            yseeley@gmail.com Yonik Seeley
            klaasm Mike Klaas
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: