using System;
using System.Drawing;
using System.Windows.Forms;
using System.Threading;
using NaGet.SubCommands;
using NaGet.Net;
namespace AppliStation.Util
{
///
/// Description of ExecutionProgressViewer.
///
public partial class ExecutionProgressViewer : Form
{
private NaGetTaskSet taskSet;
private Downloader downloader;
private Thread tasksetRunningThread = null;
///
/// 終了時に何を行うかのフラグ
///
public enum ActionOnDoneFlags {
None = 0,
FlashWindow = 1,
AutoCloseOnSuccess = 2,
}
///
/// 終了時に何を行うか
///
public ActionOnDoneFlags ActionOnDone = ActionOnDoneFlags.FlashWindow;
public Downloader Downloader {
get { return downloader; }
}
public ExecutionProgressViewer()
{
//
// The InitializeComponent() call is required for Windows Forms designer support.
//
InitializeComponent();
downloader = new Downloader();
downloader.DownloadEventRaised += delegate(object sender, DownloadEventArgs e) {
if (InvokeRequired) {
Invoke(new EventHandler(onDownloadEvent), sender, e);
} else {
onDownloadEvent(sender, e);
}
};
}
private void onDownloadEvent(object sender, DownloadEventArgs a)
{
if (a.TaskProgressPercent >= 0) {
progressBarSub.Value = (int) a.TaskProgressPercent;
progressBarSub.Style = ProgressBarStyle.Continuous;
} else {
progressBarSub.Style = ProgressBarStyle.Marquee;
}
switch (a.Type) {
case DownloadEventType.INITED:
case DownloadEventType.CONNECTED:
progressSubLabel.Text = a.TaskMessage;
progressBarSub.Visible = true;
progressSubLabel.Visible = true;
break;
case DownloadEventType.DOWNLOADING:
progressSubLabel.Text = a.TaskMessage;
break;
case DownloadEventType.COMPLETED:
progressBarSub.Visible = false;
progressSubLabel.Visible = false;
break;
case DownloadEventType.ERROR:
progressBarSub.Visible = false;
progressSubLabel.Visible = false;
logBox.SelectionColor = System.Drawing.Color.Red;
logBox.AppendText(" [エラー] " + a.TaskMessage + System.Environment.NewLine);
logBox.SelectionColor = logBox.ForeColor;
break;
}
}
#region NaGetTaskSet関連
private void onTaskSetRaised(object sender, NaGetTaskSetEventArgs e)
{
NaGetTaskSet taskSet = (NaGetTaskSet) sender;
if (e.TaskProgressPercent >= 0) {
progressBar.Value = (int) e.TaskProgressPercent;
progressBar.Style = ProgressBarStyle.Continuous;
} else {
progressBar.Style = ProgressBarStyle.Marquee;
}
progressLabel.Text = e.TaskMessage ?? string.Empty;
cancelButton.Enabled = taskSet.Running && taskSet.Cancelable;
switch (e.Type) {
case NaGetTaskSetEventType.COMPLETED:
logBox.AppendText("完了." + System.Environment.NewLine);
if (taskSet.Done) {
okButton.Enabled = true;
cancelButton.Enabled = false;
}
break;
case NaGetTaskSetEventType.STARTED_TASKSET:
subtitleLabel.Text = taskSet.TaskSetNames[taskSet.CurrentTaskSetIndex];
logBox.AppendText(" " + e.TaskMessage + System.Environment.NewLine);
break;
case NaGetTaskSetEventType.COMPLETED_TASKSET:
if (progressBarSub.Visible) progressBarSub.Hide();
if (progressSubLabel.Visible) progressSubLabel.Hide();
NativeMethods.ProgressBar_SetState(progressBar, 1); // VistaProgress色:ノーマル
logBox.AppendText(string.Format(" ... 完了. [{0}%]", (int) e.TaskProgressPercent));
logBox.AppendText(System.Environment.NewLine);
break;
case NaGetTaskSetEventType.INFO:
logBox.AppendText(" " + e.TaskMessage + System.Environment.NewLine);
break;
case NaGetTaskSetEventType.ERROR:
logBox.SelectionColor = System.Drawing.Color.Red;
logBox.AppendText(" [エラー] " + e.TaskMessage + System.Environment.NewLine);
logBox.SelectionColor = logBox.ForeColor;
NativeMethods.ProgressBar_SetState(progressBar, 2); // VistaProgress色:エラー
okButton.Enabled = true;
cancelButton.Enabled = false;
break;
case NaGetTaskSetEventType.CANCELED:
logBox.SelectionColor = System.Drawing.Color.Red;
logBox.AppendText(e.TaskMessage + System.Environment.NewLine);
logBox.SelectionColor = logBox.ForeColor;
NativeMethods.ProgressBar_SetState(progressBar, 1); // VistaProgress色:中断
okButton.Enabled = true;
cancelButton.Enabled = false;
break;
case NaGetTaskSetEventType.WARNING:
logBox.SelectionColor = System.Drawing.Color.Red;
logBox.AppendText(" [エラー] " + e.TaskMessage + System.Environment.NewLine);
logBox.SelectionColor = logBox.ForeColor;
break;
}
if (taskSet.Done) {
if ((ActionOnDone & ActionOnDoneFlags.FlashWindow) != 0) {
NativeMethods.Form_FlashWindow(this,
NativeMethods.FlashFlag.All | NativeMethods.FlashFlag.TimerNoFG,
uint.MaxValue, 0);
}
if (okButton.Enabled && (ActionOnDone & ActionOnDoneFlags.AutoCloseOnSuccess) != 0) {
this.DialogResult = DialogResult.OK;
Close();
Dispose();
}
}
}
public void SetTaskSet(NaGetTaskSet taskSet)
{
this.taskSet = taskSet;
taskSet.TaskSetRaised += delegate(object sender, NaGetTaskSetEventArgs e) {
if (InvokeRequired) {
Invoke(new EventHandler(onTaskSetRaised), taskSet, e);
} else {
onTaskSetRaised(taskSet, e);
}
};
}
public void StartTaskSet()
{
tasksetRunningThread = new Thread(taskSet.Run);
tasksetRunningThread.Start();
}
#endregion
void OkButtonClick(object sender, EventArgs e)
{
if (taskSet == null || taskSet.Done) {
this.Close();
this.Dispose();
}
}
void CancelButtonClick(object sender, EventArgs e)
{
if (InvokeRequired) {
Invoke(new EventHandler(CancelButtonClickConcrete), sender, e);
} else {
CancelButtonClickConcrete(sender,e);
}
}
void CancelButtonClickConcrete(object sender, EventArgs e)
{
if (taskSet != null && taskSet.Running && taskSet.Cancelable) {
cancelButton.Enabled = false;
NativeMethods.ProgressBar_SetState(progressBar, 3); // VistaProgress色:中断
taskSet.Cancel();
}
}
void ExecutionProgressViewerShown(object sender, EventArgs e)
{
this.BringToFront();
}
}
}