1 #Region "Microsoft.VisualBasic::ebc0acb27e6002bb75c2f03711b0f9ac, Microsoft.VisualBasic.Core\Extensions\Trinity\Extensions.vb"
2
3     ' Author:
4     
5     '       asuka (amethyst.asuka@gcmodeller.org)
6     '       xie (genetics@smrucc.org)
7     '       xieguigang (xie.guigang@live.com)
8     
9     ' Copyright (c) 2018 GPL3 Licensed
10     
11     
12     ' GNU GENERAL PUBLIC LICENSE (GPL3)
13     
14     
15     ' This program is free software: you can redistribute it and/or modify
16     ' it under the terms of the GNU General Public License as published by
17     ' the Free Software Foundation, either version 3 of the License, or
18     ' (at your option) any later version.
19     
20     ' This program is distributed in the hope that it will be useful,
21     ' but WITHOUT ANY WARRANTY; without even the implied warranty of
22     ' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23     ' GNU General Public License for more details.
24     
25     ' You should have received a copy of the GNU General Public License
26     ' along with this program. If not, see <http://www.gnu.org/licenses/>.
27
28
29
30     ' /********************************************************************************/
31
32     ' Summaries:
33
34     '     Module Extensions
35     
36     '         Properties: ClassTable
37     
38     '         Constructor: (+1 OverloadsSub New
39     '         FunctionGetClass
40     
41     
42     ' /********************************************************************************/
43
44 #End Region
45
46 Imports Microsoft.VisualBasic.Data.Trinity.NLP
47 Imports Microsoft.VisualBasic.Language
48
49 Namespace Data.Trinity
50
51     Public Module Extensions
52
53         Public ReadOnly Property ClassTable As IReadOnlyDictionary(Of String, WordClass)
54
55         Sub New()
56             ClassTable = Enums(Of WordClass).ToDictionary(Function(c) c.Description)
57         End Sub
58
59         Public Function GetClass(tag As StringAs WordClass
60             With LCase(tag)
61                 If ClassTable.ContainsKey(.ByRef) Then
62                     Return ClassTable(.ByRef)
63                 Else
64                     Return WordClass.NA
65                 End If
66             End With
67         End Function
68     End Module
69 End Namespace