/* frmDownload.cs $\r
- \r
- This file is part of the HandBrake source code.\r
- Homepage: <http://handbrake.fr>.\r
- It may be used under the terms of the GNU General Public License. */\r
-\r
-using System;\r
-using System.Collections.Generic;\r
-using System.Windows.Forms;\r
-using System.Net;\r
-using System.IO;\r
-using System.Threading;\r
-using System.Diagnostics;\r
+ This file is part of the HandBrake source code.\r
+ Homepage: <http://handbrake.fr>.\r
+ It may be used under the terms of the GNU General Public License. */\r
\r
namespace Handbrake\r
{\r
+ using System;\r
+ using System.Diagnostics;\r
+ using System.IO;\r
+ using System.Net;\r
+ using System.Threading;\r
+ using System.Windows.Forms;\r
+\r
+ /// <summary>\r
+ /// The Download Window\r
+ /// </summary>\r
public partial class frmDownload : Form\r
{\r
- private Thread downloadThread;\r
+ private readonly Thread downloadThread;\r
private Stream responceStream;\r
- private Stream loacalStream;\r
+ private Stream localStream;\r
private HttpWebRequest webRequest;\r
private HttpWebResponse webResponse;\r
private static int progress;\r
- private delegate void UpdateProgessCallback(Int64 BytesRead, Int64 TotalBytes);\r
+ private bool killThread;\r
+\r
+ private delegate void UpdateProgessCallback(long bytesRead, long totalBytes);\r
+\r
private delegate void DownloadCompleteCallback();\r
- private delegate void DownloadFailedCallback();\r
\r
- private string file;\r
+ private delegate void DownloadFailedCallback();\r
\r
public frmDownload(string filename)\r
{\r
InitializeComponent();\r
\r
- file = filename;\r
- downloadThread = new Thread(Download);\r
- downloadThread.Start();\r
+ this.downloadThread = new Thread(Download);\r
+ this.downloadThread.Start(filename);\r
}\r
\r
- private void Download()\r
+ private void Download(object file)\r
{\r
string tempPath = Path.Combine(Path.GetTempPath(), "handbrake-setup.exe");\r
- string hbUpdate = file;\r
+ string hbUpdate = (string)file;\r
WebClient wcDownload = new WebClient();\r
\r
try\r
if (File.Exists(tempPath))\r
File.Delete(tempPath);\r
\r
- webRequest = (HttpWebRequest)WebRequest.Create(hbUpdate);\r
- webRequest.Credentials = CredentialCache.DefaultCredentials;\r
- webResponse = (HttpWebResponse)webRequest.GetResponse();\r
- Int64 fileSize = webResponse.ContentLength;\r
+ this.webRequest = (HttpWebRequest)WebRequest.Create(hbUpdate);\r
+ this.webRequest.Credentials = CredentialCache.DefaultCredentials;\r
+ this.webResponse = (HttpWebResponse)this.webRequest.GetResponse();\r
+ long fileSize = this.webResponse.ContentLength;\r
\r
- responceStream = wcDownload.OpenRead(hbUpdate);\r
- loacalStream = new FileStream(tempPath, FileMode.Create, FileAccess.Write, FileShare.None);\r
+ this.responceStream = wcDownload.OpenRead(hbUpdate);\r
+ this.localStream = new FileStream(tempPath, FileMode.Create, FileAccess.Write, FileShare.None);\r
\r
- int bytesSize = 0;\r
+ int bytesSize;\r
byte[] downBuffer = new byte[2048];\r
\r
long flength = 0;\r
- while ((bytesSize = responceStream.Read(downBuffer, 0, downBuffer.Length)) > 0)\r
+ while ((bytesSize = this.responceStream.Read(downBuffer, 0, downBuffer.Length)) > 0)\r
{\r
- loacalStream.Write(downBuffer, 0, bytesSize);\r
- flength = loacalStream.Length;\r
- this.Invoke(new UpdateProgessCallback(this.UpdateProgress), new object[] { loacalStream.Length, fileSize });\r
+ if (this.killThread)\r
+ return;\r
+ this.localStream.Write(downBuffer, 0, bytesSize);\r
+ flength = this.localStream.Length;\r
+ Invoke(new UpdateProgessCallback(this.UpdateProgress), new object[] {this.localStream.Length, fileSize});\r
}\r
\r
- responceStream.Close();\r
- loacalStream.Close();\r
+ this.responceStream.Close();\r
+ this.localStream.Close();\r
\r
if (flength != fileSize)\r
- this.Invoke(new DownloadFailedCallback(this.downloadFailed));\r
+ Invoke(new DownloadFailedCallback(this.DownloadFailed));\r
else\r
- this.Invoke(new DownloadCompleteCallback(this.downloadComplete));\r
+ Invoke(new DownloadCompleteCallback(this.DownloadComplete));\r
}\r
- catch (Exception)\r
+ catch\r
{\r
// Do Nothing \r
}\r
}\r
\r
- private void UpdateProgress(Int64 BytesRead, Int64 TotalBytes)\r
+ private void UpdateProgress(long bytesRead, long totalBytes)\r
{\r
- try\r
- {\r
- long p = (BytesRead * 100) / TotalBytes;\r
- progress = int.Parse(p.ToString());\r
- progress_download.Value = progress;\r
- lblProgress.Text = (BytesRead / 1024) + "k of " + (TotalBytes / 1024) + "k ";\r
- }\r
- catch (Exception exc)\r
- {\r
- MessageBox.Show("Integer Conversion Error On Download \n" + exc.ToString(), "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);\r
- }\r
+ long p = (bytesRead * 100) / totalBytes;\r
+ int.TryParse(p.ToString(), out progress);\r
+ progress_download.Value = progress;\r
+ lblProgress.Text = (bytesRead / 1024) + "k of " + (totalBytes / 1024) + "k ";\r
}\r
\r
- private void downloadComplete()\r
+ private void DownloadComplete()\r
{\r
lblProgress.Text = "Download Complete";\r
btn_cancel.Text = "Close";\r
\r
- string tempPath = Path.Combine(Path.GetTempPath(), "handbrake-setup.exe");\r
-\r
- Process startInstall = Process.Start(tempPath);\r
+ Process.Start(Path.Combine(Path.GetTempPath(), "handbrake-setup.exe"));\r
this.Close();\r
Application.Exit();\r
}\r
\r
- private void downloadFailed()\r
+ private void DownloadFailed()\r
{\r
lblProgress.Text = "Download Failed";\r
btn_cancel.Text = "Close";\r
\r
private void btn_cancel_Click(object sender, EventArgs e)\r
{\r
- try\r
- {\r
- webResponse.Close();\r
- responceStream.Close();\r
- loacalStream.Close();\r
- downloadThread.Abort();\r
- progress_download.Value = 0;\r
- lblProgress.Text = "Download Stopped";\r
- this.Close();\r
- }\r
- catch (Exception)\r
- {\r
- // Do nothing\r
- }\r
+ this.killThread = true;\r
+ lblProgress.Text = "Cancelling ...";\r
+ if (this.webResponse != null) this.webResponse.Close();\r
+ if (this.responceStream != null) this.responceStream.Close();\r
+ if (this.localStream != null) this.localStream.Close();\r
+ this.Close();\r
}\r
}\r
}
\ No newline at end of file