forked from dkxce/KMZRebuilder
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProcessingForm.cs
112 lines (100 loc) · 3.26 KB
/
ProcessingForm.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
111
112
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
namespace KMZViewer
{
public partial class RunProcStdOutForm : Form
{
private System.Diagnostics.Process proc;
private string _stdText = "";
private bool run_proc = false;
private DateTime Started = DateTime.Now;
public RunProcStdOutForm(string caption)
{
InitializeComponent();
this.Text = caption;
this.SubText.Text = "";
this.DialogResult = DialogResult.Cancel;
UpdateElapsed();
}
public RunProcStdOutForm(string caption, string subText)
{
InitializeComponent();
this.Text = caption;
this.SubText.Text = subText;
this.DialogResult = DialogResult.Cancel;
UpdateElapsed();
}
public void SetText(string text)
{
std.Text = text;
std.SelectionStart = std.Text.Length;
}
public void Write(string text)
{
std.Text += text;
std.SelectionStart = std.Text.Length;
}
public void WriteLine(string line)
{
std.Text += line + "\r\n";
std.SelectionStart = std.Text.Length;
std.ScrollToCaret();
}
public void StdOutputDataReceived(object sender, System.Diagnostics.DataReceivedEventArgs e)
{
_stdText += e.Data + "\r\n";
try
{
this.Invoke(new DoText(WriteLine), new object[] { e.Data });
}
catch { };
}
public string StdText
{
get
{
return _stdText;
}
}
public DialogResult StartProcAndShowWhileRunning(System.Diagnostics.ProcessStartInfo psi)
{
proc = new System.Diagnostics.Process();
proc.StartInfo = psi;
proc.OutputDataReceived += new System.Diagnostics.DataReceivedEventHandler(StdOutputDataReceived);
proc.Start();
proc.BeginOutputReadLine();
this.run_proc = true;
return this.ShowDialog();
}
public delegate void DoText(string text);
private void timer1_Tick(object sender, EventArgs e)
{
UpdateElapsed();
if (run_proc)
{
if (proc.HasExited)
{
try { _stdText = proc.StandardOutput.ReadToEnd(); } catch { };
this.DialogResult = DialogResult.OK;
this.Close();
};
//proc.WaitForExit();
};
}
private ulong tickCounter = 0;
private void UpdateElapsed()
{
if (tickCounter++ % 10 == 0)
{
DateTime isNow = DateTime.Now;
TimeSpan subst = isNow.Subtract(Started);
SelfText.Text = String.Format("Started: {0}, Elapsed: {1}", Started.ToString("HH:mm:ss dd.MM.yyyy"), subst);
};
}
}
}