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
HunspellAffix.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.Diagnostics;
20 using System.Text.RegularExpressions;
21 
22 namespace Lucene.Net.Analysis.Hunspell {
23  /// <summary>
24  /// Wrapper class representing a hunspell affix.
25  /// </summary>
26  [DebuggerDisplay("{Condition}")]
27  public class HunspellAffix {
28  private String _condition;
29  private Regex _conditionPattern;
30 
31  /// <summary>
32  /// The append defined for the affix.
33  /// </summary>
34  public String Append { get; set; }
35 
36  /// <summary>
37  /// The flags defined for the affix append.
38  /// </summary>
39  public Char[] AppendFlags { get; set; }
40 
41  /// <summary>
42  /// The condition that must be met before the affix can be applied.
43  /// </summary>
44  public String Condition {
45  get { return _condition; }
46  }
47 
48  /// <summary>
49  /// The affix flag.
50  /// </summary>
51  public Char Flag { get; set; }
52 
53  /// <summary>
54  /// Whether the affix is defined as cross product.
55  /// </summary>
56  public Boolean IsCrossProduct { get; set; }
57 
58  /// <summary>
59  /// The stripping characters defined for the affix.
60  /// </summary>
61  public String Strip { get; set; }
62 
63  /// <summary>
64  /// Checks whether the String defined by the provided char array, offset
65  /// and length, meets the condition of this affix.
66  /// </summary>
67  /// <returns>
68  /// <c>true</c> if the String meets the condition, <c>false</c> otherwise.
69  /// </returns>
70  public Boolean CheckCondition(String text) {
71  if (text == null)
72  throw new ArgumentNullException("text");
73 
74  return _conditionPattern.IsMatch(text);
75  }
76 
77  /// <summary>
78  /// Sets the condition that must be met before the affix can be applied.
79  /// </summary>
80  /// <param name="condition">Condition to be met before affix application.</param>
81  /// <param name="pattern">Condition as a regular expression pattern.</param>
82  public void SetCondition(String condition, String pattern) {
83  if (condition == null) throw new ArgumentNullException("condition");
84  if (pattern == null) throw new ArgumentNullException("pattern");
85 
86  _condition = condition;
87  _conditionPattern = new Regex(pattern);
88  }
89  }
90 }