Lucene.Net  3.0.3
Lucene.Net is a port of the Lucene search engine library, written in C# and targeted at .NET runtime users.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Properties Pages
SetBasedFieldSelector.cs
Go to the documentation of this file.
1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one or more
3  * contributor license agreements. See the NOTICE file distributed with
4  * this work for additional information regarding copyright ownership.
5  * The ASF licenses this file to You under the Apache License, Version 2.0
6  * (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17 
18 using System;
19 using System.Collections.Generic;
20 
21 namespace Lucene.Net.Documents
22 {
23  /// <summary> Declare what fields to load normally and what fields to load lazily
24  ///
25  ///
26  /// </summary>
27  [Serializable]
29  {
30  private ISet<string> fieldsToLoad;
31  private ISet<string> lazyFieldsToLoad;
32 
33  /// <summary> Pass in the Set of <see cref="Field" /> names to load and the Set of <see cref="Field" /> names to load lazily. If both are null, the
34  /// Document will not have any <see cref="Field" /> on it.
35  /// </summary>
36  /// <param name="fieldsToLoad">A Set of <see cref="String" /> field names to load. May be empty, but not null
37  /// </param>
38  /// <param name="lazyFieldsToLoad">A Set of <see cref="String" /> field names to load lazily. May be empty, but not null
39  /// </param>
40  public SetBasedFieldSelector(ISet<string> fieldsToLoad, ISet<string> lazyFieldsToLoad)
41  {
42  this.fieldsToLoad = fieldsToLoad;
43  this.lazyFieldsToLoad = lazyFieldsToLoad;
44  }
45 
46  /// <summary> Indicate whether to load the field with the given name or not. If the <see cref="AbstractField.Name()" /> is not in either of the
47  /// initializing Sets, then <see cref="Lucene.Net.Documents.FieldSelectorResult.NO_LOAD" /> is returned. If a Field name
48  /// is in both <c>fieldsToLoad</c> and <c>lazyFieldsToLoad</c>, lazy has precedence.
49  ///
50  /// </summary>
51  /// <param name="fieldName">The <see cref="Field" /> name to check
52  /// </param>
53  /// <returns> The <see cref="FieldSelectorResult" />
54  /// </returns>
55  public virtual FieldSelectorResult Accept(System.String fieldName)
56  {
58  if (fieldsToLoad.Contains(fieldName) == true)
59  {
60  result = FieldSelectorResult.LOAD;
61  }
62  if (lazyFieldsToLoad.Contains(fieldName) == true)
63  {
64  result = FieldSelectorResult.LAZY_LOAD;
65  }
66  return result;
67  }
68  }
69 }