2023-08-26 20:34:51 +08:00
|
|
|
#include <VTAll.hpp>
|
2023-02-14 16:28:37 +08:00
|
|
|
#include "StructFormatter.hpp"
|
|
|
|
#include "AccessibleValue.hpp"
|
|
|
|
#include "TerminalHelper.hpp"
|
|
|
|
|
2023-03-04 00:13:03 +08:00
|
|
|
namespace Unvirt::StructFormatter {
|
|
|
|
|
|
|
|
static FILE* fout = stdout;
|
|
|
|
|
|
|
|
void PrintCKFileInfo(const LibCmo::CK2::CKFileInfo& fileinfo) {
|
|
|
|
|
|
|
|
fputs(UNVIRT_TERMCOL_LIGHT_YELLOW(("CKFileInfo\n")), fout);
|
|
|
|
fprintf(fout, "FileVersion: %" PRIu32 "\n", fileinfo.FileVersion);
|
|
|
|
fprintf(fout, "CKVersion: %02" PRIX32 "/%02" PRIX32 "/%04" PRIX32 "\n",
|
|
|
|
(fileinfo.CKVersion >> 24) & 0xFF,
|
|
|
|
(fileinfo.CKVersion >> 16) & 0xFF,
|
|
|
|
(fileinfo.CKVersion >> 0) & 0xFFFF
|
|
|
|
);
|
|
|
|
|
2023-08-27 16:45:07 +08:00
|
|
|
LibCmo::CK2::CKDWORD product_series[4] {
|
2023-03-04 00:13:03 +08:00
|
|
|
(fileinfo.ProductBuild >> 24) & 0xFF,
|
|
|
|
(fileinfo.ProductBuild >> 16) & 0xFF,
|
|
|
|
(fileinfo.ProductBuild >> 8) & 0xFF,
|
|
|
|
(fileinfo.ProductBuild >> 0) & 0xFF,
|
|
|
|
};
|
|
|
|
fprintf(fout, "Product (Version / Build): %" PRIu32 " / %" PRIu32 ".%" PRIu32 ".%" PRIu32 ".%" PRIu32 "\n",
|
|
|
|
fileinfo.ProductVersion, product_series[0], product_series[1], product_series[2], product_series[3]
|
|
|
|
);
|
|
|
|
|
2023-08-26 20:34:51 +08:00
|
|
|
fprintf(fout, "Save Flags: %s\n", Unvirt::AccessibleValue::GetFlagEnumName(
|
|
|
|
fileinfo.FileWriteMode, Unvirt::AccessibleValue::EnumDesc::CK_FILE_WRITEMODE
|
2023-03-04 00:13:03 +08:00
|
|
|
).c_str());
|
|
|
|
|
2023-08-26 20:34:51 +08:00
|
|
|
fprintf(fout, "File Size: %s\n", Unvirt::AccessibleValue::GetReadableFileSize(fileinfo.FileSize).c_str());
|
2023-03-04 00:13:03 +08:00
|
|
|
|
|
|
|
fprintf(fout, "Crc: 0x%" PRIX32 "\n", fileinfo.Crc);
|
|
|
|
fputc('\n', fout);
|
|
|
|
|
|
|
|
|
|
|
|
fputs("Hdr1 (Pack / UnPack): ", fout);
|
2023-08-26 20:34:51 +08:00
|
|
|
fprintf(fout, "%s / ", Unvirt::AccessibleValue::GetReadableFileSize(fileinfo.Hdr1PackSize).c_str());
|
|
|
|
fprintf(fout, "%s\n", Unvirt::AccessibleValue::GetReadableFileSize(fileinfo.Hdr1UnPackSize).c_str());
|
2023-03-04 00:13:03 +08:00
|
|
|
|
|
|
|
fputs("Data (Pack / UnPack): ", fout);
|
2023-08-26 20:34:51 +08:00
|
|
|
fprintf(fout, "%s / ", Unvirt::AccessibleValue::GetReadableFileSize(fileinfo.DataPackSize).c_str());
|
|
|
|
fprintf(fout, "%s\n", Unvirt::AccessibleValue::GetReadableFileSize(fileinfo.DataUnPackSize).c_str());
|
2023-03-04 00:13:03 +08:00
|
|
|
fputc('\n', fout);
|
|
|
|
|
|
|
|
|
|
|
|
fprintf(fout, "Manager Count: %" PRIu32 "\nObject Count: %" PRIu32 "\nMax ID Saved: %" PRIu32 "\n",
|
|
|
|
fileinfo.ManagerCount, fileinfo.ObjectCount, fileinfo.MaxIDSaved
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
2023-02-14 16:28:37 +08:00
|
|
|
|
2023-08-26 20:34:51 +08:00
|
|
|
static void PrintCKSTRING(const LibCmo::TypeHelper::MKString& name) {
|
|
|
|
LibCmo::CK2::CKSTRING ckname = name.c_str();
|
|
|
|
if (ckname == nullptr) {
|
2023-03-04 00:13:03 +08:00
|
|
|
fputs(UNVIRT_TERMCOL_LIGHT_MAGENTA(("<anonymous>")), fout);
|
|
|
|
} else {
|
2023-08-26 20:34:51 +08:00
|
|
|
fputs(ckname, fout);
|
2023-03-04 00:13:03 +08:00
|
|
|
}
|
2023-08-26 20:34:51 +08:00
|
|
|
//if (name.empty()) {
|
|
|
|
// fputs(UNVIRT_TERMCOL_LIGHT_MAGENTA(("<anonymous>")), fout);
|
|
|
|
//} else {
|
|
|
|
// fputs(name.c_str(), fout);
|
|
|
|
//}
|
2023-03-04 00:13:03 +08:00
|
|
|
}
|
|
|
|
static void PrintPointer(const void* ptr) {
|
|
|
|
if (ptr == nullptr) {
|
|
|
|
fputs(UNVIRT_TERMCOL_LIGHT_CYAN(("<null>")), fout);
|
|
|
|
} else {
|
|
|
|
fprintf(fout, "<0x%08zX>", reinterpret_cast<size_t>(ptr));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
static void PrintCKGUID(const LibCmo::CK2::CKGUID& guid) {
|
|
|
|
fprintf(stdout, "<0x%08" PRIx32 ", 0x%08" PRIx32 ">", guid.d1, guid.d2);
|
|
|
|
}
|
|
|
|
|
2023-08-26 20:34:51 +08:00
|
|
|
void PrintObjectList(const LibCmo::XContainer::XArray<LibCmo::CK2::CKFileObject>& ls, size_t page, size_t pageitems) {
|
2023-03-04 00:13:03 +08:00
|
|
|
|
|
|
|
fputs(UNVIRT_TERMCOL_LIGHT_YELLOW(("CKFileObject\n")), fout);
|
|
|
|
size_t fulllen = ls.size(),
|
|
|
|
startpos = page * pageitems,
|
|
|
|
fullpage = fulllen / pageitems;
|
|
|
|
|
|
|
|
// print header
|
2023-03-04 11:11:36 +08:00
|
|
|
fputs("CK ID\tType\tCKObject\tCKStateChunk\tName\n", fout);
|
2023-02-14 16:28:37 +08:00
|
|
|
|
2023-03-04 00:13:03 +08:00
|
|
|
// print body
|
|
|
|
for (size_t counter = startpos; counter < fulllen && (counter - startpos) < pageitems; ++counter) {
|
|
|
|
const auto& obj = ls[counter];
|
2023-02-14 16:28:37 +08:00
|
|
|
|
2023-03-04 11:11:36 +08:00
|
|
|
fprintf(fout, "%" PRIu32 "\t", obj.ObjectId);
|
|
|
|
fprintf(fout, "%s\t", Unvirt::AccessibleValue::GetClassIdName(obj.ObjectCid).c_str());
|
2023-03-04 00:13:03 +08:00
|
|
|
PrintPointer(obj.ObjPtr);
|
|
|
|
fputc('\t', fout);
|
|
|
|
PrintPointer(obj.Data);
|
|
|
|
fputc('\t', fout);
|
|
|
|
PrintCKSTRING(obj.Name);
|
2023-02-14 16:28:37 +08:00
|
|
|
fputc('\n', fout);
|
2023-03-04 00:13:03 +08:00
|
|
|
}
|
|
|
|
|
2023-03-04 11:11:36 +08:00
|
|
|
fprintf(fout, "Page %zu of %zu\n", page + 1, fullpage + 1);
|
2023-03-04 00:13:03 +08:00
|
|
|
}
|
|
|
|
|
2023-08-26 20:34:51 +08:00
|
|
|
void PrintManagerList(const LibCmo::XContainer::XArray<LibCmo::CK2::CKFileManagerData>& ls, size_t page, size_t pageitems) {
|
2023-02-14 16:28:37 +08:00
|
|
|
|
2023-03-04 00:13:03 +08:00
|
|
|
fputs(UNVIRT_TERMCOL_LIGHT_YELLOW(("CKFileManager\n")), fout);
|
|
|
|
size_t fulllen = ls.size(),
|
|
|
|
startpos = page * pageitems,
|
|
|
|
fullpage = fulllen / pageitems;
|
2023-02-14 16:28:37 +08:00
|
|
|
|
2023-03-04 00:13:03 +08:00
|
|
|
// print header
|
2023-03-04 11:11:36 +08:00
|
|
|
fputs("CKGUID\tCKBaseManager\tCKStateChunk\n", fout);
|
2023-02-14 16:28:37 +08:00
|
|
|
|
2023-03-04 00:13:03 +08:00
|
|
|
// print body
|
|
|
|
for (size_t counter = startpos; counter < fulllen && (counter - startpos) < pageitems; ++counter) {
|
|
|
|
const auto& mgr = ls[counter];
|
|
|
|
|
|
|
|
PrintCKGUID(mgr.Manager);
|
|
|
|
fputc('\t', fout);
|
|
|
|
PrintPointer(mgr.Data);
|
|
|
|
fputc('\n', fout);
|
2023-02-14 16:28:37 +08:00
|
|
|
}
|
|
|
|
|
2023-03-04 11:11:36 +08:00
|
|
|
fprintf(fout, "Page %zu of %zu\n", page + 1, fullpage + 1);
|
2023-02-14 16:28:37 +08:00
|
|
|
}
|
2023-03-04 00:13:03 +08:00
|
|
|
|
2023-08-27 16:45:07 +08:00
|
|
|
void PrintCKObject(const LibCmo::CK2::ObjImpls::CKObject*) {
|
|
|
|
fputs(UNVIRT_TERMCOL_MAGENTA(("NO IMPLEMENTS\n")), fout);
|
|
|
|
}
|
|
|
|
void PrintCKBaseManager(const LibCmo::CK2::MgrImpls::CKBaseManager*) {
|
|
|
|
fputs(UNVIRT_TERMCOL_MAGENTA(("NO IMPLEMENTS\n")), fout);
|
|
|
|
}
|
|
|
|
void PrintCKStateChunk(const LibCmo::CK2::CKStateChunk*) {
|
|
|
|
fputs(UNVIRT_TERMCOL_MAGENTA(("NO IMPLEMENTS\n")), fout);
|
|
|
|
}
|
|
|
|
|
2023-02-14 16:28:37 +08:00
|
|
|
}
|