自定义过滤器不使用solr

时间:2014-05-19 06:57:55

标签: java solr filter lucene

我为solr 4.2创建了一个自定义过滤器工厂。它运作良好。但是当我试图升级solr-4.2到4.7版本时,它报告错误:

  

引起:org.apache.solr.common.SolrException:[schema.xml] analyzer / filter的插件初始化失败:实例化类错误:&#39; org.apache.lucene.analysis.ExtendedNameFilterFactory&#39; < / p>

这是工厂的java代码:

package org.apache.lucene.analysis;

import java.util.Map;
import org.apache.lucene.analysis.util.AbstractAnalysisFactory;
import org.apache.lucene.analysis.util.MultiTermAwareComponent;
import org.apache.lucene.analysis.util.TokenFilterFactory;

public class ExtendedNameFilterFactory extends TokenFilterFactory
  implements MultiTermAwareComponent
{
  int extendedWordCount;

  public void init(Map<String, String> args)
  {
    super.init(args);
    assureMatchVersion();
    this.extendedWordCount = getInt("extendedWordCount", -1);
  }

  public ExtendedNameFilter create(TokenStream input) {
    return new ExtendedNameFilter(this.luceneMatchVersion, input, this.extendedWordCount);
  }

  public AbstractAnalysisFactory getMultiTermComponent()
  {
    return this;
  }
}

对于过滤器:

package org.apache.lucene.analysis;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
import org.apache.lucene.analysis.tokenattributes.OffsetAttribute;
import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute;
import org.apache.lucene.analysis.util.CharacterUtils;
import org.apache.lucene.util.Version;

public final class ExtendedNameFilter extends TokenFilter
{
  private final CharTermAttribute termAtt = (CharTermAttribute)addAttribute(CharTermAttribute.class);
  private PositionIncrementAttribute posIncAttr;
  private OffsetAttribute setOffsetAttr;
  private final int extendedWordCount;
  LinkedList<String> list = new LinkedList();
  ArrayList<Integer> startOffsetList = new ArrayList();
  int endOffset = 0;
  int count = 0;

  public ExtendedNameFilter(Version matchVersion, TokenStream in, int extendedWordCount)
  {
    super(in);
    CharacterUtils.getInstance(matchVersion);
    this.extendedWordCount = extendedWordCount;
    this.posIncAttr = ((PositionIncrementAttribute)addAttribute(PositionIncrementAttribute.class));
    this.setOffsetAttr = ((OffsetAttribute)addAttribute(OffsetAttribute.class));
  }

  public final boolean incrementToken()
    throws IOException
  {
    int len = 0;

    while (this.input.incrementToken()) {
      this.list.add(this.termAtt.toString());
      this.startOffsetList.add(Integer.valueOf(this.setOffsetAttr.startOffset()));
      this.endOffset = this.setOffsetAttr.endOffset();
    }

    Iterator iterator = this.list.iterator();
    len = this.list.size();

    if ((len > 0) && (this.extendedWordCount < 0)) {
      this.termAtt.setEmpty();
      while (iterator.hasNext()) {
        this.termAtt.append((CharSequence)iterator.next());
      }
      this.list.removeFirst();

      this.posIncAttr.setPositionIncrement(10);
      this.setOffsetAttr.setOffset(((Integer)this.startOffsetList.get(this.count)).intValue(), this.endOffset);
      this.count += 1;
      return true;
    }
    if ((len > 0) && (this.count < this.extendedWordCount)) {
      this.termAtt.setEmpty();
      while (iterator.hasNext()) {
        this.termAtt.append((CharSequence)iterator.next());
      }
      this.list.removeFirst();

      this.posIncAttr.setPositionIncrement(10);
      this.setOffsetAttr.setOffset(((Integer)this.startOffsetList.get(this.count)).intValue(), this.endOffset);
      this.count += 1;
      return true;
    }

    return false;
  }
}

与solr 4.2一起工作得很好。有人能告诉我在solr 4.7.1中运行它需要做些什么改变吗?

1 个答案:

答案 0 :(得分:0)

AbstractAnalysisFactory不再使用init方法传入args。改为覆盖constructor