1 #Region "Microsoft.VisualBasic::ce95daf644439f5b9e74bb5af16d068d, Microsoft.VisualBasic.Core\CommandLine\CliResCommon.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     '     Class CliResCommon
35     
36     '         Constructor: (+1 OverloadsSub New
37     '         FunctionToString, TryRelease
38     
39     
40     ' /********************************************************************************/
41
42 #End Region
43
44 Imports System.Reflection
45
46 Namespace CommandLine
47
48     ''' <summary>
49     ''' CLI resources manager
50     ''' </summary>
51     Public Class CliResCommon
52
53         Private ReadOnly bufType As Type = GetType(Byte())
54         Private ReadOnly Resource As Dictionary(Of String, Func(Of Byte()))
55
56         ReadOnly EXPORT As String
57
58         ''' <summary>
59         ''' 
60         ''' </summary>
61         ''' <param name="EXPORT">资源文件的数据缓存文件夹</param>
62         Sub New(EXPORT As String, ResourceManager As Type)
63             Dim tag As BindingFlags = BindingFlags.NonPublic Or BindingFlags.Static
64             Dim propBufs = From [Property] As PropertyInfo
65                            In ResourceManager.GetProperties(bindingAttr:=tag)
66                            Where [Property].PropertyType.Equals(bufType)
67                            Select [Property]
68
69             Me.EXPORT = EXPORT
70             Me.Resource = propBufs.ToDictionary(Of String, Func(Of Byte()))(
71                 Function(x) x.Name,
72                 Function(x) New Func(Of Byte())(Function() DirectCast(x.GetValue(Nothing, Nothing), Byte())))
73         End Sub
74
75         ''' <summary>
76         ''' 
77         ''' </summary>
78         ''' <param name="Name">使用 NameOf 操作符来获取资源</param>
79         ''' <returns></returns>
80         Public Function TryRelease(Name As StringOptional ext As String = "exe"As String
81             Dim path As String = $"{EXPORT}/{Name}.{ext}"
82
83             If path.FileExists Then
84                 Return path
85             End If
86
87             If Not Resource.ContainsKey(Name) Then
88                 Return ""
89             End If
90
91             Dim buf As Byte() = Resource(Name)()
92             Try
93                 If buf.FlushStream(path) Then
94                     Call Console.WriteLine(resReleaseMsg, path.ToFileURL, buf.Length)
95                     Return path
96                 Else
97                     Return ""
98                 End If
99             Catch ex As Exception
100                 ex = New Exception(path, ex)
101                 Call App.LogException(ex)
102                 Return ""
103             End Try
104         End Function
105
106         Const resReleaseMsg As String = "Release resource to {0} // length={1} bytes"
107
108         Public Overrides Function ToString() As String
109             Return EXPORT
110         End Function
111     End Class
112 End Namespace