Pastebin

New pastes are no longer accepted · Stats

Latest Pastes

eodata.cpp


/* $Id: eodata.cpp 181 2009-12-31 04:24:55Z sausage $
 * EOSERV is released under the zlib license.
 * See LICENSE.txt for more info.
 */

#include "eodata.hpp"

#include "console.hpp"
#include "packet.hpp"

static const char *safe_fail_filename;

static void safe_fail(int line)
{
	Console::Err("Invalid file / failed read/seek: %s -- %i", safe_fail_filename, line);
	std::exit(1);
}

#define SAFE_SEEK(fh, offset, from) if (std::fseek(fh, offset, from) != 0) { std::fclose(fh); safe_fail(__LINE__); }
#define SAFE_READ(buf, size, count, fh) if (std::fread(buf, size, count, fh) != static_cast<int>(count)) { std::fclose(fh); safe_fail(__LINE__); }

void EIF::Read(std::string filename)
{
	this->data.clear();

	std::FILE *fh = std::fopen(filename.c_str(), "rb");
	safe_fail_filename = filename.c_str();

	if (!fh)
	{
		Console::Err("Could not load file: %s", filename.c_str());
		std::exit(1);
	}

	SAFE_SEEK(fh, 3, SEEK_SET);
	SAFE_READ(this->rid, sizeof(char), 4, fh);
	SAFE_READ(this->len, sizeof(char), 2, fh);
	int numobj = PacketProcessor::Number(this->len[0], this->len[1]);
	SAFE_SEEK(fh, 1, SEEK_CUR);

	unsigned char namesize;
	std::string name;
	char buf[EIF::DATA_SIZE] = {0};

	this->data.resize(numobj+1);

	this->data[0] = new EIF_Data;

	SAFE_READ(static_cast<void *>(&namesize), sizeof(char), 1, fh);
	for (int i = 1; i <= numobj; ++i)
	{
		EIF_Data *newdata = new EIF_Data;

		namesize = PacketProcessor::Number(namesize);
		name.resize(namesize);
		SAFE_READ(&name[0], sizeof(char), namesize, fh);
		SAFE_READ(buf, sizeof(char), EIF::DATA_SIZE, fh);

		newdata->id = i;
		newdata->name = name;

		newdata->graphic = PacketProcessor::Number(buf[0], buf[1]);
		newdata->type = static_cast<EIF::Type>(PacketProcessor::Number(buf[2]));
		newdata->subtype = static_cast<EIF::SubType>(PacketProcessor::Number(buf[3]));
		// Ranged gun hack
		if (newdata->id == 365 && newdata->name == "Gun")
		{
			newdata->subtype = EIF::Ranged;
		}
		// / Ranged gun hack
		newdata->special = static_cast<EIF::Special>(PacketProcessor::Number(buf[4]));
		newdata->hp = PacketProcessor::Number(buf[5], buf[6]);
		newdata->tp = PacketProcessor::Number(buf[7], buf[8]);
		newdata->mindam = PacketProcessor::Number(buf[9], buf[10]);
		newdata->maxdam = PacketProcessor::Number(buf[11], buf[12]);
		newdata->accuracy = PacketProcessor::Number(buf[13], buf[14]);
		newdata->evade = PacketProcessor::Number(buf[15], buf[16]);
		newdata->armor = PacketProcessor::Number(buf[17], buf[18]);

		newdata->str = PacketProcessor::Number(buf[20]);
		newdata->intl = PacketProcessor::Number(buf[21]);
		newdata->wis = PacketProcessor::Number(buf[22]);
		newdata->agi = PacketProcessor::Number(buf[23]);
		newdata->con = PacketProcessor::Number(buf[24]);
		newdata->cha = PacketProcessor::Number(buf[25]);

		newdata->light = PacketProcessor::Number(buf[26]);
		newdata->dark = PacketProcessor::Number(buf[27]);
		newdata->earth = PacketProcessor::Number(buf[28]);
		newdata->air = PacketProcessor::Number(buf[29]);
		newdata->water = PacketProcessor::Number(buf[30]);
		newdata->fire = PacketProcessor::Number(buf[31]);

		newdata->scrollmap = PacketProcessor::Number(buf[32], buf[33], buf[34]);
		newdata->scrollx = PacketProcessor::Number(buf[35]);
		newdata->scrolly = PacketProcessor::Number(buf[36]);

		newdata->levelreq = PacketProcessor::Number(buf[37], buf[38]);
		newdata->classreq = PacketProcessor::Number(buf[39], buf[40]);

		newdata->strreq = PacketProcessor::Number(buf[41], buf[42]);
		newdata->intreq = PacketProcessor::Number(buf[43], buf[44]);
		newdata->wisreq = PacketProcessor::Number(buf[45], buf[46]);
		newdata->agireq = PacketProcessor::Number(buf[47], buf[48]);
		newdata->conreq = PacketProcessor::Number(buf[49], buf[50]);
		newdata->chareq = PacketProcessor::Number(buf[51], buf[52]);
		newdata->aoe = PacketProcessor::Number(buf[54]);

		newdata->weight = PacketProcessor::Number(buf[55]);

		newdata->size = static_cast<EIF::Size>(PacketProcessor::Number(buf[57]));

		this->data[i] = newdata;

		if (std::fread(static_cast<void *>(&namesize), sizeof(char), 1, fh) != 1)
		{
			break;
		}
	}

	if (this->data.back()->name.compare("eof") == 0)
	{
		this->data.pop_back();
	}

	Console::Out("%i items loaded.", this->data.size()-1);

	std::fclose(fh);
}

EIF_Data *EIF::Get(unsigned int id)
{
	if (id > 0 && id < this->data.size())
	{
		return this->data[id];
	}
	else
	{
		return this->data[0];
	}
}

 unsigned int EIF::GetKey(int keynum)
    {
        for (std::size_t i = 0; i < this->data.size(); ++i)
        {
            if (this->Get(i)->type == EIF::Key && this->Get(i)->key == keynum)
            {
                return i;
            }
        }

        return 0;
    }

void ENF::Read(std::string filename)
{
	this->data.clear();

	std::FILE *fh = std::fopen(filename.c_str(), "rb");
	safe_fail_filename = filename.c_str();

	if (!fh)
	{
		Console::Err("Could not load file: %s", filename.c_str());
		std::exit(1);
	}

	SAFE_SEEK(fh, 3, SEEK_SET);
	SAFE_READ(this->rid, sizeof(char), 4, fh);
	SAFE_READ(this->len, sizeof(char), 2, fh);
	int numobj = PacketProcessor::Number(this->len[0], this->len[1]);
	SAFE_SEEK(fh, 1, SEEK_CUR);

	unsigned char namesize;
	std::string name;
	char buf[ENF::DATA_SIZE] = {0};

	this->data.resize(numobj+1);

	this->data[0] = new ENF_Data;

	SAFE_READ(static_cast<void *>(&namesize), sizeof(char), 1, fh);
	for (int i = 1; i <= numobj; ++i)
	{
		ENF_Data *newdata = new ENF_Data;

		namesize = PacketProcessor::Number(namesize);
		name.resize(namesize);
		SAFE_READ(&name[0], sizeof(char), namesize, fh);
		SAFE_READ(buf, sizeof(char), ENF::DATA_SIZE, fh);

		newdata->id = i;
		newdata->name = name;

		newdata->graphic = PacketProcessor::Number(buf[0], buf[1]);

		newdata->boss = PacketProcessor::Number(buf[3], buf[4]);
		newdata->child = PacketProcessor::Number(buf[5], buf[6]);
		newdata->type = static_cast<ENF::Type>(PacketProcessor::Number(buf[7], buf[8]));
		newdata->type_index = PacketProcessor::Number(buf[9], buf[10]);
		newdata->hp = PacketProcessor::Number(buf[11], buf[12], buf[13]);

		newdata->mindam = PacketProcessor::Number(buf[16], buf[17]);
		newdata->maxdam = PacketProcessor::Number(buf[18], buf[19]);

		newdata->accuracy = PacketProcessor::Number(buf[20], buf[21]);
		newdata->evade = PacketProcessor::Number(buf[22], buf[23]);
		newdata->armor = PacketProcessor::Number(buf[24], buf[25]);

		newdata->exp = PacketProcessor::Number(buf[36], buf[37]);

		this->data[i] = newdata;

		if (std::fread(static_cast<void *>(&namesize), sizeof(char), 1, fh) != 1)
		{
			break;
		}
	}

	if (this->data.back()->name.compare("eof") == 0)
	{
		this->data.pop_back();
	}

	Console::Out("%i npc types loaded.", this->data.size()-1);

	std::fclose(fh);
}

ENF_Data *ENF::Get(unsigned int id)
{
	if (id > 0 && id < this->data.size())
	{
		return this->data[id];
	}
	else
	{
		return this->data[0];
	}
}

