From a147e64b79e21dab7732a94d47984ba02df22b12 Mon Sep 17 00:00:00 2001 From: TheShadowEevee Date: Mon, 21 Mar 2022 21:51:14 -0500 Subject: [PATCH] Add IDE Annotaions to NusClient.cs --- NusClient.cs | 116 ++++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 101 insertions(+), 15 deletions(-) diff --git a/NusClient.cs b/NusClient.cs index 595af58..a278d1d 100644 --- a/NusClient.cs +++ b/NusClient.cs @@ -62,11 +62,8 @@ namespace libWiiSharp get => continueWithoutTicket; set => continueWithoutTicket = value; } - - public event EventHandler Progress; - - public event EventHandler Debug; - + + #region IDisposable Members ~NusClient() => Dispose(false); public void Dispose() @@ -84,7 +81,17 @@ namespace libWiiSharp isDisposed = true; } + #endregion + #region Public Functions + /// + /// Grabs a title from NUS, you can define several store types. + /// Leave the title version empty for the latest. + /// + /// + /// + /// + /// public void DownloadTitle(string titleId, string titleVersion, string outputDir, params StoreType[] storeTypes) { if (titleId.Length != 16) @@ -96,6 +103,16 @@ namespace libWiiSharp PrivDownloadTitle(titleId, titleVersion, outputDir, storeTypes); } + /// + /// Grabs a title from NUS, you can define several store types. + /// Leave the title version empty for the latest. + /// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/" + /// + /// + /// + /// + /// + /// public void DownloadTitle(string titleId, string titleVersion, string outputDir, string nusUrl, params StoreType[] storeTypes) { if (titleId.Length != 16) @@ -107,30 +124,66 @@ namespace libWiiSharp PrivDownloadTitle(titleId, titleVersion, outputDir, nusUrl, storeTypes); } + /// + /// Grabs a TMD from NUS. + /// Leave the title version empty for the latest. + /// + /// + /// + /// public TMD DownloadTMD(string titleId, string titleVersion) { if (isStopRequired) return null; return titleId.Length == 16 ? PrivDownloadTmd(titleId, titleVersion) : throw new Exception("Title ID must be 16 characters long!"); } + /// + /// Grabs a TMD from NUS. + /// Leave the title version empty for the latest. + /// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/" + /// + /// + /// + /// + /// public TMD DownloadTMD(string titleId, string titleVersion, string nusUrl) { if (isStopRequired) return null; return titleId.Length == 16 ? PrivDownloadTmd(titleId, titleVersion, nusUrl) : throw new Exception("Title ID must be 16 characters long!"); } + /// + /// Grabs a Ticket from NUS. + /// + /// + /// public Ticket DownloadTicket(string titleId) { if (isStopRequired) return null; return titleId.Length == 16 ? PrivDownloadTicket(titleId) : throw new Exception("Title ID must be 16 characters long!"); } + /// + /// Grabs a Ticket from NUS. + /// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/" + /// + /// + /// + /// public Ticket DownloadTicket(string titleId, string nusUrl) { if (isStopRequired) return null; return titleId.Length == 16 ? PrivDownloadTicket(titleId, nusUrl) : throw new Exception("Title ID must be 16 characters long!"); } + /// + /// Grabs a single content file and decrypts it. + /// Leave the title version empty for the latest. + /// + /// + /// + /// + /// public byte[] DownloadSingleContent(string titleId, string titleVersion, string contentId) { if (isStopRequired) return null; @@ -142,6 +195,14 @@ namespace libWiiSharp return PrivDownloadSingleContent(titleId, titleVersion, contentId); } + /// + /// Grabs a single content file and decrypts it. + /// Leave the title version empty for the latest. + /// + /// + /// + /// + /// public void DownloadSingleContent(string titleId, string titleVersion, string contentId, string savePath) { if (titleId.Length != 16) @@ -163,6 +224,16 @@ namespace libWiiSharp File.WriteAllBytes(savePath, bytes); } + /// + /// Grabs a single content file and decrypts it. + /// Leave the title version empty for the latest. + /// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/" + /// + /// + /// + /// + /// + /// public void DownloadSingleContent(string titleId, string titleVersion, string contentId, string savePath, string nusUrl) { if (titleId.Length != 16) @@ -183,7 +254,9 @@ namespace libWiiSharp byte[] bytes = PrivDownloadSingleContent(titleId, titleVersion, contentId, nusUrl); File.WriteAllBytes(savePath, bytes); } + #endregion + #region Private Functions private byte[] PrivDownloadSingleContent(string titleId, string titleVersion, string contentId) { uint num = uint.Parse(contentId, NumberStyles.HexNumber); @@ -952,6 +1025,28 @@ namespace libWiiSharp return false; } } + #endregion + + #region Events + /// + /// Fires the Progress of various operations + /// + public event EventHandler Progress; + /// + /// Fires debugging messages. You may write them into a log file or log textbox. + /// + public event EventHandler Debug; + + private void FireProgress(int progressPercentage) + { + EventHandler progress = Progress; + if (progress == null) + { + return; + } + + progress(new object(), new ProgressChangedEventArgs(progressPercentage, string.Empty)); + } private void FireDebug(string debugMessage, params object[] args) { @@ -964,15 +1059,6 @@ namespace libWiiSharp debug(new object(), new MessageEventArgs(string.Format(debugMessage, args))); } - private void FireProgress(int progressPercentage) - { - EventHandler progress = Progress; - if (progress == null) - { - return; - } - - progress(new object(), new ProgressChangedEventArgs(progressPercentage, string.Empty)); - } + #endregion } }