diff options
-rw-r--r-- | tools/TexturePacker/TexturePacker.exe | bin | 86528 -> 86528 bytes | |||
-rw-r--r-- | tools/TexturePacker/XBTFWriter.cpp | 55 | ||||
-rw-r--r-- | tools/TexturePacker/XBTFWriter.h | 5 |
3 files changed, 31 insertions, 29 deletions
diff --git a/tools/TexturePacker/TexturePacker.exe b/tools/TexturePacker/TexturePacker.exe Binary files differindex 9a96102b46..6da10b0889 100644 --- a/tools/TexturePacker/TexturePacker.exe +++ b/tools/TexturePacker/TexturePacker.exe diff --git a/tools/TexturePacker/XBTFWriter.cpp b/tools/TexturePacker/XBTFWriter.cpp index d5beb143d7..6435734d91 100644 --- a/tools/TexturePacker/XBTFWriter.cpp +++ b/tools/TexturePacker/XBTFWriter.cpp @@ -34,7 +34,9 @@ CXBTFWriter::CXBTFWriter(CXBTF& xbtf, const std::string& outputFile) : m_xbtf(xbtf) { m_outputFile = outputFile; - m_file = m_tempFile = NULL; + m_file = NULL; + m_data = NULL; + m_size = 0; } bool CXBTFWriter::Create() @@ -45,52 +47,49 @@ bool CXBTFWriter::Create() return false; } - m_tempFile = fopen(TEMP_FILE, "wb"); - if (m_tempFile == NULL) - { - return false; - } - return true; } bool CXBTFWriter::Close() { - if (m_file == NULL || m_tempFile == NULL) + if (m_file == NULL || m_data == NULL) { return false; } - fclose(m_tempFile); - m_tempFile = fopen(TEMP_FILE, "rb"); - if (m_tempFile == NULL) - { - return false; - } - - unsigned char* tmp = new unsigned char[10*1024*1024]; - size_t bytesRead; - while ((bytesRead = fread(tmp, 1, TEMP_SIZE, m_tempFile)) > 0) - { - fwrite(tmp, bytesRead, 1, m_file); - } - delete[] tmp; + fwrite(m_data, 1, m_size, m_file); - fclose(m_file); - fclose(m_tempFile); - unlink(TEMP_FILE); + Cleanup(); return true; } -bool CXBTFWriter::AppendContent(unsigned char const* data, size_t length) +void CXBTFWriter::Cleanup() { - if (m_tempFile == NULL) + free(m_data); + m_data = NULL; + m_size = 0; + if (m_file) { + fclose(m_file); + m_file = NULL; + } +} + +bool CXBTFWriter::AppendContent(unsigned char const* data, size_t length) +{ + unsigned char *new_data = (unsigned char *)realloc(m_data, m_size + length); + + if (new_data == NULL) + { // OOM - cleanup and fail + Cleanup(); return false; } - fwrite(data, length, 1, m_tempFile); + m_data = new_data; + + memcpy(m_data + m_size, data, length); + m_size += length; return true; } diff --git a/tools/TexturePacker/XBTFWriter.h b/tools/TexturePacker/XBTFWriter.h index d86094e449..f7f06ee3f2 100644 --- a/tools/TexturePacker/XBTFWriter.h +++ b/tools/TexturePacker/XBTFWriter.h @@ -37,10 +37,13 @@ public: bool UpdateHeader(const std::vector<unsigned int>& dupes); private: + void Cleanup(); + CXBTF& m_xbtf; std::string m_outputFile; FILE* m_file; - FILE* m_tempFile; + unsigned char *m_data; + size_t m_size; }; #endif |