void ESF::Read(std::string filename)
{
	this->data.clear();

	std::FILE *fh = std::fopen(filename.c_str(), "rb");
	safe_fail_filename = filename.c_str();

	if (!fh)
	{
		Console::Err("Could not load file: %s", filename.c_str());
		std::exit(1);
	}

	SAFE_SEEK(fh, 3, SEEK_SET);
	SAFE_READ(this->rid, sizeof(char), 4, fh);
	SAFE_READ(this->len, sizeof(char), 2, fh);
	int numobj = PacketProcessor::Number(this->len[0], this->len[1]);
	SAFE_SEEK(fh, 1, SEEK_CUR);

	unsigned char namesize, shoutsize;
	std::string name, shout;
	char buf[ESF::DATA_SIZE] = {0};

	this->data.resize(numobj+1);

	this->data[0] = new ESF_Data;

	SAFE_READ(static_cast<void *>(&namesize), sizeof(char), 1, fh);
	SAFE_READ(static_cast<void *>(&shoutsize), sizeof(char), 1, fh);
	for (int i = 1; i <= numobj; ++i)
	{
		ESF_Data *newdata = new ESF_Data;

		namesize = PacketProcessor::Number(namesize);
		name.resize(namesize);
		if (namesize > 0)
		{
			SAFE_READ(&name[0], sizeof(char), namesize, fh);
		}

		shoutsize = PacketProcessor::Number(shoutsize);
		shout.resize(shoutsize);
		if (shoutsize > 0)
		{
			SAFE_READ(&shout[0], sizeof(char), shoutsize, fh);
		}

		SAFE_READ(buf, sizeof(char), ESF::DATA_SIZE, fh);

		newdata->id = i;
		newdata->name = name;
		newdata->shout = shout;

		newdata->icon = PacketProcessor::Number(buf[0], buf[1]);
		newdata->graphic = PacketProcessor::Number(buf[2], buf[3]);
		newdata->tp = PacketProcessor::Number(buf[4], buf[5]);
		newdata->sp = PacketProcessor::Number(buf[6], buf[7]);
		newdata->cast_time = PacketProcessor::Number(buf[8]);

		//newdata->damage_heal = PacketProcessor::Number(buf[10]);
		newdata->spell_effect = static_cast<ESF::Spell_Effect>(PacketProcessor::Number(buf[11]));
		newdata->target = static_cast<ESF::Target>(PacketProcessor::Number(buf[17]));
		newdata->type = static_cast<ESF::Type>(PacketProcessor::Number(buf[18]));

		newdata->mindam = PacketProcessor::Number(buf[23], buf[24]);
		newdata->maxdam = PacketProcessor::Number(buf[25], buf[26]);
		newdata->accuracy = PacketProcessor::Number(buf[27], buf[28]);
		newdata->hp = PacketProcessor::Number(buf[34], buf[35]);

		this->data[i] = newdata;

		if (std::fread(static_cast<void *>(&namesize), sizeof(char), 1, fh) != 1)
		{
			break;
		}

		if (std::fread(static_cast<void *>(&shoutsize), sizeof(char), 1, fh) != 1)
		{
			break;
		}
	}

	if (this->data.back()->name.compare("eof") == 0)
	{
		this->data.pop_back();
	}

	Console::Out("%i spells loaded.", this->data.size()-1);

	std::fclose(fh);
}

ESF_Data *ESF::Get(unsigned int id)
{
	if (id > 0 && id < this->data.size())
	{
		return this->data[id];
	}
	else
	{
		return this->data[0];
	}
}

void ECF::Read(std::string filename)
{
	this->data.clear();

	std::FILE *fh = std::fopen(filename.c_str(), "rb");
	safe_fail_filename = filename.c_str();

	if (!fh)
	{
		Console::Err("Could not load file: %s", filename.c_str());
		std::exit(1);
	}

	SAFE_SEEK(fh, 3, SEEK_SET);
	SAFE_READ(this->rid, sizeof(char), 4, fh);
	SAFE_READ(this->len, sizeof(char), 2, fh);
	int numobj = PacketProcessor::Number(this->len[0], this->len[1]);
	SAFE_SEEK(fh, 1, SEEK_CUR);

	unsigned char namesize;
	std::string name;
	char buf[ECF::DATA_SIZE] = {0};

	this->data.resize(numobj+1);

	this->data[0] = new ECF_Data;

	SAFE_READ(static_cast<void *>(&namesize), sizeof(char), 1, fh);
	for (int i = 1; i <= numobj; ++i)
	{
		ECF_Data *newdata = new ECF_Data;

		namesize = PacketProcessor::Number(namesize);
		name.resize(namesize);
		SAFE_READ(&name[0], sizeof(char), namesize, fh);

		SAFE_READ(buf, sizeof(char), ECF::DATA_SIZE, fh);

		newdata->id = i;
		newdata->name = name;

		newdata->base = PacketProcessor::Number(buf[0]);

		this->data[i] = newdata;

		if (std::fread(static_cast<void *>(&namesize), sizeof(char), 1, fh) != 1)
		{
			break;
		}
	}

	if (this->data.back()->name.compare("eof") == 0)
	{
		this->data.pop_back();
	}

	Console::Out("%i classes loaded.", this->data.size()-1);

	std::fclose(fh);
}