-
Notifications
You must be signed in to change notification settings - Fork 0
/
Decoder.cs
110 lines (106 loc) · 5.65 KB
/
Decoder.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
using System.ComponentModel;
using System.Linq;
using System.Text.RegularExpressions;
namespace Laba1
{
public class Decoder
{
public static void Decoding()
{
var decoder = new BackgroundWorker { WorkerReportsProgress = true };
decoder.DoWork += decoder_DoWork;
decoder.ProgressChanged += decoder_ProgressChanged;
decoder.RunWorkerCompleted += decoder_RunWorkerCompleted;
decoder.RunWorkerAsync();
}
private static void decoder_DoWork(object sender, DoWorkEventArgs e)
{
var i = 0;
switch (Processor.Lang)
{
case Languages.Ru:
switch (Processor.Task)
{
case Keys.Straight:
case Keys.Progressive:
foreach (var c in Processor.Text.Where(char.IsLetter))
{
var reg = new Regex(Processor.Key[i].ToString());
var reg1 = new Regex(c.ToString());
Processor.Cipertext += char.IsLower(c)
? Processor.SmlRus[((reg1.Match(Processor.SmlRus).Index) + 33 - reg.Match(Processor.SmlRus).Index) % 33]
: Processor.BigRus[((reg1.Match(Processor.BigRus).Index) + 33 - reg.Match(Processor.SmlRus).Index) % 33];
i++;
(sender as BackgroundWorker).ReportProgress(i);
}
break;
case Keys.Auto:
for (i = 0; i < Processor.KeyLen; i++)
{
var c = Processor.Text[i];
var reg = new Regex(Processor.Key[i].ToString());
var reg1 = new Regex(c.ToString());
Processor.Cipertext += char.IsLower(c)
? Processor.SmlRus[(reg1.Match(Processor.SmlRus).Index + 33 - reg.Match(Processor.SmlRus).Index) % 33]
: Processor.BigRus[(reg1.Match(Processor.BigRus).Index + 33 - reg.Match(Processor.SmlRus).Index) % 33];
(sender as BackgroundWorker).ReportProgress(i);
}
for (; i < Processor.Text.Length; i++)
{
var c = Processor.Text[i];
var reg = new Regex(Processor.Cipertext.ToLower()[i - Processor.KeyLen].ToString());
var reg1 = new Regex(c.ToString());
Processor.Cipertext += char.IsLower(c)
? Processor.SmlRus[(reg1.Match(Processor.SmlRus).Index + 33 - reg.Match(Processor.SmlRus).Index) % 33]
: Processor.BigRus[(reg1.Match(Processor.BigRus).Index + 33 - reg.Match(Processor.SmlRus).Index) % 33];
(sender as BackgroundWorker).ReportProgress(i);
}
break;
}
break;
case Languages.Eng:
switch (Processor.Task)
{
case Keys.Straight:
case Keys.Progressive:
foreach (var c in Processor.Text.Where(char.IsLetter))
{
Processor.Cipertext += char.IsLower(c)
? Processor.SmlEng[((c - 'a') + 104 - (Processor.Key[i] - 'a')) % 26]
: Processor.BigEng[((c - 'A') + 104 - (Processor.Key[i] - 'a')) % 26];
i++;
(sender as BackgroundWorker).ReportProgress(i);
}
break;
case Keys.Auto:
for (i = 0; i < Processor.KeyLen; i++)
{
var c = Processor.Text[i];
Processor.Cipertext += char.IsLower(c)
? Processor.SmlEng[((c - 'a') + 104 - (Processor.Key[i] - 'a')) % 26]
: Processor.BigEng[((c - 'A') + 104 - (Processor.Key[i] - 'a')) % 26];
(sender as BackgroundWorker).ReportProgress(i);
}
for (; i < Processor.Text.Length; i++)
{
var c = Processor.Text[i];
Processor.Cipertext += char.IsLower(c)
? Processor.SmlEng[((c - 'a') + 104 - (Processor.Cipertext.ToLower()[i - Processor.KeyLen] - 'a')) % 26]
: Processor.BigEng[((c - 'A') + 104 - (Processor.Cipertext.ToLower()[i - Processor.KeyLen] - 'a')) % 26];
(sender as BackgroundWorker).ReportProgress(i);
}
break;
}
break;
}
}
private static void decoder_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
Processor.Bar.Value = e.ProgressPercentage;
}
private static void decoder_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
Processor.Goal.Text = Processor.Cipertext;
}
}
}