mirror of
https://github.com/AAndyProgram/SCrawler.git
synced 2026-03-15 00:02:17 +00:00
112 lines
4.6 KiB
VB.net
112 lines
4.6 KiB
VB.net
' Copyright (C) 2022 Andy
|
|
' This program is free software: you can redistribute it and/or modify
|
|
' it under the terms of the GNU General Public License as published by
|
|
' the Free Software Foundation, either version 3 of the License, or
|
|
' (at your option) any later version.
|
|
'
|
|
' This program is distributed in the hope that it will be useful,
|
|
' but WITHOUT ANY WARRANTY
|
|
Imports PersonalUtilities.Tools
|
|
Friend Class LabelsKeeper : Implements ICollection(Of String), IMyEnumerator(Of String), IDisposable
|
|
Friend Event NewLabelAdded()
|
|
Friend Const NoLabeledName As String = "No Label"
|
|
Friend Const NoParsedUser As String = "No Parsed"
|
|
Friend ReadOnly NoLabel As New ListViewGroup(NoLabeledName, NoLabeledName)
|
|
Private ReadOnly LabelsList As List(Of String)
|
|
Private ReadOnly LabelsFile As SFile = "Settings\Labels.txt"
|
|
Friend ReadOnly NewLabels As List(Of String)
|
|
Friend ReadOnly Property NewLabelsExists As Boolean
|
|
Get
|
|
Return NewLabels.Count > 0
|
|
End Get
|
|
End Property
|
|
Friend ReadOnly Property CurrentSelection As List(Of String)
|
|
Friend Sub New()
|
|
LabelsList = New List(Of String)
|
|
NewLabels = New List(Of String)
|
|
CurrentSelection = New List(Of String)
|
|
If LabelsFile.Exists Then LabelsList.ListAddList(IO.File.ReadAllLines(LabelsFile), LAP.NotContainsOnly)
|
|
LabelsList.ListAddList({NoLabeledName, NoParsedUser}, LAP.NotContainsOnly)
|
|
End Sub
|
|
Friend ReadOnly Property ToList As List(Of String)
|
|
Get
|
|
Return LabelsList
|
|
End Get
|
|
End Property
|
|
Friend ReadOnly Property Count As Integer Implements ICollection(Of String).Count, IMyEnumerator(Of String).MyEnumeratorCount
|
|
Get
|
|
Return LabelsList.Count
|
|
End Get
|
|
End Property
|
|
Default Friend ReadOnly Property Item(ByVal Index As Integer) As String Implements IMyEnumerator(Of String).MyEnumeratorObject
|
|
Get
|
|
Return LabelsList(Index)
|
|
End Get
|
|
End Property
|
|
Friend Sub Clear() Implements ICollection(Of String).Clear
|
|
LabelsList.Clear()
|
|
NewLabels.Clear()
|
|
End Sub
|
|
Friend Sub Update()
|
|
If LabelsList.Count > 0 Then
|
|
LabelsList.Sort()
|
|
TextSaver.SaveTextToFile(LabelsList.ListToString(, vbNewLine), LabelsFile, True, False, EDP.SendInLog)
|
|
Else
|
|
If LabelsFile.Exists Then LabelsFile.Delete(,,, EDP.SendInLog)
|
|
End If
|
|
End Sub
|
|
Friend Overloads Sub Add(ByVal _Item As String) Implements ICollection(Of String).Add
|
|
Add(_Item, True)
|
|
End Sub
|
|
Friend Overloads Sub Add(ByVal _Item As String, ByVal UpdateMainFrame As Boolean)
|
|
If Not _Item.IsEmptyString And Not LabelsList.Contains(_Item) Then
|
|
LabelsList.Add(_Item)
|
|
If Not NewLabels.Contains(_Item) Then NewLabels.Add(_Item)
|
|
If UpdateMainFrame Then RaiseEvent NewLabelAdded()
|
|
End If
|
|
End Sub
|
|
Friend Sub AddRange(ByVal _Items As IEnumerable(Of String))
|
|
If _Items.ListExists Then
|
|
For Each i$ In _Items : Add(i, False) : Next
|
|
RaiseEvent NewLabelAdded()
|
|
End If
|
|
End Sub
|
|
Friend Function Contains(ByVal _Item As String) As Boolean Implements ICollection(Of String).Contains
|
|
Return LabelsList.Contains(_Item)
|
|
End Function
|
|
Friend Function Remove(ByVal _Item As String) As Boolean Implements ICollection(Of String).Remove
|
|
Return LabelsList.Remove(_Item)
|
|
End Function
|
|
Private ReadOnly Property IsReadOnly As Boolean = False Implements ICollection(Of String).IsReadOnly
|
|
Private Sub CopyTo(ByVal _Array() As String, ByVal ArrayIndex As Integer) Implements ICollection(Of String).CopyTo
|
|
Throw New NotImplementedException()
|
|
End Sub
|
|
#Region "IEnumerable Support"
|
|
Private Function GetEnumerator() As IEnumerator(Of String) Implements IEnumerable(Of String).GetEnumerator
|
|
Return New MyEnumerator(Of String)(Me)
|
|
End Function
|
|
Private Function IEnumerable_GetEnumerator() As IEnumerator Implements IEnumerable.GetEnumerator
|
|
Return GetEnumerator()
|
|
End Function
|
|
#End Region
|
|
#Region "IDisposable Support"
|
|
Private disposedValue As Boolean = False
|
|
Protected Overridable Overloads Sub Dispose(ByVal disposing As Boolean)
|
|
If Not disposedValue Then
|
|
If disposing Then
|
|
Clear()
|
|
CurrentSelection.Clear()
|
|
End If
|
|
disposedValue = True
|
|
End If
|
|
End Sub
|
|
Protected Overrides Sub Finalize()
|
|
Dispose(False)
|
|
MyBase.Finalize()
|
|
End Sub
|
|
Friend Overloads Sub Dispose() Implements IDisposable.Dispose
|
|
Dispose(True)
|
|
GC.SuppressFinalize(Me)
|
|
End Sub
|
|
#End Region
|
|
End Class |