1 #Region "Microsoft.VisualBasic::b3e63b053b67835981b8dfabf349b196, Microsoft.VisualBasic.Core\CommandLine\CLIMapper.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 CLIMapper
35     
36     '         FunctionGetName, Maps
37     
38     
39     ' /********************************************************************************/
40
41 #End Region
42
43 Imports System.Reflection
44 Imports System.Runtime.CompilerServices
45 Imports Microsoft.VisualBasic.CommandLine.Reflection
46
47 Namespace CommandLine
48
49     ''' <summary>
50     ''' 从可写属性之中赋值
51     ''' </summary>
52     Public Module CLIMapper
53
54         ''' <summary>
55         ''' Assign the argument value in the commandline into the target argument container object.
56         ''' The properties in the container class type needs decorating with attribute 
57         ''' <see cref="CLIParameter"/>
58         ''' </summary>
59         ''' <typeparam name="T"></typeparam>
60         ''' <param name="args"></param>
61         ''' <param name="strict"></param>
62         ''' <returns></returns>
63         <Extension>
64         Public Function Maps(Of T As Class)(args As CommandLine, Optional strict As Boolean = FalseAs T
65             Dim type As Type = GetType(T)
66             Dim obj As Object = Activator.CreateInstance(type)
67             Dim props = From prop As PropertyInfo
68                         In type.GetProperties
69                         Where prop.CanWrite AndAlso
70                             Scripting.IsPrimitive(prop.PropertyType)
71                         Select prop
72
73             For Each prop As PropertyInfo In props
74                 Dim name As String = prop.GetName
75
76                 If Not args.ContainsParameter(name, Not strict) Then
77                     Continue For
78                 Else
79                     type = prop.PropertyType
80                 End If
81
82                 If type.Equals(GetType(Boolean)) Then
83                     ' 由于是逻辑值,所以只要存在就是真,不存在就是False
84                     Call prop.SetValue(obj, TrueNothing)
85                 Else
86                     Dim s As String = args(name)
87                     Dim value = Scripting.CTypeDynamic(s, type)
88
89                     Call prop.SetValue(obj, value, Nothing)
90                 End If
91             Next
92
93             Return DirectCast(obj, T)
94         End Function
95
96         ''' <summary>
97         ''' If the property <paramref name="prop"/> have the custom attribute <see cref="CLIParameter"/>
98         ''' then the name value in <see cref="CLIParameter"/> will be used, otherwise, 
99         ''' <see cref="PropertyInfo.Name"/> will be used. 
100         ''' </summary>
101         ''' <param name="prop"></param>
102         ''' <returns></returns>
103         <Extension> Public Function GetName(prop As PropertyInfo) As String
104             Dim attr As CLIParameter = prop.GetAttribute(Of CLIParameter)
105
106             If attr Is Nothing OrElse attr.Name.StringEmpty Then
107                 Return prop.Name
108             Else
109                 Return attr.Name
110             End If
111         End Function
112     End Module
113 End Namespace