public static void DumpTAHEntries(Stream source) { TAHFile tah = new TAHFile(source); try { tah.LoadEntries(); } catch (Exception ex) { Console.WriteLine("Error: " + ex); return; } foreach (TAHEntry ent in tah.EntrySet.Entries) { if (ent.FileName != null && Path.GetExtension(ent.FileName).ToLower() == ".tso") { byte[] data = TAHUtil.ReadEntryData(tah.Reader, ent); byte[] hash = md5.ComputeHash(data); StringBuilder sb = new StringBuilder(); foreach (byte b in hash) { sb.Append(b.ToString("x2")); } string md5sum = sb.ToString(); Console.WriteLine("{0} {1}", md5sum, ent.FileName); } } }
public static TAHEntry Load(BinaryReader br, TAHFile file) { TAHEntry h = new TAHEntry(); h.Read(br, file); return(h); }
public void DumpTAHEntries(Stream source) { TAHFile tah = new TAHFile(source); try { tah.LoadEntries(); } catch (Exception ex) { Console.WriteLine("Error: " + ex); return; } foreach (TAHEntry ent in tah.EntrySet.Entries) { if (Path.GetExtension(ent.FileName) == ".tso") { Console.WriteLine(ent.FileName); byte[] data = TAHUtil.ReadEntryData(tah.Reader, ent); using (MemoryStream ms = new MemoryStream(data)) LoadTSOFile(ms); current_TSOFileName = ent.FileName; AssignCurrentTMOFile(current_TSOFileName); { FrameMove(); Render(); SaveToBitmap(); ClearFigureList(); Application.DoEvents(); } current_TSOFileName = null; } } }
public static TAHDirectories Load(BinaryReader br, TAHFile file) { TAHDirectories dir = new TAHDirectories(); dir.Read(br, file); return(dir); }
public static TAHEntrySet Load(BinaryReader br, TAHFile file) { TAHEntrySet es = new TAHEntrySet(); es.Read(br, file); return(es); }
public void Read(BinaryReader br, TAHFile file) { Hash = br.ReadUInt32(); FileName = FindExternalFileName(Hash); DataOffset = br.ReadUInt32(); Owner = file; }
public void Read(BinaryReader br, TAHFile file) { Entries = new List <TAHEntry>(file.Header.NumEntries); EntryMap = new Dictionary <uint, TAHEntry>(); for (int i = 0, n = file.Header.NumEntries; i < n; ++i) { TAHEntry e = TAHEntry.Load(br, file); if (i != 0) { TailEntry.Length = (int)(e.DataOffset - TailEntry.DataOffset); } //Console.WriteLine(e.ToString()); Entries.Add(e); if (EntryMap.ContainsKey(e.Hash)) { Console.WriteLine("Error: delect hashkey collision. " + e.Hash.ToString("X8") + ": " + e.DataOffset.ToString()); } else { EntryMap.Add(e.Hash, e); } } TailEntry.Length = (int)(br.BaseStream.Length - TailEntry.DataOffset); }
public void Read(BinaryReader br, TAHFile file) { Entries = new List <TAHEntry>(file.Header.NumEntries); EntryMap = new Dictionary <uint, TAHEntry>(); for (int i = 0, n = file.Header.NumEntries; i < n; ++i) { TAHEntry e = TAHEntry.Load(br, file); if (i != 0) { TailEntry.Length = (int)(e.DataOffset - TailEntry.DataOffset); } Entries.Add(e); EntryMap.Add(e.Hash, e); } TailEntry.Length = (int)(br.BaseStream.Length - TailEntry.DataOffset); }
public void Read(BinaryReader br, TAHFile file) { // ディレクトリデータの読み込み Files = new List <string>(file.Header.NumEntries); int output_length = br.ReadInt32(); int input_length = (int)(file.EntrySet[0].DataOffset - br.BaseStream.Position); //- 16 - 8 * file.Header.NumEntries; byte[] input = br.ReadBytes(input_length); byte[] output = new byte[output_length]; if (output.Length == 0) { return; } TAHUtil.Decrypt(input, output); //TAHdecrypt.Decrypter.decrypt(ref input, (uint)input.Length, ref output, (uint)output.Length); MemoryStream ms = new MemoryStream(output); BinaryReader br2 = new BinaryReader(ms); try { string dir = ""; while (ms.Position < ms.Length) { string name = TAHUtil.ReadString(br2); if (name.Length == 0) { } else if (name.EndsWith("/")) { dir = name; //DbgPrint("Directory: " + dir); } else { name = dir + name; uint hash = TAHUtil.CalcHash(name); TAHEntry ent; //DbgPrint(hash.ToString("X").PadLeft(8, '0')); if (file.EntrySet.TryGetValue(hash, out ent)) { ent.FileName = name; //DbgPrint(": Found: " + file); } else { //DbgPrint(": Not Found: " + file); System.Diagnostics.Debug.Assert(false); } //EntryMap[hash].FileName = FileName; } Files.Add(name); } } catch (EndOfStreamException) { } }
public void Read(BinaryReader br, TAHFile file) { Hash = br.ReadUInt32(); DataOffset = br.ReadUInt32(); Owner = file; }