// // Created by Иван_Архипов on 24.11.2017. // #include "Subfiles/JpgSubfile.h" #include "EasyLogging++/easylogging++.h" #include "BinaryData.h" #include "DatFile.h" #include "SubfileData.h" namespace LOTRO_DAT { JpgSubfile::JpgSubfile() = default; JpgSubfile::JpgSubfile(DatFile *dat, long long dictionary_offset, long long unknown1, long long file_id, long long file_offset, long long file_size, long long timestamp, long long version, long long block_size, long long unknown2) : Subfile(dat, dictionary_offset, unknown1, file_id, file_offset, file_size, timestamp, version, block_size, unknown2) { } FILE_TYPE JpgSubfile::FileType() const { return JPG; } std::string JpgSubfile::Extension() const { return std::string(".jpg"); } SubfileData JpgSubfile::PrepareForExport(const BinaryData &file_data) { if (file_data.Empty()) { return SubfileData(); } SubfileData result; result.binary_data = file_data.CutData(24); result.options["fid"] = file_id(); result.options["ext"] = Extension(); return result; } BinaryData JpgSubfile::MakeForImport(const BinaryData &old_data, const SubfileData &data) { if (!data.options["ext"] || data.options["ext"].as() != Extension() || !data.options["fid"] || data.options["fid"].as() != file_id()) { LOG(ERROR) << "invalid options data!"; return BinaryData(0); } BinaryData file_size = BinaryData::FromNumber<4>(data.binary_data.size()); return old_data.CutData(0, 28) + file_size + data.binary_data; } };