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
SegmentTermPositionVector.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 
20 namespace Lucene.Net.Index
21 {
22 
24  {
25  protected internal int[][] positions;
26  protected internal TermVectorOffsetInfo[][] offsets;
27  public static readonly int[] EMPTY_TERM_POS = new int[0];
28 
29  public SegmentTermPositionVector(System.String field, System.String[] terms, int[] termFreqs, int[][] positions, TermVectorOffsetInfo[][] offsets):base(field, terms, termFreqs)
30  {
31  this.offsets = offsets;
32  this.positions = positions;
33  }
34 
35  /// <summary> Returns an array of TermVectorOffsetInfo in which the term is found.
36  ///
37  /// </summary>
38  /// <param name="index">The position in the array to get the offsets from
39  /// </param>
40  /// <returns> An array of TermVectorOffsetInfo objects or the empty list
41  /// </returns>
42  /// <seealso cref="Lucene.Net.Analysis.Token">
43  /// </seealso>
44  public virtual TermVectorOffsetInfo[] GetOffsets(int index)
45  {
47  if (offsets == null)
48  return null;
49  if (index >= 0 && index < offsets.Length)
50  {
51  result = offsets[index];
52  }
53  return result;
54  }
55 
56  /// <summary> Returns an array of positions in which the term is found.
57  /// Terms are identified by the index at which its number appears in the
58  /// term String array obtained from the <c>indexOf</c> method.
59  /// </summary>
60  public virtual int[] GetTermPositions(int index)
61  {
62  int[] result = EMPTY_TERM_POS;
63  if (positions == null)
64  return null;
65  if (index >= 0 && index < positions.Length)
66  {
67  result = positions[index];
68  }
69 
70  return result;
71  }
72  }
73 }