Details
-
Bug
-
Status: Open
-
Major
-
Resolution: Unresolved
-
None
-
None
-
None
-
New, Patch Available
Description
The fine print here is that they can't be reset without calling setReader() every time before reset() is called. The reason for this is that Tokenizer violates the contract put forth by TokenStream.reset() which is the following:
"Resets this stream to a clean state. Stateful implementations must implement this method so that they can be reused, just as if they had been created fresh."
Tokenizer implementation's reset function can't reset in that manner because their Tokenizer.close() removes the reference to the underlying Reader because of LUCENE-2387. The catch-22 here is that we don't want to unnecessarily keep around a Reader (memory leak) but we would like to be able to reset() if necessary.
The patches include an integration test that attempts to use a ConcatenatingTokenStream to join an input TokenStream with a KeywordTokenizer TokenStream. This test fails with an IllegalStateException thrown by Tokenizer.ILLEGAL_STATE_READER.
Attachments
Attachments
Issue Links
- is related to
-
LUCENE-2387 IndexWriter retains references to Readers used in Fields (memory leak)
- Closed
-
LUCENE-8650 ConcatenatingTokenStream does not end() nor reset() properly
- Closed