LUCENE-5384: Add some analysis api tips to the package.html (closes #12)

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1555907 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Robert Muir 2014-01-06 16:44:14 +00:00
parent a92ca0f717
commit e45755d9b1
2 changed files with 25 additions and 2 deletions

View File

@ -141,6 +141,12 @@ Changes in Runtime Behavior
AlreadyClosedException if the refCount in incremented but AlreadyClosedException if the refCount in incremented but
is less that 1. (Simon Willnauer) is less that 1. (Simon Willnauer)
Documentation
* LUCENE-5384: Add some tips for making tokenfilters and tokenizers
to the analysis package overview.
(Benson Margulies via Robert Muir - pull request #12)
======================= Lucene 4.6.0 ======================= ======================= Lucene 4.6.0 =======================
New Features New Features

View File

@ -386,7 +386,15 @@ and proximity searches (though sentence identification is not provided by Lucene
<li>The first position increment must be &gt; 0.</li> <li>The first position increment must be &gt; 0.</li>
<li>Positions must not go backward.</li> <li>Positions must not go backward.</li>
<li>Tokens that have the same start position must have the same start offset.</li> <li>Tokens that have the same start position must have the same start offset.</li>
<li>Tokens that have the same end position (taking into account the position length) must have the same end offset.</li> <li>Tokens that have the same end position (taking into account the
position length) must have the same end offset.</li>
<li>Tokenizers must call {@link
org.apache.lucene.util.AttributeSource#clearAttributes()} in
incrementToken().</li>
<li>Tokenizers must override {@link
org.apache.lucene.analysis.TokenStream#end()}, and pass the final
offset (the total number of input characters processed) to both
parameters of {@link org.apache.lucene.analysis.tokenattributes.OffsetAttribute#setOffset(int, int)}.</li>
</ul> </ul>
<p> <p>
Although these rules might seem easy to follow, problems can quickly happen when chaining Although these rules might seem easy to follow, problems can quickly happen when chaining
@ -395,7 +403,8 @@ and proximity searches (though sentence identification is not provided by Lucene
</p> </p>
<ul> <ul>
<li>Token filters should not modify offsets. If you feel that your filter would need to modify offsets, then it should probably be implemented as a tokenizer.</li> <li>Token filters should not modify offsets. If you feel that your filter would need to modify offsets, then it should probably be implemented as a tokenizer.</li>
<li>Token filters should not insert positions. If a filter needs to add tokens, then they shoud all have a position increment of 0.</li> <li>Token filters should not insert positions. If a filter needs to add tokens, then they should all have a position increment of 0.</li>
<li>When they add tokens, token filters should call {@link org.apache.lucene.util.AttributeSource#clearAttributes()} first.</li>
<li>When they remove tokens, token filters should increment the position increment of the following token.</li> <li>When they remove tokens, token filters should increment the position increment of the following token.</li>
<li>Token filters should preserve position lengths.</li> <li>Token filters should preserve position lengths.</li>
</ul> </ul>
@ -467,6 +476,14 @@ and proximity searches (though sentence identification is not provided by Lucene
</td> </td>
</tr> </tr>
</table> </table>
<h3>Testing Your Analysis Component</h3>
<p>
The lucene-test-framework component defines
<a href="{@docRoot}/../test-framework/org/apache/lucene/analysis/BaseTokenStreamTestCase.html">BaseTokenStreamTestCase</a>. By extending
this class, you can create JUnit tests that validate that your
Analyzer and/or analysis components correctly implement the
protocol. The checkRandomData methods of that class are particularly effective in flushing out errors.
</p>
<h3>Using the TokenStream API</h3> <h3>Using the TokenStream API</h3>
There are a few important things to know in order to use the new API efficiently which are summarized here. You may want There are a few important things to know in order to use the new API efficiently which are summarized here. You may want
to walk through the example below first and come back to this section afterwards. to walk through the example below first and come back to this section afterwards.