mirror of
https://github.com/TheShadowEevee/libWiiSharp.git
synced 2025-01-11 15:38:51 -06:00
Updates
This commit is contained in:
parent
25a7878313
commit
894dbce4ab
4 changed files with 93 additions and 44 deletions
68
Lz77.cs
68
Lz77.cs
|
@ -27,26 +27,45 @@ namespace libWiiSharp
|
||||||
//private const int F = 18;
|
//private const int F = 18;
|
||||||
//private const int threshold = 2;
|
//private const int threshold = 2;
|
||||||
private static readonly uint lz77Magic = 1280980791;
|
private static readonly uint lz77Magic = 1280980791;
|
||||||
//private readonly int[] leftSon = new int[4097];
|
private readonly int[] leftSon = new int[4097];
|
||||||
//private readonly int[] rightSon = new int[4353];
|
private readonly int[] rightSon = new int[4353];
|
||||||
//private readonly int[] dad = new int[4097];
|
private readonly int[] dad = new int[4097];
|
||||||
private readonly ushort[] textBuffer = new ushort[4113];
|
private readonly ushort[] textBuffer = new ushort[4113];
|
||||||
//private int matchPosition;
|
private int matchPosition;
|
||||||
//private int matchLength;
|
private int matchLength;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Lz77 Magic.
|
||||||
|
/// </summary>
|
||||||
public static uint Lz77Magic => lz77Magic;
|
public static uint Lz77Magic => lz77Magic;
|
||||||
|
|
||||||
|
#region Public Functions
|
||||||
|
/// <summary>
|
||||||
|
/// Checks whether a file is Lz77 compressed or not.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="file"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public static bool IsLz77Compressed(string file)
|
public static bool IsLz77Compressed(string file)
|
||||||
{
|
{
|
||||||
return IsLz77Compressed(File.ReadAllBytes(file));
|
return IsLz77Compressed(File.ReadAllBytes(file));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Checks whether a file is Lz77 compressed or not.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="file"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public static bool IsLz77Compressed(byte[] file)
|
public static bool IsLz77Compressed(byte[] file)
|
||||||
{
|
{
|
||||||
Headers.HeaderType headerType = Headers.DetectHeader(file);
|
Headers.HeaderType headerType = Headers.DetectHeader(file);
|
||||||
return (int)Shared.Swap(BitConverter.ToUInt32(file, (int)headerType)) == (int)lz77Magic;
|
return (int)Shared.Swap(BitConverter.ToUInt32(file, (int)headerType)) == (int)lz77Magic;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Checks whether a file is Lz77 compressed or not.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="file"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public static bool IsLz77Compressed(Stream file)
|
public static bool IsLz77Compressed(Stream file)
|
||||||
{
|
{
|
||||||
Headers.HeaderType headerType = Headers.DetectHeader(file);
|
Headers.HeaderType headerType = Headers.DetectHeader(file);
|
||||||
|
@ -56,12 +75,17 @@ namespace libWiiSharp
|
||||||
return (int)Shared.Swap(BitConverter.ToUInt32(buffer, 0)) == (int)lz77Magic;
|
return (int)Shared.Swap(BitConverter.ToUInt32(buffer, 0)) == (int)lz77Magic;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Compresses a file using the Lz77 algorithm.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="inFile"></param>
|
||||||
|
/// <param name="outFile"></param>
|
||||||
public void Compress(string inFile, string outFile)
|
public void Compress(string inFile, string outFile)
|
||||||
{
|
{
|
||||||
Stream stream = null;
|
Stream stream = null;
|
||||||
using (FileStream fileStream = new FileStream(inFile, FileMode.Open))
|
using (FileStream fileStream = new FileStream(inFile, FileMode.Open))
|
||||||
{
|
{
|
||||||
stream = Compress(fileStream);
|
stream = PrivCompress(fileStream);
|
||||||
}
|
}
|
||||||
|
|
||||||
byte[] buffer = new byte[stream.Length];
|
byte[] buffer = new byte[stream.Length];
|
||||||
|
@ -77,22 +101,37 @@ namespace libWiiSharp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Compresses the byte array using the Lz77 algorithm.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="file"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public byte[] Compress(byte[] file)
|
public byte[] Compress(byte[] file)
|
||||||
{
|
{
|
||||||
return ((MemoryStream)Compress(new MemoryStream(file))).ToArray();
|
return ((MemoryStream)PrivCompress(new MemoryStream(file))).ToArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Compresses the stream using the Lz77 algorithm.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="file"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public Stream Compress(Stream file)
|
public Stream Compress(Stream file)
|
||||||
{
|
{
|
||||||
return Compress(file);
|
return PrivCompress(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Decompresses a file using the Lz77 algorithm.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="inFile"></param>
|
||||||
|
/// <param name="outFile"></param>
|
||||||
public void Decompress(string inFile, string outFile)
|
public void Decompress(string inFile, string outFile)
|
||||||
{
|
{
|
||||||
Stream stream = null;
|
Stream stream = null;
|
||||||
using (FileStream fileStream = new FileStream(inFile, FileMode.Open))
|
using (FileStream fileStream = new FileStream(inFile, FileMode.Open))
|
||||||
{
|
{
|
||||||
stream = Decompress(fileStream);
|
stream = PrivDecompress(fileStream);
|
||||||
}
|
}
|
||||||
|
|
||||||
byte[] buffer = new byte[stream.Length];
|
byte[] buffer = new byte[stream.Length];
|
||||||
|
@ -108,6 +147,11 @@ namespace libWiiSharp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Decompresses the byte array using the Lz77 algorithm.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="file"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public byte[] Decompress(byte[] file)
|
public byte[] Decompress(byte[] file)
|
||||||
{
|
{
|
||||||
return ((MemoryStream)PrivDecompress(new MemoryStream(file))).ToArray();
|
return ((MemoryStream)PrivDecompress(new MemoryStream(file))).ToArray();
|
||||||
|
@ -117,7 +161,9 @@ namespace libWiiSharp
|
||||||
{
|
{
|
||||||
return PrivDecompress(file);
|
return PrivDecompress(file);
|
||||||
}
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Private Functions
|
||||||
private Stream PrivDecompress(Stream inFile)
|
private Stream PrivDecompress(Stream inFile)
|
||||||
{
|
{
|
||||||
if (!IsLz77Compressed(inFile))
|
if (!IsLz77Compressed(inFile))
|
||||||
|
@ -224,7 +270,7 @@ namespace libWiiSharp
|
||||||
label_24:
|
label_24:
|
||||||
return memoryStream;
|
return memoryStream;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
private Stream PrivCompress(Stream inFile)
|
private Stream PrivCompress(Stream inFile)
|
||||||
{
|
{
|
||||||
if (Lz77.IsLz77Compressed(inFile))
|
if (Lz77.IsLz77Compressed(inFile))
|
||||||
|
@ -415,6 +461,6 @@ namespace libWiiSharp
|
||||||
this.leftSon[this.dad[p]] = index;
|
this.leftSon[this.dad[p]] = index;
|
||||||
this.dad[p] = 4096;
|
this.dad[p] = 4096;
|
||||||
}
|
}
|
||||||
*/
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
38
NusClient.cs
38
NusClient.cs
|
@ -25,6 +25,14 @@ using System.Security.Cryptography;
|
||||||
|
|
||||||
namespace libWiiSharp
|
namespace libWiiSharp
|
||||||
{
|
{
|
||||||
|
public enum StoreType
|
||||||
|
{
|
||||||
|
EncryptedContent,
|
||||||
|
DecryptedContent,
|
||||||
|
WAD,
|
||||||
|
All,
|
||||||
|
}
|
||||||
|
|
||||||
public class NusClient : IDisposable
|
public class NusClient : IDisposable
|
||||||
{
|
{
|
||||||
private const string nusUrl = "http://nus.cdn.shop.wii.com/ccs/download/";
|
private const string nusUrl = "http://nus.cdn.shop.wii.com/ccs/download/";
|
||||||
|
@ -33,12 +41,18 @@ namespace libWiiSharp
|
||||||
private bool continueWithoutTicket;
|
private bool continueWithoutTicket;
|
||||||
private bool isDisposed;
|
private bool isDisposed;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// If true, existing local files will be used.
|
||||||
|
/// </summary>
|
||||||
public bool UseLocalFiles
|
public bool UseLocalFiles
|
||||||
{
|
{
|
||||||
get => useLocalFiles;
|
get => useLocalFiles;
|
||||||
set => useLocalFiles = value;
|
set => useLocalFiles = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// If true, the download will be continued even if no ticket for the title is avaiable (WAD packaging and decryption are disabled).
|
||||||
|
/// </summary>
|
||||||
public bool ContinueWithoutTicket
|
public bool ContinueWithoutTicket
|
||||||
{
|
{
|
||||||
get => continueWithoutTicket;
|
get => continueWithoutTicket;
|
||||||
|
@ -165,11 +179,19 @@ namespace libWiiSharp
|
||||||
FireDebug(" Content ID {0} wasn't found in TMD...", (object)contentId);
|
FireDebug(" Content ID {0} wasn't found in TMD...", (object)contentId);
|
||||||
throw new Exception("Content ID wasn't found in the TMD!");
|
throw new Exception("Content ID wasn't found in the TMD!");
|
||||||
}
|
}
|
||||||
if (!File.Exists("cetk"))
|
if (!File.Exists("cetk") && !continueWithoutTicket)
|
||||||
{
|
{
|
||||||
FireDebug(" Downloading Ticket...");
|
FireDebug(" Downloading Ticket...");
|
||||||
//byte[] tikArray = wcNus.DownloadData(str2 + "cetk");
|
|
||||||
Console.WriteLine("Downloading");
|
Console.WriteLine("Downloading");
|
||||||
|
try
|
||||||
|
{
|
||||||
|
byte[] tikArray = wcNus.DownloadData(str2 + "cetk");
|
||||||
|
}
|
||||||
|
catch(Exception ex)
|
||||||
|
{
|
||||||
|
FireDebug(" Downloading Ticket Failed...");
|
||||||
|
throw new Exception("CETK Doesn't Exist and Downloading Ticket Failed:\n" + ex.Message);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Console.WriteLine("Continuing");
|
Console.WriteLine("Continuing");
|
||||||
FireDebug("Parsing Ticket...");
|
FireDebug("Parsing Ticket...");
|
||||||
|
@ -257,6 +279,12 @@ namespace libWiiSharp
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (ContinueWithoutTicket == true)
|
||||||
|
{
|
||||||
|
flag2 = false;
|
||||||
|
flag1 = true;
|
||||||
|
flag3 = false;
|
||||||
|
}
|
||||||
FireDebug(" Checking for Internet connection...");
|
FireDebug(" Checking for Internet connection...");
|
||||||
if (!CheckInet())
|
if (!CheckInet())
|
||||||
{
|
{
|
||||||
|
@ -317,7 +345,8 @@ namespace libWiiSharp
|
||||||
|
|
||||||
FireDebug(" -> {0} Contents", (object)tmd.NumOfContents);
|
FireDebug(" -> {0} Contents", (object)tmd.NumOfContents);
|
||||||
FireDebug(" Parsing Ticket...");
|
FireDebug(" Parsing Ticket...");
|
||||||
Ticket tik = Ticket.Load(outputDir + "cetk");
|
Ticket tik = null;
|
||||||
|
if (!continueWithoutTicket) { tik = Ticket.Load(outputDir + "cetk"); }
|
||||||
string[] strArray1 = new string[tmd.NumOfContents];
|
string[] strArray1 = new string[tmd.NumOfContents];
|
||||||
uint contentId;
|
uint contentId;
|
||||||
for (int index1 = 0; index1 < tmd.NumOfContents; ++index1)
|
for (int index1 = 0; index1 < tmd.NumOfContents; ++index1)
|
||||||
|
@ -427,8 +456,11 @@ namespace libWiiSharp
|
||||||
{
|
{
|
||||||
FireDebug(" Deleting TMD and Ticket...");
|
FireDebug(" Deleting TMD and Ticket...");
|
||||||
File.Delete(outputDir + str2);
|
File.Delete(outputDir + str2);
|
||||||
|
if (ContinueWithoutTicket == false)
|
||||||
|
{
|
||||||
File.Delete(outputDir + "cetk");
|
File.Delete(outputDir + "cetk");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
FireDebug("Downloading Title {0} v{1} Finished...", titleId, string.IsNullOrEmpty(titleVersion) ? "[Latest]" : titleVersion);
|
FireDebug("Downloading Title {0} v{1} Finished...", titleId, string.IsNullOrEmpty(titleVersion) ? "[Latest]" : titleVersion);
|
||||||
FireProgress(100);
|
FireProgress(100);
|
||||||
}
|
}
|
||||||
|
|
28
StoreType.cs
28
StoreType.cs
|
@ -1,28 +0,0 @@
|
||||||
/* This file is part of libWiiSharp
|
|
||||||
* Copyright (C) 2009 Leathl
|
|
||||||
* Copyright (C) 2020 - 2021 Github Contributors
|
|
||||||
*
|
|
||||||
* libWiiSharp 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.
|
|
||||||
*
|
|
||||||
* libWiiSharp 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace libWiiSharp
|
|
||||||
{
|
|
||||||
public enum StoreType
|
|
||||||
{
|
|
||||||
EncryptedContent,
|
|
||||||
DecryptedContent,
|
|
||||||
WAD,
|
|
||||||
All,
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -60,7 +60,6 @@
|
||||||
<Compile Include="MessageEventArgs.cs" />
|
<Compile Include="MessageEventArgs.cs" />
|
||||||
<Compile Include="NusClient.cs" />
|
<Compile Include="NusClient.cs" />
|
||||||
<Compile Include="Shared.cs" />
|
<Compile Include="Shared.cs" />
|
||||||
<Compile Include="StoreType.cs" />
|
|
||||||
<Compile Include="Ticket.cs" />
|
<Compile Include="Ticket.cs" />
|
||||||
<Compile Include="TMD.cs" />
|
<Compile Include="TMD.cs" />
|
||||||
<Compile Include="TPL.cs" />
|
<Compile Include="TPL.cs" />
|
||||||
|
|
Loading…
Reference in a new issue