mirror of
https://github.com/TheShadowEevee/Sharpii-NetCore.git
synced 2025-01-11 14:58:51 -06:00
699 lines
No EOL
31 KiB
C#
699 lines
No EOL
31 KiB
C#
/* This file is part of Sharpii.
|
|
* Copyright (C) 2013 Person66
|
|
* Copyright (C) 2020 Sharpii-NetCore Contributors
|
|
*
|
|
* Sharpii is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Sharpii is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with Sharpii. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
using System;
|
|
using System.IO;
|
|
using System.Collections.Generic;
|
|
using libWiiSharp;
|
|
|
|
namespace Sharpii
|
|
{
|
|
partial class NUS_Stuff
|
|
{
|
|
public static int ExceptionListRan = 0;
|
|
public static void NUS(string[] args)
|
|
{
|
|
if (args.Length < 2)
|
|
{
|
|
NUS_help();
|
|
return;
|
|
}
|
|
if (args[1].ToUpper() == "-H" || args[1].ToUpper() == "-HELP")
|
|
{
|
|
NUS_help();
|
|
return;
|
|
}
|
|
|
|
//Set up variables
|
|
string id = "";
|
|
string url = "";
|
|
string content = "";
|
|
string version = "";
|
|
int intver = -1;
|
|
string output = "";
|
|
bool local = false;
|
|
List<StoreType> store = new List<StoreType>();
|
|
bool entered = false;
|
|
bool wad = false;
|
|
bool NoOut = false;
|
|
string ios = "";
|
|
string temp = Path.GetTempPath() + "Sharpii.tmp";
|
|
bool ContinueWithoutTicket = false;
|
|
|
|
//Get arguments
|
|
for (int i = 1; i < args.Length; i++)
|
|
{
|
|
switch (args[i].ToUpper())
|
|
{
|
|
case "-ALL":
|
|
store.Add(StoreType.All);
|
|
entered = true;
|
|
break;
|
|
case "-WAD":
|
|
store.Add(StoreType.WAD);
|
|
entered = true;
|
|
break;
|
|
case "-ENCRYPT":
|
|
store.Add(StoreType.EncryptedContent);
|
|
entered = true;
|
|
break;
|
|
case "-ENCRYPTED":
|
|
store.Add(StoreType.EncryptedContent);
|
|
entered = true;
|
|
break;
|
|
case "-DECRYPT":
|
|
store.Add(StoreType.DecryptedContent);
|
|
entered = true;
|
|
break;
|
|
case "-DECRYPTED":
|
|
store.Add(StoreType.DecryptedContent);
|
|
entered = true;
|
|
break;
|
|
case "-LOCAL":
|
|
local = true;
|
|
break;
|
|
case "-V":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No version set");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_VERSION");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8B);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000000D);
|
|
}
|
|
return;
|
|
}
|
|
version = args[i + 1];
|
|
if (version.ToUpper() == "LATEST")
|
|
break;
|
|
if (!int.TryParse(version, out intver))
|
|
{
|
|
Console.WriteLine("Invalid version {0}...", args[i + 1]);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_INVALID_VERSION");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8C);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000000E);
|
|
}
|
|
return;
|
|
}
|
|
if (intver < 0 || intver > 65535)
|
|
{
|
|
Console.WriteLine("Invalid version {0}...", version);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_INVALID_VERSION");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8C);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000000E);
|
|
}
|
|
return;
|
|
}
|
|
break;
|
|
case "-VERSION":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No version set");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_VERSION");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8B);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000000D);
|
|
}
|
|
return;
|
|
}
|
|
version = args[i + 1];
|
|
if (version.ToUpper() == "LATEST")
|
|
break;
|
|
if (!int.TryParse(version, out intver))
|
|
{
|
|
Console.WriteLine("Invalid version {0}...", args[i + 1]);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_INVALID_VERSION");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8C);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000000E);
|
|
}
|
|
return;
|
|
}
|
|
if (intver < 0 || intver > 65535)
|
|
{
|
|
Console.WriteLine("Invalid version {0}...", version);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_INVALID_VERSION");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8C);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000000E);
|
|
}
|
|
return;
|
|
}
|
|
break;
|
|
case "-O":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No output set");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_OUTPUT");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8D);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000000F);
|
|
}
|
|
return;
|
|
}
|
|
output = args[i + 1];
|
|
break;
|
|
case "-ID":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No ID specified");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_ID");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8E);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000010);
|
|
}
|
|
return;
|
|
}
|
|
id = args[i + 1];
|
|
id = id.ToUpper();
|
|
break;
|
|
case "-URL":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No URL specified");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_URL");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8E);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000010);
|
|
}
|
|
return;
|
|
}
|
|
url = args[i + 1];
|
|
break;
|
|
case "-IOS":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No IOS specified");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_IOS");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E86);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000008);
|
|
}
|
|
return;
|
|
}
|
|
id = "00000001000000" + Convert.ToInt32(args[i + 1]).ToString("X2");
|
|
break;
|
|
case "-SINGLE":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No ID specified");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_ID");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8E);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000010);
|
|
}
|
|
return;
|
|
}
|
|
content = args[i + 1];
|
|
break;
|
|
case "-S":
|
|
if (i + 1 >= args.Length)
|
|
{
|
|
Console.WriteLine("ERROR: No ID specified");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_ID");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8E);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000010);
|
|
}
|
|
return;
|
|
}
|
|
content = args[i + 1];
|
|
break;
|
|
}
|
|
}
|
|
|
|
//Error checking & stuff
|
|
if (id == "")
|
|
{
|
|
Console.WriteLine("ERROR: No ID specified");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_NO_ID");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E8E);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000010);
|
|
}
|
|
return;
|
|
}
|
|
|
|
if (version == "")
|
|
{
|
|
if (BeQuiet.quiet > 2)
|
|
Console.WriteLine("No version specified, using latest", version);
|
|
version = "LATEST";
|
|
}
|
|
|
|
try
|
|
{
|
|
if (version.ToUpper() == "LATEST")
|
|
{
|
|
//Grab the TMD and get the latest version
|
|
NusClient grabtmd = new NusClient();
|
|
TMD tmd = grabtmd.DownloadTMD(id, "");
|
|
version = tmd.TitleVersion.ToString();
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
if (ex.Message == "Title ID must be 16 characters long!")
|
|
{
|
|
Console.WriteLine("");
|
|
Console.WriteLine("The ID needs to be 16 Characters.");
|
|
Console.WriteLine("");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_BAD_ID");
|
|
Console.WriteLine("");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E9C);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000001E);
|
|
}
|
|
return;
|
|
}
|
|
if (ex.Message.Contains("The remote server returned an error:"))
|
|
{
|
|
Console.WriteLine("The remote server returned an HTTP error. Check your Title ID.");
|
|
Console.WriteLine("");
|
|
Console.WriteLine("ERROR DETAILS: {0}", ex.Message);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_SERVER_ERROR");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E9E);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000020);
|
|
}
|
|
return;
|
|
}
|
|
if (ExceptionListRan == 0)
|
|
{
|
|
Console.WriteLine("An unknown error occured, please try again");
|
|
Console.WriteLine("");
|
|
Console.WriteLine("ERROR DETAILS: {0}", ex.Message);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_UNKNOWN");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E82);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000004);
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
if (BeQuiet.quiet > 2)
|
|
Console.WriteLine("Found latest version: v{0}", version);
|
|
|
|
if (entered == false) //Will only be false if no store type argument was given
|
|
{
|
|
store.Add(StoreType.All);
|
|
if (BeQuiet.quiet > 2)
|
|
Console.WriteLine("No store type specified, using all");
|
|
}
|
|
|
|
if (id.Length == 16 && Convert.ToInt32(id.Substring(14, 2), 16) >= 3 && Convert.ToInt32(id.Substring(14, 2), 16) <= 255 && id.Substring(0, 14) == "00000001000000")
|
|
ios = "IOS" + Convert.ToInt32(id.Substring(14, 2), 16) + "-64-" + version + ".wad";
|
|
|
|
if ((((output.Length >= 4 && output.Substring(output.Length - 4, 4).ToUpper() == ".WAD") || output == "") && Array.IndexOf(store.ToArray(), StoreType.WAD) != -1 && store.ToArray().Length == 1) || (output == "" && ios != "" && Array.IndexOf(store.ToArray(), StoreType.WAD) != -1 && store.ToArray().Length == 1))
|
|
{
|
|
wad = true;
|
|
if (Directory.Exists(temp) == true)
|
|
DeleteADir.DeleteDirectory(temp);
|
|
|
|
Directory.CreateDirectory(temp);
|
|
}
|
|
|
|
if (output == "")
|
|
{
|
|
NoOut = true;
|
|
output = ios == "" ? id + "v" + version : ios[0..^4];
|
|
if (BeQuiet.quiet > 2)
|
|
Console.WriteLine("No output specified, using {0}", output);
|
|
}
|
|
|
|
//Main part, catches random/unexpected exceptions
|
|
try
|
|
{
|
|
NusClient nus = new NusClient();
|
|
|
|
if (local == true)
|
|
{
|
|
if (BeQuiet.quiet > 2)
|
|
Console.WriteLine("Using local files if present...");
|
|
nus.UseLocalFiles = true;
|
|
}
|
|
|
|
if (ContinueWithoutTicket == true)
|
|
{
|
|
if (BeQuiet.quiet > 2)
|
|
Console.WriteLine("Attempting Download without ticket");
|
|
nus.ContinueWithoutTicket = true;
|
|
}
|
|
|
|
if (content != "")
|
|
{
|
|
if (BeQuiet.quiet > 1)
|
|
Console.Write("Downloading content...");
|
|
|
|
if (url != "") {
|
|
nus.DownloadSingleContent(id, version, content, output, url);
|
|
} else {
|
|
nus.DownloadSingleContent(id, version, content, output);
|
|
}
|
|
|
|
if (BeQuiet.quiet > 1)
|
|
Console.Write("Done!\n");
|
|
}
|
|
else
|
|
{
|
|
if (BeQuiet.quiet > 1)
|
|
Console.Write("Downloading title...\n");
|
|
|
|
string realout = output;
|
|
if (wad == true) {
|
|
output = temp;
|
|
}
|
|
|
|
if (url != "") {
|
|
nus.DownloadTitle(id, version, output, url, store.ToArray());
|
|
} else {
|
|
nus.DownloadTitle(id, version, output, store.ToArray());
|
|
}
|
|
|
|
|
|
WadIosNamingStuff(wad, temp, id, version, ios, NoOut, output, realout);
|
|
|
|
if (BeQuiet.quiet > 1)
|
|
Console.Write("Done!\n");
|
|
}
|
|
|
|
if (BeQuiet.quiet > 1)
|
|
Console.WriteLine("Operation completed succesfully!\n");
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
if (ex.Message == "CETK Doesn't Exist and Downloading Ticket Failed:\nThe remote server returned an error: (404) Not Found.")
|
|
{
|
|
|
|
Console.WriteLine("The remote server returned a 404 error. Check your Title ID.");
|
|
Console.WriteLine("If you have a CETK file, please place it in the same directory as Sharpii saves the NUS Files to.");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_REMOTE_404");
|
|
Console.WriteLine("");
|
|
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E9E);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000020);
|
|
}
|
|
return;
|
|
}
|
|
if (ex.Message == "Title ID must be 16 characters long!")
|
|
{
|
|
Console.WriteLine("");
|
|
Console.WriteLine("The ID needs to be 16 Characters.");
|
|
Console.WriteLine("");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_BAD_ID");
|
|
Console.WriteLine("");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E9C);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x0000001E);
|
|
}
|
|
return;
|
|
}
|
|
if (ex.Message == "ERROR DETAILS: Downloading Content Failed:\nAn exception occurred during a WebClient request.")
|
|
{
|
|
Console.WriteLine("A WebClient Request Error occurred. This usually means that Sharpii can not properly download the file.");
|
|
Console.WriteLine("Please ensure you have the proper permissions.");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_WEBREQUEST_FAIL");
|
|
ExceptionListRan = 1;
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E9F);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000021);
|
|
}
|
|
}
|
|
if (ExceptionListRan == 0)
|
|
{
|
|
Console.WriteLine("An unknown error occured, please try again");
|
|
Console.WriteLine("");
|
|
Console.WriteLine("ERROR DETAILS: {0}", ex.Message);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_UNKNOWN");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E82);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000004);
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
private static void WadIosNamingStuff(bool wad, string temp, string id, string version, string ios, bool NoOut, string output, string realout)
|
|
{
|
|
bool LowercaseWad = false;
|
|
bool OperationDone = false;
|
|
if (wad == true)
|
|
{
|
|
try
|
|
{
|
|
if (!File.Exists(Path.Combine(temp, id + "v" + version + ".wad")))
|
|
{
|
|
LowercaseWad = true;
|
|
try
|
|
{
|
|
if (!File.Exists(Path.Combine(temp, id.ToLower() + "v" + version + ".wad")))
|
|
{
|
|
Console.WriteLine("ERROR: Can't find WAD {0}", id.ToLower());
|
|
Console.WriteLine("Try running without the -WAD or -ALL tag. If it still doesn't work, open an issue on Github.");
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_FILE_ERR");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E81);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000003);
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
catch (Exception ex2)
|
|
{
|
|
Console.WriteLine("ERROR: Can't find WAD {0}", id.ToLower());
|
|
Console.WriteLine("Try running without the -WAD or -ALL tag. If it still doesn't work, open an issue on Github.");
|
|
Console.WriteLine("Exact Error: {0}", ex2.Message);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_FILE_ERR");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E81);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000003);
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
Console.WriteLine("ERROR: Can't find WAD");
|
|
Console.WriteLine("Try running with out the -WAD or -ALL tag. If it still doesn't work, open an issue on Github.");
|
|
Console.WriteLine("Exact Error: {0}", ex.Message);
|
|
Console.WriteLine("Error: SHARPII_NET_CORE_NUSD_FILE_ERR");
|
|
if (OperatingSystem.Windows())
|
|
{
|
|
Environment.Exit(0x00003E81);
|
|
}
|
|
else
|
|
{
|
|
Environment.Exit(0x00000003);
|
|
}
|
|
return;
|
|
}
|
|
if (ios != "" && NoOut == true && LowercaseWad == false)
|
|
{
|
|
int index = realout.LastIndexOf("\\") > realout.LastIndexOf("/") ? realout.LastIndexOf("\\") : realout.LastIndexOf("/");
|
|
if (File.Exists(realout.Substring(0, index + 1) + ios))
|
|
File.Delete(realout.Substring(0, index + 1) + ios);
|
|
File.Move(Path.Combine(temp, id.ToUpper() + "v" + version + ".wad"), realout.Substring(0, index + 1) + ios);
|
|
}
|
|
else if (ios == "" && NoOut == true && LowercaseWad == false)
|
|
{
|
|
if (File.Exists(realout + ".wad"))
|
|
File.Delete(realout + ".wad");
|
|
File.Move(Path.Combine(temp, id.ToUpper() + "v" + version + ".wad"), realout + ".wad");
|
|
}
|
|
else if (LowercaseWad == false && OperationDone == false)
|
|
{
|
|
if (File.Exists(realout))
|
|
File.Delete(realout);
|
|
File.Move(Path.Combine(temp, id.ToUpper() + "v" + version + ".wad"), realout);
|
|
}
|
|
else if (ios != "" && NoOut == true && LowercaseWad == true)
|
|
{
|
|
int index = realout.LastIndexOf("\\") > realout.LastIndexOf("/") ? realout.LastIndexOf("\\") : realout.LastIndexOf("/");
|
|
if (File.Exists(realout.Substring(0, index + 1) + ios))
|
|
File.Delete(realout.Substring(0, index + 1) + ios);
|
|
File.Move(Path.Combine(temp, id.ToLower() + "v" + version + ".wad"), realout.Substring(0, index + 1) + ios);
|
|
}
|
|
else if (ios == "" && NoOut == true && LowercaseWad == true)
|
|
{
|
|
if (File.Exists(realout + ".wad"))
|
|
File.Delete(realout + ".wad");
|
|
File.Move(Path.Combine(temp, id.ToLower() + "v" + version + ".wad"), realout + ".wad");
|
|
}
|
|
else if (LowercaseWad == true && OperationDone == false)
|
|
{
|
|
if (File.Exists(realout))
|
|
File.Delete(realout);
|
|
File.Move(Path.Combine(temp, id.ToLower() + "v" + version + ".wad"), realout);
|
|
}
|
|
DeleteADir.DeleteDirectory(temp);
|
|
}
|
|
else if (ios != "" && LowercaseWad == false)
|
|
{
|
|
if (output.Substring(output.Length - 1, 1) == "\\" || output.Substring(output.Length - 1, 1) == "/")
|
|
output = output.Substring(output.Length - 1, 1);
|
|
if (File.Exists(Path.Combine(output, id.ToUpper() + "v" + version + ".wad")))
|
|
{
|
|
if (File.Exists(Path.Combine(output, ios)))
|
|
File.Delete(Path.Combine(output, ios));
|
|
File.Move(Path.Combine(output, id.ToUpper() + "v" + version + ".wad"), Path.Combine(output, ios));
|
|
}
|
|
}
|
|
else if (ios != "" && LowercaseWad == true)
|
|
{
|
|
if (output.Substring(output.Length - 1, 1) == "\\" || output.Substring(output.Length - 1, 1) == "/")
|
|
output = output.Substring(output.Length - 1, 1);
|
|
if (File.Exists(Path.Combine(output, id.ToLower() + "v" + version + ".wad")))
|
|
{
|
|
if (File.Exists(Path.Combine(output, ios)))
|
|
File.Delete(Path.Combine(output, ios));
|
|
File.Move(Path.Combine(output, id.ToLower() + "v" + version + ".wad"), Path.Combine(output, ios));
|
|
}
|
|
}
|
|
}
|
|
public static void NUS_help()
|
|
{
|
|
Console.WriteLine("");
|
|
Console.WriteLine("Sharpii .Net Core v{0} - Ported and Maintained by TheShadowEevee, originally by person66", ProgramVersion.version);
|
|
Console.WriteLine("Using a modified version of libWiiSharp, originally made by leathl");
|
|
Console.WriteLine("");
|
|
Console.WriteLine("");
|
|
Console.WriteLine(" Usage:");
|
|
Console.WriteLine("");
|
|
Console.WriteLine(" ./Sharpii NUSD [-id titleID | -ios IOS] [-v version] [-o output] [-all]");
|
|
Console.WriteLine(" [-wad] [-decrypt] [-encrypt] [-local] [-s content]");
|
|
Console.WriteLine("");
|
|
Console.WriteLine("");
|
|
Console.WriteLine(" Arguments:");
|
|
Console.WriteLine("");
|
|
Console.WriteLine(" -id titleID [required] The Title ID of the file you wish to download");
|
|
Console.WriteLine(" -v version [required] The version of the file you wish to download");
|
|
Console.WriteLine(" NOTE: Use 'latest' to get the latest version");
|
|
Console.WriteLine(" -ios IOS The IOS you wish to download. This is an alternative to");
|
|
Console.WriteLine(" '-id', use one or the other, but not both.");
|
|
Console.WriteLine(" -o output Folder to output the files to");
|
|
Console.WriteLine(" -local Use local files if present");
|
|
Console.WriteLine(" -s content Download a single content from the file");
|
|
Console.WriteLine(" NOTE: When using this, output MUST have a path and a");
|
|
Console.WriteLine(" filename. For current directory use '.\\[filename]'");
|
|
Console.WriteLine(" -all Create and keep encrypted, decrypted, and WAD versions");
|
|
Console.WriteLine(" of the file you wish to download");
|
|
Console.WriteLine(" -wad Keep only the WAD version of the file you wish to");
|
|
Console.WriteLine(" download");
|
|
Console.WriteLine(" -decrypt Keep only the decrypted contents of the file you wish to");
|
|
Console.WriteLine(" download");
|
|
Console.WriteLine(" -encrypt Keep only the encrypted contents of the file you wish to");
|
|
Console.WriteLine(" download");
|
|
}
|
|
}
|
|
} |