/src/tools/vmap4_extractor/adtfile.cpp
https://gitlab.com/tkrokli/TrinityCore_434 · C++ · 227 lines · 170 code · 32 blank · 25 comment · 43 complexity · aef0ac0794ed1ef4648343203acf756b MD5 · raw file
- /*
- * Copyright (C) 2008-2015 TrinityCore <http://www.trinitycore.org/>
- * Copyright (C) 2005-2011 MaNGOS <http://getmangos.com/>
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License as published by the
- * Free Software Foundation; either version 2 of the License, or (at your
- * option) any later version.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program. If not, see <http://www.gnu.org/licenses/>.
- */
- #include "vmapexport.h"
- #include "adtfile.h"
- #include <algorithm>
- #include <cstdio>
- #ifdef WIN32
- #define snprintf _snprintf
- #endif
- char const* GetPlainName(char const* FileName)
- {
- const char * szTemp;
- if((szTemp = strrchr(FileName, '\\')) != NULL)
- FileName = szTemp + 1;
- return FileName;
- }
- char* GetPlainName(char* FileName)
- {
- char * szTemp;
- if((szTemp = strrchr(FileName, '\\')) != NULL)
- FileName = szTemp + 1;
- return FileName;
- }
- void FixNameCase(char* name, size_t len)
- {
- char* ptr = name + len - 1;
- //extension in lowercase
- for (; *ptr != '.'; --ptr)
- *ptr |= 0x20;
- for (; ptr >= name; --ptr)
- {
- if (ptr > name && *ptr >= 'A' && *ptr <= 'Z' && isalpha(*(ptr - 1)))
- *ptr |= 0x20;
- else if ((ptr == name || !isalpha(*(ptr - 1))) && *ptr >= 'a' && *ptr <= 'z')
- *ptr &= ~0x20;
- }
- }
- void FixNameSpaces(char* name, size_t len)
- {
- for (size_t i=0; i<len-3; i++)
- {
- if(name[i] == ' ')
- name[i] = '_';
- }
- }
- char* GetExtension(char* FileName)
- {
- if (char* szTemp = strrchr(FileName, '.'))
- return szTemp;
- return NULL;
- }
- extern HANDLE WorldMpq;
- ADTFile::ADTFile(char* filename) : ADT(WorldMpq, filename, false)
- {
- Adtfilename.append(filename);
- }
- bool ADTFile::init(uint32 map_num, uint32 tileX, uint32 tileY)
- {
- if(ADT.isEof ())
- return false;
- uint32 size;
- string xMap;
- string yMap;
- Adtfilename.erase(Adtfilename.find(".adt"),4);
- string TempMapNumber;
- TempMapNumber = Adtfilename.substr(Adtfilename.length()-6,6);
- xMap = TempMapNumber.substr(TempMapNumber.find("_")+1,(TempMapNumber.find_last_of("_")-1) - (TempMapNumber.find("_")));
- yMap = TempMapNumber.substr(TempMapNumber.find_last_of("_")+1,(TempMapNumber.length()) - (TempMapNumber.find_last_of("_")));
- Adtfilename.erase((Adtfilename.length()-xMap.length()-yMap.length()-2), (xMap.length()+yMap.length()+2));
- //string AdtMapNumber = xMap + ' ' + yMap + ' ' + GetPlainName((char*)Adtfilename.c_str());
- //printf("Processing map %s...\n", AdtMapNumber.c_str());
- //printf("MapNumber = %s\n", TempMapNumber.c_str());
- //printf("xMap = %s\n", xMap.c_str());
- //printf("yMap = %s\n", yMap.c_str());
- std::string dirname = std::string(szWorkDirWmo) + "/dir_bin";
- FILE *dirfile;
- dirfile = fopen(dirname.c_str(), "ab");
- if(!dirfile)
- {
- printf("Can't open dirfile!'%s'\n", dirname.c_str());
- return false;
- }
- while (!ADT.isEof())
- {
- char fourcc[5];
- ADT.read(&fourcc,4);
- ADT.read(&size, 4);
- flipcc(fourcc);
- fourcc[4] = 0;
- size_t nextpos = ADT.getPos() + size;
- if (!strcmp(fourcc,"MCIN"))
- {
- }
- else if (!strcmp(fourcc,"MTEX"))
- {
- }
- else if (!strcmp(fourcc,"MMDX"))
- {
- if (size)
- {
- char* buf = new char[size];
- ADT.read(buf, size);
- char* p = buf;
- int t = 0;
- ModelInstanceNames = new std::string[size];
- while (p < buf + size)
- {
- std::string path(p);
- char* s = GetPlainName(p);
- FixNameCase(s, strlen(s));
- FixNameSpaces(s, strlen(s));
- ModelInstanceNames[t++] = s;
- ExtractSingleModel(path);
- p += strlen(p) + 1;
- }
- delete[] buf;
- }
- }
- else if (!strcmp(fourcc,"MWMO"))
- {
- if (size)
- {
- char* buf = new char[size];
- ADT.read(buf, size);
- char* p = buf;
- int q = 0;
- WmoInstanceNames = new std::string[size];
- while (p < buf + size)
- {
- char* s = GetPlainName(p);
- FixNameCase(s, strlen(s));
- FixNameSpaces(s, strlen(s));
- WmoInstanceNames[q++] = s;
- p += strlen(p) + 1;
- }
- delete[] buf;
- }
- }
- //======================
- else if (!strcmp(fourcc,"MDDF"))
- {
- if (size)
- {
- nMDX = (int)size / 36;
- for (int i=0; i<nMDX; ++i)
- {
- uint32 id;
- ADT.read(&id, 4);
- ModelInstance inst(ADT, ModelInstanceNames[id].c_str(), map_num, tileX, tileY, dirfile);
- }
- delete[] ModelInstanceNames;
- ModelInstanceNames = NULL;
- }
- }
- else if (!strcmp(fourcc,"MODF"))
- {
- if (size)
- {
- nWMO = (int)size / 64;
- for (int i=0; i<nWMO; ++i)
- {
- uint32 id;
- ADT.read(&id, 4);
- WMOInstance inst(ADT, WmoInstanceNames[id].c_str(), map_num, tileX, tileY, dirfile);
- }
- delete[] WmoInstanceNames;
- WmoInstanceNames = NULL;
- }
- }
- //======================
- ADT.seek(nextpos);
- }
- ADT.close();
- fclose(dirfile);
- return true;
- }
- ADTFile::~ADTFile()
- {
- ADT.close();
- }