/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ using System; using AttributeSource = Lucene.Net.Util.AttributeSource; namespace Lucene.Net.Analysis { /// This class can be used if the token attributes of a TokenStream /// are intended to be consumed more than once. It caches /// all token attribute states locally in a List. /// ///

CachingTokenFilter implements the optional method /// {@link TokenStream#Reset()}, which repositions the /// stream to the first Token. ///

public class CachingTokenFilter:TokenFilter { private System.Collections.IList cache = null; private System.Collections.IEnumerator iterator = null; private AttributeSource.State finalState; public CachingTokenFilter(TokenStream input):base(input) { } /// Will be removed in Lucene 3.0. This method is final, as it should /// not be overridden. Delegates to the backwards compatibility layer. /// [Obsolete("Will be removed in Lucene 3.0. This method is final, as it should not be overridden. Delegates to the backwards compatibility layer. ")] public override Token Next(Token reusableToken) { return base.Next(reusableToken); } /// Will be removed in Lucene 3.0. This method is final, as it should /// not be overridden. Delegates to the backwards compatibility layer. /// [Obsolete("Will be removed in Lucene 3.0. This method is final, as it should not be overridden. Delegates to the backwards compatibility layer. ")] public override Token Next() { return base.Next(); } public override bool IncrementToken() { if (cache == null) { // fill cache lazily cache = new System.Collections.ArrayList(); FillCache(); iterator = cache.GetEnumerator(); } if (!iterator.MoveNext()) { // the cache is exhausted, return false return false; } // Since the TokenFilter can be reset, the tokens need to be preserved as immutable. RestoreState((AttributeSource.State) iterator.Current); return true; } public override void End() { if (finalState != null) { RestoreState(finalState); } } public override void Reset() { if (cache != null) { iterator = cache.GetEnumerator(); } } private void FillCache() { while (input.IncrementToken()) { cache.Add(CaptureState()); } // capture final state input.End(); finalState = CaptureState(); } } }