mirror of
https://github.com/vcmi/vcmi.git
synced 2024-11-24 08:32:34 +02:00
8040a81eec
- hopefully some speedup for filesystem loading (#1048)
266 lines
5.0 KiB
C++
266 lines
5.0 KiB
C++
#include "StdInc.h"
|
|
#include "VCMI_Lib.h"
|
|
|
|
|
|
#include "CArtHandler.h"
|
|
#include "CCreatureHandler.h"
|
|
#include "CDefObjInfoHandler.h"
|
|
#include "CHeroHandler.h"
|
|
#include "CObjectHandler.h"
|
|
#include "CTownHandler.h"
|
|
#include "CBuildingHandler.h"
|
|
#include "CSpellHandler.h"
|
|
#include "CGeneralTextHandler.h"
|
|
#include "IGameEventsReceiver.h"
|
|
#include "CStopWatch.h"
|
|
#include "VCMIDirs.h"
|
|
#include "Filesystem/CResourceLoader.h"
|
|
|
|
/*
|
|
* VCMI_Lib.cpp, part of VCMI engine
|
|
*
|
|
* Authors: listed in file AUTHORS in main folder
|
|
*
|
|
* License: GNU General Public License v2.0 or later
|
|
* Full text of license available in license.txt file, in main folder
|
|
*
|
|
*/
|
|
|
|
LibClasses * VLC = NULL;
|
|
|
|
DLL_LINKAGE VCMIDirs GVCMIDirs;
|
|
|
|
|
|
DLL_LINKAGE void initDLL(CConsoleHandler *Console, std::ostream *Logfile)
|
|
{
|
|
console = Console;
|
|
logfile = Logfile;
|
|
VLC = new LibClasses;
|
|
//try
|
|
{
|
|
VLC->init();
|
|
}
|
|
//HANDLE_EXCEPTION;
|
|
}
|
|
|
|
DLL_LINKAGE void loadToIt(std::string &dest, const std::string &src, int &iter, int mode)
|
|
{
|
|
switch(mode)
|
|
{
|
|
case 0:
|
|
{
|
|
int hmcr = 0;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\t')
|
|
++hmcr;
|
|
if(hmcr==1)
|
|
break;
|
|
}
|
|
++iter;
|
|
|
|
int befi=iter;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\t')
|
|
break;
|
|
}
|
|
dest = src.substr(befi, iter-befi);
|
|
++iter;
|
|
|
|
hmcr = 0;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\r')
|
|
++hmcr;
|
|
if(hmcr==1)
|
|
break;
|
|
}
|
|
iter+=2;
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
int hmcr = 0;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\t')
|
|
++hmcr;
|
|
if(hmcr==1)
|
|
break;
|
|
}
|
|
++iter;
|
|
|
|
int befi=iter;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\r')
|
|
break;
|
|
}
|
|
dest = src.substr(befi, iter-befi);
|
|
iter+=2;
|
|
break;
|
|
}
|
|
case 2:
|
|
{
|
|
int befi=iter;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\t')
|
|
break;
|
|
}
|
|
dest = src.substr(befi, iter-befi);
|
|
++iter;
|
|
|
|
int hmcr = 0;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\r')
|
|
++hmcr;
|
|
if(hmcr==1)
|
|
break;
|
|
}
|
|
iter+=2;
|
|
break;
|
|
}
|
|
case 3:
|
|
{
|
|
int befi=iter;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\r')
|
|
break;
|
|
}
|
|
dest = src.substr(befi, iter-befi);
|
|
iter+=2;
|
|
break;
|
|
}
|
|
case 4:
|
|
{
|
|
int befi=iter;
|
|
for(; iter<src.size(); ++iter)
|
|
{
|
|
if(src[iter]=='\t')
|
|
break;
|
|
}
|
|
dest = src.substr(befi, iter-befi);
|
|
iter++;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
DLL_LINKAGE void loadToIt(si32 &dest, const std::string &src, int &iter, int mode)
|
|
{
|
|
std::string pom;
|
|
loadToIt(pom,src,iter,mode);
|
|
dest = atol(pom.c_str());
|
|
}
|
|
|
|
void LibClasses::loadFilesystem()
|
|
{
|
|
CStopWatch totalTime;
|
|
CStopWatch loadTime;
|
|
|
|
CResourceHandler::initialize();
|
|
tlog0<<"\t Initialization: "<<loadTime.getDiff()<<std::endl;
|
|
|
|
CResourceHandler::loadFileSystem("ALL/config/filesystem.json");
|
|
tlog0<<"\t Data loading: "<<loadTime.getDiff()<<std::endl;
|
|
|
|
CResourceHandler::loadModsFilesystems();
|
|
tlog0<<"\t Mod filesystems: "<<loadTime.getDiff()<<std::endl;
|
|
|
|
tlog0<<"File system handler: "<<totalTime.getDiff()<<std::endl;
|
|
}
|
|
|
|
void LibClasses::init()
|
|
{
|
|
CStopWatch pomtime;
|
|
|
|
generaltexth = new CGeneralTextHandler;
|
|
generaltexth->load();
|
|
tlog0<<"\tGeneral text handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
heroh = new CHeroHandler;
|
|
heroh->loadHeroes();
|
|
heroh->loadObstacles();
|
|
heroh->loadPuzzleInfo();
|
|
tlog0 <<"\tHero handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
arth = new CArtHandler;
|
|
arth->loadArtifacts(false);
|
|
tlog0<<"\tArtifact handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
creh = new CCreatureHandler();
|
|
creh->loadCreatures();
|
|
tlog0<<"\tCreature handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
townh = new CTownHandler;
|
|
townh->loadStructures();
|
|
tlog0<<"\tTown handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
objh = new CObjectHandler;
|
|
objh->loadObjects();
|
|
tlog0<<"\tObject handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
dobjinfo = new CDefObjInfoHandler;
|
|
dobjinfo->load();
|
|
tlog0<<"\tDef information handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
buildh = new CBuildingHandler;
|
|
buildh->loadBuildings();
|
|
tlog0<<"\tBuilding handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
spellh = new CSpellHandler;
|
|
spellh->loadSpells();
|
|
tlog0<<"\tSpell handler: "<<pomtime.getDiff()<<std::endl;
|
|
|
|
IS_AI_ENABLED = false;
|
|
}
|
|
|
|
void LibClasses::clear()
|
|
{
|
|
delete generaltexth;
|
|
delete heroh;
|
|
delete arth;
|
|
delete creh;
|
|
delete townh;
|
|
delete objh;
|
|
delete dobjinfo;
|
|
delete buildh;
|
|
delete spellh;
|
|
makeNull();
|
|
}
|
|
|
|
void LibClasses::makeNull()
|
|
{
|
|
generaltexth = NULL;
|
|
heroh = NULL;
|
|
arth = NULL;
|
|
creh = NULL;
|
|
townh = NULL;
|
|
objh = NULL;
|
|
dobjinfo = NULL;
|
|
buildh = NULL;
|
|
spellh = NULL;
|
|
}
|
|
|
|
LibClasses::LibClasses()
|
|
{
|
|
//init pointers to handlers
|
|
makeNull();
|
|
}
|
|
|
|
void LibClasses::callWhenDeserializing()
|
|
{
|
|
generaltexth = new CGeneralTextHandler;
|
|
generaltexth->load();
|
|
arth->loadArtifacts(true);
|
|
}
|
|
|
|
LibClasses::~LibClasses()
|
|
{
|
|
clear();
|
|
} |