1
0
mirror of https://github.com/vcmi/vcmi.git synced 2024-12-24 22:14:36 +02:00
vcmi/CHeroHandler.cpp
Michał W. Urbańczyk 4e0cacff14 * [bugfix] nie zamula
* [new] uniezależnienie od rozprutego h3sprite.lod
2007-07-11 12:08:42 +00:00

377 lines
7.4 KiB
C++

#include "stdafx.h"
#include "CHeroHandler.h"
#include "CGameInfo.h"
#include <sstream>
#define CGI (CGameInfo::mainObj)
void CHeroHandler::loadHeroes()
{
int ID=0;
std::ifstream inp("H3bitmap.lod\\HOTRAITS.TXT", std::ios::in);
std::string dump;
for(int i=0; i<25; ++i)
{
inp>>dump;
}
inp.ignore();
while(!inp.eof())
{
CHero nher;
std::string base;
char * tab = new char[500];
int iit = 0;
inp.getline(tab, 500);
base = std::string(tab);
if(base.size()<2) //ended, but some rubbish could still stay end we have something useless
{
loadSpecialAbilities();
loadBiographies();
loadHeroClasses();
inp.close();
return;
}
while(base[iit]!='\t')
{
++iit;
}
nher.name = base.substr(0, iit);
++iit;
for(int i=iit; i<iit+100; ++i)
{
if(base[i]==(char)(10) || base[i]==(char)(9))
{
nher.low1stack = atoi(base.substr(iit, i).c_str());
iit=i+1;
break;
}
}
for(int i=iit; i<iit+100; ++i)
{
if(base[i]==(char)(10) || base[i]==(char)(9))
{
nher.high1stack = atoi(base.substr(iit, i).c_str());
iit=i+1;
break;
}
}
int ipom=iit;
while(base[ipom]!='\t')
{
++ipom;
}
nher.refType1stack = base.substr(iit, ipom-iit);
iit=ipom+1;
for(int i=iit; i<iit+100; ++i)
{
if(base[i]==(char)(10) || base[i]==(char)(9))
{
nher.low2stack = atoi(base.substr(iit, i-iit).c_str());
iit=i+1;
break;
}
}
for(int i=iit; i<iit+100; ++i)
{
if(base[i]==(char)(10) || base[i]==(char)(9))
{
nher.high2stack = atoi(base.substr(iit, i-iit).c_str());
iit=i+1;
break;
}
}
ipom=iit;
while(base[ipom]!='\t')
{
++ipom;
}
nher.refType2stack = base.substr(iit, ipom-iit);
iit=ipom+1;
for(int i=iit; i<iit+100; ++i)
{
if(base[i]==(char)(10) || base[i]==(char)(9))
{
nher.low3stack = atoi(base.substr(iit, i-iit).c_str());
iit=i+1;
break;
}
}
for(int i=iit; i<iit+100; ++i)
{
if(base[i]==(char)(10) || base[i]==(char)(9))
{
nher.high3stack = atoi(base.substr(iit, i-iit).c_str());
iit=i+1;
break;
}
}
nher.refType3stack = base.substr(iit, base.size()-iit);
nher.ID=ID++;
heroes.push_back(nher);
delete[500] tab;
}
loadSpecialAbilities();
}
void CHeroHandler::loadSpecialAbilities()
{
std::ifstream inp("H3bitmap.lod\\HEROSPEC.txt", std::ios::in);
std::string dump;
for(int i=0; i<7; ++i)
{
inp>>dump;
}
inp.ignore();
int whHero=0;
while(!inp.eof() && whHero<heroes.size())
{
std::string base;
char * tab = new char[500];
int iitBef = 0;
int iit = 0;
inp.getline(tab, 500);
base = std::string(tab);
if(base.size()<2) //ended, but some rubbish could still stay end we have something useless
{
inp.close();
return; //add counter
}
while(base[iit]!='\t')
{
++iit;
}
heroes[whHero].bonusName = base.substr(0, iit);
++iit;
iitBef=iit;
if(heroes[whHero].bonusName == std::string("Ogry"))
{
char * tab2 = new char[500];
inp.getline(tab2, 500);
base += std::string(tab2);
delete [500] tab2;
}
while(base[iit]!='\t')
{
++iit;
}
heroes[whHero].shortBonus = base.substr(iitBef, iit-iitBef);
++iit;
iitBef=iit;
while(base[iit]!='\t' && iit<base.size())
{
++iit;
}
heroes[whHero].longBonus = base.substr(iitBef, iit-iitBef);
++whHero;
delete [500] tab;
}
inp.close();
}
void CHeroHandler::loadBiographies()
{
std::ifstream inp("H3bitmap.lod\\HEROBIOS.TXT", std::ios::in | std::ios::binary);
inp.seekg(0,std::ios::end); // na koniec
int andame = inp.tellg(); // read length
inp.seekg(0,std::ios::beg); // wracamy na poczatek
char * bufor = new char[andame]; // allocate memory
inp.read((char*)bufor, andame); // read map file to buffer
inp.close();
std::string buf = std::string(bufor);
delete [andame] bufor;
int i = 0; //buf iterator
for(int q=0; q<heroes.size(); ++q)
{
int befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\r')
break;
}
heroes[q].biography = buf.substr(befi, i-befi);
i+=2;
}
}
void CHeroHandler::loadHeroClasses()
{
std::ifstream inp("H3bitmap.lod\\HCTRAITS.TXT", std::ios::in | std::ios::binary);
inp.seekg(0,std::ios::end); // na koniec
int andame = inp.tellg(); // read length
inp.seekg(0,std::ios::beg); // wracamy na poczatek
char * bufor = new char[andame]; // allocate memory
inp.read((char*)bufor, andame); // read map file to buffer
inp.close();
std::string buf = std::string(bufor);
delete [andame] bufor;
int i = 0; //buf iterator
int hmcr = 0;
for(i; i<andame; ++i) //omitting rubbish
{
if(buf[i]=='\r')
++hmcr;
if(hmcr==2)
break;
}
i+=2;
for(int ss=0; ss<18; ++ss) //18 classes of hero (including conflux)
{
CHeroClass * hc = new CHeroClass;
int befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->name = buf.substr(befi, i-befi);
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->aggression = atof(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->initialAttack = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->initialDefence = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->initialPower = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->initialKnowledge = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proAttack[0] = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proDefence[0] = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proPower[0] = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proKnowledge[0] = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proAttack[1] = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proDefence[1] = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proPower[1] = atoi(buf.substr(befi, i-befi).c_str());
++i;
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
hc->proKnowledge[1] = atoi(buf.substr(befi, i-befi).c_str());
++i;
CHero kkk = heroes[0];
for(int dd=0; dd<CGameInfo::mainObj->abilh->abilities.size(); ++dd)
{
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t')
break;
}
int buff = atoi(buf.substr(befi, i-befi).c_str());
++i;
hc->proSec.push_back(buff);
}
for(int dd=0; dd<9; ++dd)
{
befi=i;
for(i; i<andame; ++i)
{
if(buf[i]=='\t' || buf[i]=='\r')
break;
}
hc->selectionProbability[dd] = atoi(buf.substr(befi, i-befi).c_str());
++i;
}
++i;
heroClasses.push_back(hc);
}
}