CSaveFile.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /*
  2. * CSaveFile.cpp, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #include "StdInc.h"
  11. #include "CSaveFile.h"
  12. VCMI_LIB_NAMESPACE_BEGIN
  13. CSaveFile::CSaveFile(const boost::filesystem::path &fname)
  14. : serializer(this)
  15. {
  16. openNextFile(fname);
  17. }
  18. //must be instantiated in .cpp file for access to complete types of all member fields
  19. CSaveFile::~CSaveFile() = default;
  20. int CSaveFile::write(const void * data, unsigned size)
  21. {
  22. sfile->write((char *)data,size);
  23. return size;
  24. }
  25. void CSaveFile::openNextFile(const boost::filesystem::path &fname)
  26. {
  27. fName = fname;
  28. try
  29. {
  30. sfile = std::make_unique<std::fstream>(fname.c_str(), std::ios::out | std::ios::binary);
  31. sfile->exceptions(std::ifstream::failbit | std::ifstream::badbit); //we throw a lot anyway
  32. if(!(*sfile))
  33. THROW_FORMAT("Error: cannot open to write %s!", fname);
  34. sfile->write("VCMI",4); //write magic identifier
  35. serializer & SERIALIZATION_VERSION; //write format version
  36. }
  37. catch(...)
  38. {
  39. logGlobal->error("Failed to save to %s", fname.string());
  40. clear();
  41. throw;
  42. }
  43. }
  44. void CSaveFile::reportState(vstd::CLoggerBase * out)
  45. {
  46. out->debug("CSaveFile");
  47. if(sfile.get() && *sfile)
  48. {
  49. out->debug("\tOpened %s \tPosition: %d", fName, sfile->tellp());
  50. }
  51. }
  52. void CSaveFile::clear()
  53. {
  54. fName.clear();
  55. sfile = nullptr;
  56. }
  57. void CSaveFile::putMagicBytes(const std::string &text)
  58. {
  59. write(text.c_str(), static_cast<unsigned int>(text.length()));
  60. }
  61. VCMI_LIB_NAMESPACE_END