All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.browseengine.bobo.search.section.PhraseNode Maven / Gradle / Ivy

There is a newer version: 3.1.2
Show newest version
/**
 * This software is licensed to you under the Apache License, Version 2.0 (the
 * "Apache License").
 *
 * LinkedIn's contributions are made under the Apache License. If you contribute
 * to the Software, the contributions will be deemed to have been made under the
 * Apache License, unless you expressly indicate otherwise. Please do not make any
 * contributions that would be inconsistent with the Apache License.
 *
 * You may obtain a copy of the Apache License at http://www.apache.org/licenses/LICENSE-2.0
 * Unless required by applicable law or agreed to in writing, this software
 * distributed under the Apache License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Apache
 * License for the specific language governing permissions and limitations for the
 * software governed under the Apache License.
 *
 * © 2012 LinkedIn Corp. All Rights Reserved.  
 */

package com.browseengine.bobo.search.section;

import java.io.IOException;

import org.apache.lucene.index.IndexReader;

/**
 * Phrase operator node for SectionSearchQUeryPlan
 *
 */
public class PhraseNode extends AndNode
{
  private TermNode[] _termNodes;
  private int _curPos;
  
  public PhraseNode(TermNode[] termNodes, IndexReader reader) throws IOException
  {
    super(termNodes);
    _termNodes = termNodes;
  }
  
  @Override
  public int fetchDoc(int targetDoc) throws IOException
  {
    _curPos = -1;
    return super.fetchDoc(targetDoc);
  }
  
  @Override
  public int fetchSec(int targetSec) throws IOException
  {
    TermNode firstNode = _termNodes[0];
    
    while(fetchPos() < SectionSearchQueryPlan.NO_MORE_POSITIONS)
    {
      int secId = firstNode.readSecId();
      if(secId >= targetSec)
      {
        targetSec = secId;
        boolean matched = true;
        for(int i = 1; i < _termNodes.length; i++)
        {
          matched = (targetSec == _termNodes[i].readSecId());
          if(!matched) break;
        }
        if(matched)
        {
          _curSec = targetSec;
          return _curSec;
        }
      }
    }
    _curSec = SectionSearchQueryPlan.NO_MORE_SECTIONS;
    return _curSec;
  }
  
  @Override
  protected int fetchPos() throws IOException
  {
    int targetPhrasePos = _curPos + 1;
    
    int i = 0;
    while(i < _termNodes.length)
    {
      TermNode node = _termNodes[i];
      int targetTermPos = (targetPhrasePos + node._positionInPhrase);
      while(node._curPos < targetTermPos)
      {
        if(node.fetchPos() == SectionSearchQueryPlan.NO_MORE_POSITIONS)
        {
          _curPos = SectionSearchQueryPlan.NO_MORE_POSITIONS;
          return _curPos;
        }
      }
      if(node._curPos == targetTermPos)
      {
        i++;
      }
      else
      {
        targetPhrasePos = node._curPos - i;
        i = 0;
      }
    }
    _curPos = targetPhrasePos;
    return _curPos;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy