1 #Region "Microsoft.VisualBasic::f90127708c0dd871af8142375132f13c, Microsoft.VisualBasic.Core\ComponentModel\Ranges\RangeList.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 RangeList
35     
36     '         Constructor: (+1 OverloadsSub New
37     '         Function: [Select], (+2 OverloadsSelectValue
38     
39     
40     ' /********************************************************************************/
41
42 #End Region
43
44 Imports Microsoft.VisualBasic.ComponentModel.Ranges.Model
45 Imports Microsoft.VisualBasic.Language
46 Imports Microsoft.VisualBasic.Serialization.JSON
47
48 Namespace ComponentModel.Ranges
49
50     Public Class RangeList(Of T As IComparable, V) : Inherits List(Of RangeTagValue(Of T, V))
51
52         Sub New()
53             MyBase.New(128)
54         End Sub
55
56         Public Function [Select](x As T) As RangeTagValue(Of T, V)
57             Dim LQuery As RangeTagValue(Of T, V) =
58                 LinqAPI.DefaultFirst(Of RangeTagValue(Of T, V)) <=
59                 From r As RangeTagValue(Of T, V)
60                 In Me.AsQueryable
61                 Where r.IsInside(x)
62                 Select r
63
64             Return LQuery
65         End Function
66
67         Public Function SelectValue(x As T, Optional [throw] As Boolean = TrueOptional ByRef success As Boolean = FalseAs V
68             Dim n As RangeTagValue(Of T, V) = [Select](x)
69             If n Is Nothing Then
70                 If [throw] Then
71                     Throw New DataException($"{x.GetJson} is not in any ranges!")
72                 Else
73                     Return Nothing
74                 End If
75             Else
76                 success = True
77                 Return n.Value
78             End If
79         End Function
80
81         Public Function SelectValue(x As T, [default] As Func(Of T, V)) As V
82             Dim success As Boolean = False
83             Dim v As V = SelectValue(x, [throw]:=False, success:=success)
84
85             If success Then
86                 Return v
87             Else
88                 Return [default](x)
89             End If
90         End Function
91
92         Public ReadOnly Iterator Property Values As IEnumerable(Of V)
93             Get
94                 For Each x As RangeTagValue(Of T, V) In Me
95                     Yield x.Value
96                 Next
97             End Get
98         End Property
99
100         Public ReadOnly Iterator Property Keys As IEnumerable(Of Range(Of T))
101             Get
102                 For Each x As RangeTagValue(Of T, V) In Me
103                     Yield x
104                 Next
105             End Get
106         End Property
107     End Class
108 End Namespace