📄 querytokencollector.java
字号:
/*
* 本代码所有权归作者所有 但在保持源代码不被破坏以及所有人署名的基础上 任何人可自由无限使用
*/
package com.sohospace.lucene.analysis.xanalyzer.collector;
import java.util.Iterator;
import java.util.LinkedList;
import org.apache.lucene.analysis.Token;
import com.sohospace.lucene.analysis.xanalyzer.TokenCollector;
/**
*
* @author zhiliang.wang@yahoo.com.cn
*
* @since 1.1
*/
public class QueryTokenCollector implements TokenCollector {
/**
* 存储当前被knife分解而成的Token对象
*
*/
private LinkedList<Token> tokens = new LinkedList<Token>();
private Token candidate;
private Token last;
public Iterator<Token> iterator() {
if (candidate != null) {
this.tokens.add(candidate);
candidate = null;
}
Iterator<Token> iter = this.tokens.iterator();
this.tokens = new LinkedList<Token>();
return iter;
}
public void collect(String word, int offset, int end) {
Token c = candidate != null ? candidate : last;
if (c == null) {
candidate = new Token(word, offset, end);
} else if (offset == c.startOffset()) {
if (end > c.endOffset()) {
candidate = new Token(word, offset, end);
}
} else if (offset > c.startOffset()) {
if (candidate != null) {
select(candidate);
}
if (end > c.endOffset()) {
candidate = new Token(word, offset, end);
} else {
candidate = null;
}
} else if (end >= c.endOffset()) {
if (last != null && last.startOffset() >= offset
&& last.endOffset() <= end) {
for (Iterator iter = tokens.iterator(); iter.hasNext();) {
last = (Token) iter.next();
if (last.startOffset() >= offset && last.endOffset() <= end) {
iter.remove();
}
}
}
last = null;
candidate = new Token(word, offset, end);
}
}
protected void select(Token t) {
this.tokens.add(t);
this.last = t;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -