Class LRUQueryCache.CachingWrapperWeight

    • Field Detail

      • used

        private final java.util.concurrent.atomic.AtomicBoolean used
    • Method Detail

      • matches

        public Matches matches​(LeafReaderContext context,
                               int doc)
                        throws java.io.IOException
        Description copied from class: Weight
        Returns Matches for a specific document, or null if the document does not match the parent query

        A query match that contains no position information (for example, a Point or DocValues query) will return MatchesUtils.MATCH_WITH_NO_TERMS

        Overrides:
        matches in class Weight
        Parameters:
        context - the reader's context to create the Matches for
        doc - the document's id relative to the given context's reader
        Throws:
        java.io.IOException
      • cacheEntryHasReasonableWorstCaseSize

        private boolean cacheEntryHasReasonableWorstCaseSize​(int maxDoc)
      • shouldCache

        private boolean shouldCache​(LeafReaderContext context)
                             throws java.io.IOException
        Check whether this segment is eligible for caching, regardless of the query.
        Throws:
        java.io.IOException
      • scorer

        public Scorer scorer​(LeafReaderContext context)
                      throws java.io.IOException
        Description copied from class: Weight
        Returns a Scorer which can iterate in order over all matching documents and assign them a score.

        NOTE: null can be returned if no documents will be scored by this query.

        NOTE: The returned Scorer does not have LeafReader.getLiveDocs() applied, they need to be checked on top.

        Specified by:
        scorer in class Weight
        Parameters:
        context - the LeafReaderContext for which to return the Scorer.
        Returns:
        a Scorer which scores documents in/out-of order.
        Throws:
        java.io.IOException - if there is a low-level I/O error
      • count

        public int count​(LeafReaderContext context)
                  throws java.io.IOException
        Description copied from class: Weight
        Counts the number of live documents that match a given Weight.parentQuery in a leaf.

        The default implementation returns -1 for every query. This indicates that the count could not be computed in sub-linear time.

        Specific query classes should override it to provide other accurate sub-linear implementations (that actually return the count). Look at MatchAllDocsQuery.createWeight(IndexSearcher, ScoreMode, float) for an example

        We use this property of the function to count hits in IndexSearcher.count(Query).

        Overrides:
        count in class Weight
        Parameters:
        context - the LeafReaderContext for which to return the count.
        Returns:
        integer count of the number of matches
        Throws:
        java.io.IOException - if there is a low-level I/O error
      • isCacheable

        public boolean isCacheable​(LeafReaderContext ctx)
        Returns:
        true if the object can be cached against a given leaf
      • bulkScorer

        public BulkScorer bulkScorer​(LeafReaderContext context)
                              throws java.io.IOException
        Description copied from class: Weight
        Optional method, to return a BulkScorer to score the query and send hits to a Collector. Only queries that have a different top-level approach need to override this; the default implementation pulls a normal Scorer and iterates and collects the resulting hits which are not marked as deleted.
        Overrides:
        bulkScorer in class Weight
        Parameters:
        context - the LeafReaderContext for which to return the Scorer.
        Returns:
        a BulkScorer which scores documents and passes them to a collector.
        Throws:
        java.io.IOException - if there is a low-level I/O error