JpgSubfile.cpp 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. //
  2. // Created by Иван_Архипов on 24.11.2017.
  3. //
  4. #include "JpgSubfile.h"
  5. #include "../../include/BinaryData.h"
  6. #include "../../include/DatFile.h"
  7. #include "../../include/DatException.h"
  8. #include "../../include/SubfileData.h"
  9. namespace LOTRO_DAT {
  10. JpgSubfile::JpgSubfile() = default;
  11. JpgSubfile::JpgSubfile(DatFile *dat, long long dictionary_offset, long long fragments_count, long long unknown1,
  12. long long file_id, long long file_offset, long long file_size, long long timestamp,
  13. long long version, long long block_size)
  14. : Subfile(dat, dictionary_offset, fragments_count, unknown1, file_id, file_offset, file_size, timestamp,
  15. version, block_size) {
  16. }
  17. FILE_TYPE JpgSubfile::FileType() const {
  18. return JPG;
  19. }
  20. std::string JpgSubfile::Extension() const {
  21. return std::string(".jpg");
  22. }
  23. SubfileData JpgSubfile::PrepareForExport(const BinaryData &file_data) {
  24. SubfileData result;
  25. result.binary_data = file_data.CutData(24);
  26. result.options["fid"] = file_id();
  27. result.options["ext"] = Extension();
  28. return result;
  29. }
  30. BinaryData JpgSubfile::MakeForImport(const BinaryData &old_data, const SubfileData &data) {
  31. if (!data.options["ext"] || data.options["ext"].as<std::string>() != Extension() ||
  32. !data.options["fid"] || data.options["fid"].as<long long>() != file_id()) {
  33. throw DatException("Bad DdsSubfile::MakeForImport() - invalid options data!", IMPORT_EXCEPTION);
  34. }
  35. BinaryData file_size;
  36. file_size.FromNumber<4>(data.binary_data.size());
  37. return old_data.CutData(0, 28) + file_size + data.binary_data;
  38. }
  39. };