當前位置: 首頁>>代碼示例>>Java>>正文


Java Token.getFlags方法代碼示例

本文整理匯總了Java中org.apache.lucene.analysis.Token.getFlags方法的典型用法代碼示例。如果您正苦於以下問題:Java Token.getFlags方法的具體用法?Java Token.getFlags怎麽用?Java Token.getFlags使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.lucene.analysis.Token的用法示例。


在下文中一共展示了Token.getFlags方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: convert

import org.apache.lucene.analysis.Token; //導入方法依賴的package包/類
/**
 * Converts the original query string to a collection of Lucene Tokens.
 * @param original the original query string
 * @return a Collection of Lucene Tokens
 */
@Override
public Collection<Token> convert(String original) {
  if (original == null) { // this can happen with q.alt = and no query
    return Collections.emptyList();
  }
  Collection<Token> result = new ArrayList<>();
  Matcher matcher = QUERY_REGEX.matcher(original);
  String nextWord = null;
  int nextStartIndex = 0;
  String lastBooleanOp = null;
  while (nextWord!=null || matcher.find()) {
    String word = null;
    int startIndex = 0;
    if(nextWord != null) {
      word = nextWord;
      startIndex = nextStartIndex;
      nextWord = null;
    } else {
      word = matcher.group(0);
      startIndex = matcher.start();
    }
    if(matcher.find()) {
      nextWord = matcher.group(0);
      nextStartIndex = matcher.start();
    }      
    if("AND".equals(word) || "OR".equals(word) || "NOT".equals(word)) {
      lastBooleanOp = word;        
      continue;
    }
    // treat "AND NOT" as "NOT"...
    if ("AND".equals(nextWord)
        && original.length() > nextStartIndex + 7
        && original.substring(nextStartIndex, nextStartIndex + 7).equals(
            "AND NOT")) {
      nextWord = "NOT";
    }
    
    int flagValue = 0;
    if (word.charAt(0) == '-'
        || (startIndex > 0 && original.charAt(startIndex - 1) == '-')) {
      flagValue = PROHIBITED_TERM_FLAG;
    } else if (word.charAt(0) == '+'
        || (startIndex > 0 && original.charAt(startIndex - 1) == '+')) {
      flagValue = REQUIRED_TERM_FLAG;
    //we don't know the default operator so just assume the first operator isn't new.
    } else if (nextWord != null
        && lastBooleanOp != null 
        && !nextWord.equals(lastBooleanOp)
        && ("AND".equals(nextWord) || "OR".equals(nextWord) || "NOT".equals(nextWord))) {
      flagValue = TERM_PRECEDES_NEW_BOOLEAN_OPERATOR_FLAG;
    //...unless the 1st boolean operator is a NOT, because only AND/OR can be default.
    } else if (nextWord != null
        && lastBooleanOp == null
        && !nextWord.equals(lastBooleanOp)
        && ("NOT".equals(nextWord))) {
      flagValue = TERM_PRECEDES_NEW_BOOLEAN_OPERATOR_FLAG;
    }
    try {
      analyze(result, word, startIndex, flagValue);
    } catch (IOException e) {
      // TODO: shouldn't we log something?
    }   
  }
  if(lastBooleanOp != null) {
    for(Token t : result) {
      int f = t.getFlags();
      t.setFlags(f |= QueryConverter.TERM_IN_BOOLEAN_QUERY_FLAG);
    }
  }
  return result;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:77,代碼來源:SpellingQueryConverter.java

示例2: getCollation

import org.apache.lucene.analysis.Token; //導入方法依賴的package包/類
private String getCollation(String origQuery,
                            List<SpellCheckCorrection> corrections) {
  StringBuilder collation = new StringBuilder(origQuery);
  int offset = 0;
  String corr = "";
  for(int i=0 ; i<corrections.size() ; i++) {
    SpellCheckCorrection correction = corrections.get(i);   
    Token tok = correction.getOriginal();
    // we are replacing the query in order, but injected terms might cause
    // illegal offsets due to previous replacements.
    if (tok.getPositionIncrement() == 0)
      continue;
    corr = correction.getCorrection();
    boolean addParenthesis = false;
    Character requiredOrProhibited = null;
    int indexOfSpace = corr.indexOf(' ');
    StringBuilder corrSb = new StringBuilder(corr);
    int bump = 1;
    
    //If the correction contains whitespace (because it involved breaking a word in 2+ words),
    //then be sure all of the new words have the same optional/required/prohibited status in the query.
    while(indexOfSpace>-1 && indexOfSpace<corr.length()-1) {
      addParenthesis = true;
      char previousChar = tok.startOffset()>0 ? origQuery.charAt(tok.startOffset()-1) : ' ';
      if(previousChar=='-' || previousChar=='+') {
        corrSb.insert(indexOfSpace + bump, previousChar);
        if(requiredOrProhibited==null) {
          requiredOrProhibited = previousChar;
        }
        bump++;
      } else if ((tok.getFlags() & QueryConverter.TERM_IN_BOOLEAN_QUERY_FLAG) == QueryConverter.TERM_IN_BOOLEAN_QUERY_FLAG) {
        corrSb.insert(indexOfSpace + bump, "AND ");
        bump += 4;
      }
      indexOfSpace = correction.getCorrection().indexOf(' ', indexOfSpace + bump);
    }
    
    int oneForReqOrProhib = 0;
    if(addParenthesis) { 
      if(requiredOrProhibited!=null) {
        corrSb.insert(0, requiredOrProhibited);
        oneForReqOrProhib++;
      }
      corrSb.insert(0, '(');
      corrSb.append(')');
    }
    corr = corrSb.toString();  
    int startIndex = tok.startOffset() + offset - oneForReqOrProhib;
    int endIndex = tok.endOffset() + offset;
    collation.replace(startIndex, endIndex, corr);
    offset += corr.length() - oneForReqOrProhib - (tok.endOffset() - tok.startOffset());      
  }
  return collation.toString();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:55,代碼來源:SpellCheckCollator.java

示例3: hasRequiredFlag

import org.apache.lucene.analysis.Token; //導入方法依賴的package包/類
private boolean hasRequiredFlag(Token t) {
  return (t.getFlags() & QueryConverter.REQUIRED_TERM_FLAG) == QueryConverter.REQUIRED_TERM_FLAG;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:4,代碼來源:SpellingQueryConverterTest.java

示例4: hasProhibitedFlag

import org.apache.lucene.analysis.Token; //導入方法依賴的package包/類
private boolean hasProhibitedFlag(Token t) {
  return (t.getFlags() & QueryConverter.PROHIBITED_TERM_FLAG) == QueryConverter.PROHIBITED_TERM_FLAG;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:4,代碼來源:SpellingQueryConverterTest.java

示例5: hasNBOFlag

import org.apache.lucene.analysis.Token; //導入方法依賴的package包/類
private boolean hasNBOFlag(Token t) {
  return (t.getFlags() & QueryConverter.TERM_PRECEDES_NEW_BOOLEAN_OPERATOR_FLAG) == QueryConverter.TERM_PRECEDES_NEW_BOOLEAN_OPERATOR_FLAG;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:4,代碼來源:SpellingQueryConverterTest.java

示例6: hasInBooleanFlag

import org.apache.lucene.analysis.Token; //導入方法依賴的package包/類
private boolean hasInBooleanFlag(Token t) {
  return (t.getFlags() & QueryConverter.TERM_IN_BOOLEAN_QUERY_FLAG) == QueryConverter.TERM_IN_BOOLEAN_QUERY_FLAG;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:4,代碼來源:SpellingQueryConverterTest.java


注:本文中的org.apache.lucene.analysis.Token.getFlags方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。