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.
Main Page
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Properties
Pages
core
Document
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]
28
public
class
SetBasedFieldSelector
:
FieldSelector
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
{
57
FieldSelectorResult
result =
FieldSelectorResult
.NO_LOAD;
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
}
Generated on Thu Jan 3 2013 02:34:11 for Lucene.Net by
1.8.3