private static void Extract(string fileName) { sceModule sceModule = new sceModule(fileName); if (!sceModule.isHaveText()) { return; } string path = !(Path.GetDirectoryName(fileName) != "") ? Environment.CurrentDirectory + "\\" + Path.GetFileNameWithoutExtension(fileName) + ".txt" : Path.GetDirectoryName(fileName) + "\\" + Path.GetFileNameWithoutExtension(fileName) + ".txt"; Console.WriteLine(string.Format("Extracting {0}...", Path.GetFileName(fileName))); if (jpcodes == null || dumpRaw) { ExtractRaw(fileName, sceModule); return; } if (dumpCount) { ExtractCount(fileName, sceModule); return; } if (codes == null) { MiscUtils.Warn("No CODES.txt file! Special sequences will be ignored, output can get messy!"); } List <string> stringList = new List <string>(); for (int idx = 0; idx < sceModule.Count; ++idx) { string str = sceModule.GetStringBlock(idx); if (codes != null) { str = codes.ConvertNativeToTags(str); } if (jpcodes != null) { str = jpcodes.ConvertAtoB(str); } stringList.Add(HexToAnsi(str)); stringList.Add("[ENDBLOCK]"); } if (useSJIS) { File.WriteAllLines(path, stringList.ToArray(), SJIS); } else { File.WriteAllLines(path, stringList.ToArray()); } }
private static void Extract(string fileName) { sceModule sceModule = new sceModule(fileName); if (!sceModule.isHaveText()) { return; } string path = !(Path.GetDirectoryName(fileName) != "") ? Environment.CurrentDirectory + "\\" + Path.GetFileNameWithoutExtension(fileName) + ".txt" : Path.GetDirectoryName(fileName) + "\\" + Path.GetFileNameWithoutExtension(fileName) + ".txt"; string pathCount = !(Path.GetDirectoryName(fileName) != "") ? Environment.CurrentDirectory + "\\" + Path.GetFileNameWithoutExtension(fileName) + "_count.txt" : Path.GetDirectoryName(fileName) + "\\" + Path.GetFileNameWithoutExtension(fileName) + "_count.txt"; Console.WriteLine(string.Format("Extracting {0}...", Path.GetFileName(fileName))); if (jpcodes == null) { Console.WriteLine("No JPCODES.txt file! Dumping raw bytes..."); } if (jpcodes == null || dumpRaw || dumpCount) { List <byte> dump = new List <byte>(); List <string> byteInfo = new List <string>(); int total = 0; bool switch1 = true; for (int idx = 0; idx < sceModule.Count - 1; ++idx) { if (dumpCount) { total += sceModule.GetBlock(idx).Length; if (total > 0xFFF && switch1) { byteInfo.Add("-----------CUT POINT-----------------------"); byteInfo.Add("| length average: " + (total / idx + 1)); byteInfo.Add("-----------CUT POINT-----------------------"); switch1 = false; } byteInfo.Add("Block: " + String.Format("{0:D3}", idx) + " | Line length: " + String.Format("{0:D3}", sceModule.GetBlock(idx).Length) + " total length: " + String.Format("{0:D4}", total)); } else { dump.AddRange(sceModule.GetBlock(idx)); dump.Add(0x0D); dump.Add(0x0A); dump.AddRange(Encoding.ASCII.GetBytes("[ENDBLOCK]")); dump.Add(0x0D); dump.Add(0x0A); } } if (dumpCount) { File.WriteAllLines(pathCount, byteInfo.ToArray()); } else { File.WriteAllBytes(path, dump.ToArray()); } return; } List <string> stringList = new List <string>(); for (int idx = 0; idx < sceModule.Count; ++idx) { string str = sceModule.GetStringBlock(idx); if (codes != null) { str = codes.ConvertNativeToTags(str); } else { Console.WriteLine("No CODES.txt file! Special sequences will be ignored, output can get messy!"); } if (jpcodes != null) { str = jpcodes.ConvertAtoB(str); } stringList.Add(HexToAnsi(str)); stringList.Add("[ENDBLOCK]"); } if (useSJIS) { File.WriteAllLines(path, stringList.ToArray(), SJIS); } else { File.WriteAllLines(path, stringList.ToArray()); } }