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


Java AttributeSource類代碼示例

本文整理匯總了Java中org.apache.lucene.util.AttributeSource的典型用法代碼示例。如果您正苦於以下問題:Java AttributeSource類的具體用法?Java AttributeSource怎麽用?Java AttributeSource使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: incrementToken

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
@Override
public boolean incrementToken() throws IOException {
  if (input.incrementToken()) {
    // capture state lazily - maybe no SinkFilter accepts this state
    AttributeSource.State state = null;
    for (WeakReference<SinkTokenStream> ref : sinks) {
      final SinkTokenStream sink = ref.get();
      if (sink != null) {
        if (sink.accept(this)) {
          if (state == null) {
            state = this.captureState();
          }
          sink.addState(state);
        }
      }
    }
    return true;
  }
  
  return false;
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:22,代碼來源:TeeSinkTokenFilter.java

示例2: accept

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
@Override
public boolean accept(AttributeSource source) {
  if (termAtt == null) {
    termAtt = source.addAttribute(CharTermAttribute.class);
  }
  try {
    Date date = dateFormat.parse(termAtt.toString());//We don't care about the date, just that we can parse it as a date
    if (date != null) {
      return true;
    }
  } catch (ParseException e) {

  }
  
  return false;
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:17,代碼來源:DateRecognizerSinkFilter.java

示例3: incrementToken

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
@Override
public final boolean incrementToken() throws IOException {
  if (cache == null) {
    // fill cache lazily
    cache = new LinkedList<AttributeSource.State>();
    fillCache();
    iterator = cache.iterator();
  }
  
  if (!iterator.hasNext()) {
    // the cache is exhausted, return false
    return false;
  }
  // Since the TokenFilter can be reset, the tokens need to be preserved as immutable.
  restoreState(iterator.next());
  return true;
}
 
開發者ID:gncloud,項目名稱:fastcatsearch3,代碼行數:18,代碼來源:CachingTokenFilter.java

示例4: walkTokens

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
private String[] walkTokens() throws IOException {
    List<String> wordList = new ArrayList<>();
    while (input.incrementToken()) {
        CharTermAttribute textAtt = input.getAttribute(CharTermAttribute.class);
        OffsetAttribute offsetAtt = input.getAttribute(OffsetAttribute.class);
        char[] buffer = textAtt.buffer();
        String word = new String(buffer, 0, offsetAtt.endOffset() - offsetAtt.startOffset());
        wordList.add(word);
        AttributeSource attrs = input.cloneAttributes();
        tokenAttrs.add(attrs);
    }
    String[] words = new String[wordList.size()];
    for (int i = 0; i < words.length; i++) {
        words[i] = wordList.get(i);
    }
    return words;
}
 
開發者ID:jprante,項目名稱:elasticsearch-analysis-opennlp,代碼行數:18,代碼來源:OpenNLPTokenFilter.java

示例5: TokenizerWrapper

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
TokenizerWrapper() {
    super();

    tokenizerTimestamp = dictionaryTimestamp;
    tokenizer = new JapaneseTokenizer(userDictionary,
            discartPunctuation, mode);

    try {
        final Field attributesField = getAccessibleField(AttributeSource.class, "attributes");
        final Object attributesObj = attributesField.get(tokenizer);
        attributesField.set(this, attributesObj);

        final Field attributeImplsField = getAccessibleField(AttributeSource.class, "attributeImpls");
        final Object attributeImplsObj = attributeImplsField.get(tokenizer);
        attributeImplsField.set(this, attributeImplsObj);

        final Field currentStateField = getAccessibleField(AttributeSource.class, "currentState");
        final Object currentStateObj = currentStateField.get(tokenizer);
        currentStateField.set(this, currentStateObj);
    } catch (final Exception e) {
        throw new IllegalStateException(
                "Failed to update the tokenizer.", e);
    }
}
 
開發者ID:codelibs,項目名稱:elasticsearch-analysis-ja,代碼行數:25,代碼來源:ReloadableKuromojiTokenizerFactory.java

示例6: newTokenizerArgs

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
static Object[] newTokenizerArgs(Random random, Reader reader, Class<?>[] paramTypes) {
  Object[] args = new Object[paramTypes.length];
  for (int i = 0; i < args.length; i++) {
    Class<?> paramType = paramTypes[i];
    if (paramType == Reader.class) {
      args[i] = reader;
    } else if (paramType == AttributeSource.class) {
      // TODO: args[i] = new AttributeSource();
      // this is currently too scary to deal with!
      args[i] = null; // force IAE
    } else {
      args[i] = newRandomArg(random, paramType);
    }
  }
  return args;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:17,代碼來源:TestRandomChains.java

示例7: analyzeTokenStream

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
/**
 * Analyzes the given TokenStream, collecting the Tokens it produces.
 *
 * @param tokenStream TokenStream to analyze
 *
 * @return List of tokens produced from the TokenStream
 */
private List<AttributeSource> analyzeTokenStream(TokenStream tokenStream) {
  final List<AttributeSource> tokens = new ArrayList<>();
  final PositionIncrementAttribute posIncrAtt = tokenStream.addAttribute(PositionIncrementAttribute.class);
  final TokenTrackingAttribute trackerAtt = tokenStream.addAttribute(TokenTrackingAttribute.class);
  // for backwards compatibility, add all "common" attributes
  tokenStream.addAttribute(OffsetAttribute.class);
  tokenStream.addAttribute(TypeAttribute.class);
  try {
    tokenStream.reset();
    int position = 0;
    while (tokenStream.incrementToken()) {
      position += posIncrAtt.getPositionIncrement();
      trackerAtt.setActPosition(position);
      tokens.add(tokenStream.cloneAttributes());
    }
    tokenStream.end();
  } catch (IOException ioe) {
    throw new RuntimeException("Error occured while iterating over tokenstream", ioe);
  } finally {
    IOUtils.closeWhileHandlingException(tokenStream);
  }

  return tokens;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:32,代碼來源:AnalysisRequestHandlerBase.java

示例8: TokenizerWrapper

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
TokenizerWrapper() {
    super();

    tokenizerTimestamp = dictionaryTimestamp;
    tokenizer = new JapaneseTokenizer(userDictionary, discartPunctuation, mode);

    try {
        Field attributesField = getAccessibleField(AttributeSource.class, "attributes");
        final Object attributesObj = attributesField.get(tokenizer);
        attributesField.set(this, attributesObj);

        Field attributeImplsField = getAccessibleField(AttributeSource.class, "attributeImpls");
        final Object attributeImplsObj = attributeImplsField.get(tokenizer);
        attributeImplsField.set(this, attributeImplsObj);

        Field currentStateField = getAccessibleField(AttributeSource.class, "currentState");
        final Object currentStateObj = currentStateField.get(tokenizer);
        currentStateField.set(this, currentStateObj);
    } catch (final Exception e) {
        throw new IllegalStateException(
                "Failed to update the tokenizer.", e);
    }
}
 
開發者ID:codelibs,項目名稱:elasticsearch-analysis-kuromoji-neologd,代碼行數:24,代碼來源:ReloadableKuromojiTokenizerFactory.java

示例9: newTokenizerArgs

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
static Object[] newTokenizerArgs(Random random, Reader reader, Class<?>[] paramTypes) {
  Object[] args = new Object[paramTypes.length];
  for (int i = 0; i < args.length; i++) {
    Class<?> paramType = paramTypes[i];
    if (paramType == Reader.class) {
      args[i] = reader;
    } else if (paramType == AttributeFactory.class) {
      // TODO: maybe the collator one...???
      args[i] = AttributeFactory.DEFAULT_ATTRIBUTE_FACTORY;
    } else if (paramType == AttributeSource.class) {
      // TODO: args[i] = new AttributeSource();
      // this is currently too scary to deal with!
      args[i] = null; // force IAE
    } else {
      args[i] = newRandomArg(random, paramType);
    }
  }
  return args;
}
 
開發者ID:pkarmstr,項目名稱:NYBC,代碼行數:20,代碼來源:TestRandomChains.java

示例10: getTermsEnum

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
@Override @SuppressWarnings("unchecked")
protected TermsEnum getTermsEnum(final Terms terms, AttributeSource atts) throws IOException {
  // very strange: java.lang.Number itself is not Comparable, but all subclasses used here are
  if (min != null && max != null && ((Comparable<T>) min).compareTo(max) > 0) {
    return TermsEnum.EMPTY;
  }
  return new NumericRangeTermsEnum(terms.iterator(null));
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:9,代碼來源:NumericRangeQuery.java

示例11: getTermsEnum

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
@Override
protected TermsEnum getTermsEnum(Terms terms, AttributeSource atts) throws IOException {
  if (lowerTerm != null && upperTerm != null && lowerTerm.compareTo(upperTerm) > 0) {
    return TermsEnum.EMPTY;
  }
  
  TermsEnum tenum = terms.iterator(null);
  
  if ((lowerTerm == null || (includeLower && lowerTerm.length == 0)) && upperTerm == null) {
    return tenum;
  }
  return new TermRangeTermsEnum(tenum,
      lowerTerm, upperTerm, includeLower, includeUpper);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:15,代碼來源:TermRangeQuery.java

示例12: getTermsEnum

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
@Override  
protected TermsEnum getTermsEnum(Terms terms, AttributeSource atts) throws IOException {
  TermsEnum tenum = terms.iterator(null);
  
  if (prefix.bytes().length == 0) {
    // no prefix -- match all terms for this field:
    return tenum;
  }
  return new PrefixTermsEnum(tenum, prefix.bytes());
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:11,代碼來源:PrefixQuery.java

示例13: getTermsEnum

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
@Override
protected TermsEnum getTermsEnum(Terms terms, AttributeSource atts) throws IOException {
  if (maxEdits == 0 || prefixLength >= term.text().length()) {  // can only match if it's exact
    return new SingleTermsEnum(terms.iterator(null), term.bytes());
  }
  return new FuzzyTermsEnum(terms, atts, getTerm(), maxEdits, prefixLength, transpositions);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:8,代碼來源:FuzzyQuery.java

示例14: setAttributeSource

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
/**
 * Sets attributeSource to a new instance.
 */
void setAttributeSource(AttributeSource attributeSource) {
  if (this.attributeSource != attributeSource) {
    this.attributeSource = attributeSource;
    termAttribute = attributeSource.getAttribute(TermToBytesRefAttribute.class);
    posIncrAttribute = attributeSource.addAttribute(PositionIncrementAttribute.class);
    offsetAttribute = attributeSource.addAttribute(OffsetAttribute.class);
    payloadAttribute = attributeSource.getAttribute(PayloadAttribute.class);
  }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:13,代碼來源:FieldInvertState.java

示例15: nextTok

import org.apache.lucene.util.AttributeSource; //導入依賴的package包/類
private AttributeSource nextTok() throws IOException {
  if (buffer!=null && !buffer.isEmpty()) {
    return buffer.removeFirst();
  } else {
    if (!exhausted && input.incrementToken()) {
      return this;
    } else {
      exhausted = true;
      return null;
    }
  }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:13,代碼來源:SlowSynonymFilter.java


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