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
HunspellStem.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.Analysis.Hunspell {
22  public class HunspellStem {
23  private readonly List<HunspellAffix> _prefixes = new List<HunspellAffix>();
24  private readonly List<HunspellAffix> _suffixes = new List<HunspellAffix>();
25  private readonly String _stem;
26 
27  /// <summary>
28  /// the actual word stem itself.
29  /// </summary>
30  public String Stem {
31  get { return _stem; }
32  }
33 
34  /// <summary>
35  /// The stem length.
36  /// </summary>
37  public Int32 StemLength {
38  get { return _stem.Length; }
39  }
40 
41  /// <summary>
42  /// The list of prefixes used to generate the stem.
43  /// </summary>
44  public IEnumerable<HunspellAffix> Prefixes {
45  get { return _prefixes; }
46  }
47 
48  /// <summary>
49  /// The list of suffixes used to generate the stem.
50  /// </summary>
51  public IEnumerable<HunspellAffix> Suffixes {
52  get { return _suffixes; }
53  }
54 
55  /// <summary>
56  /// Creates a new Stem wrapping the given word stem.
57  /// </summary>
58  public HunspellStem(String stem) {
59  if (stem == null) throw new ArgumentNullException("stem");
60 
61  _stem = stem;
62  }
63 
64  /// <summary>
65  /// Adds a prefix to the list of prefixes used to generate this stem. Because it is
66  /// assumed that prefixes are added depth first, the prefix is added to the front of
67  /// the list.
68  /// </summary>
69  /// <param name="prefix">Prefix to add to the list of prefixes for this stem.</param>
70  public void AddPrefix(HunspellAffix prefix) {
71  _prefixes.Insert(0, prefix);
72  }
73 
74  /// <summary>
75  /// Adds a suffix to the list of suffixes used to generate this stem. Because it
76  /// is assumed that suffixes are added depth first, the suffix is added to the end
77  /// of the list.
78  /// </summary>
79  /// <param name="suffix">Suffix to add to the list of suffixes for this stem.</param>
80  public void AddSuffix(HunspellAffix suffix) {
81  _suffixes.Add(suffix);
82  }
83  }
84 }