125 lines
3.9 KiB
C++
125 lines
3.9 KiB
C++
/*
|
|
https://github.com/peterix/dfhack
|
|
Copyright (c) 2009-2012 Petr Mrázek (peterix@gmail.com)
|
|
|
|
This software is provided 'as-is', without any express or implied
|
|
warranty. In no event will the authors be held liable for any
|
|
damages arising from the use of this software.
|
|
|
|
Permission is granted to anyone to use this software for any
|
|
purpose, including commercial applications, and to alter it and
|
|
redistribute it freely, subject to the following restrictions:
|
|
|
|
1. The origin of this software must not be misrepresented; you must
|
|
not claim that you wrote the original software. If you use this
|
|
software in a product, an acknowledgment in the product documentation
|
|
would be appreciated but is not required.
|
|
|
|
2. Altered source versions must be plainly marked as such, and
|
|
must not be misrepresented as being the original software.
|
|
|
|
3. This notice may not be removed or altered from any source
|
|
distribution.
|
|
*/
|
|
|
|
|
|
#pragma once
|
|
|
|
#include "Pragma.h"
|
|
#include "Export.h"
|
|
|
|
#include "DataDefs.h"
|
|
#include "df/general_ref.h"
|
|
#include "df/specific_ref.h"
|
|
|
|
namespace DFHack
|
|
{
|
|
struct t_matglossPair
|
|
{
|
|
int16_t type;
|
|
int32_t index;
|
|
bool operator<(const t_matglossPair &b) const
|
|
{
|
|
if (type != b.type) return (type < b.type);
|
|
return (index < b.index);
|
|
}
|
|
bool operator==(const t_matglossPair &b) const
|
|
{
|
|
return (type == b.type) && (index == b.index);
|
|
}
|
|
bool operator!=(const t_matglossPair &b) const
|
|
{
|
|
return (type != b.type) || (index != b.index);
|
|
}
|
|
};
|
|
|
|
template <int SIZE>
|
|
struct junk_fill
|
|
{
|
|
uint8_t data[SIZE];
|
|
};
|
|
|
|
struct t_name
|
|
{
|
|
char first_name[128];
|
|
char nickname[128];
|
|
int32_t words[7];
|
|
uint16_t parts_of_speech[7];
|
|
uint32_t language;
|
|
bool has_name;
|
|
};
|
|
|
|
struct t_attrib
|
|
{
|
|
uint32_t level;
|
|
uint32_t field_4; // offset from beginning, purpose unknown
|
|
uint32_t field_8;
|
|
uint32_t field_C;
|
|
uint32_t leveldiff;
|
|
uint32_t field_14;
|
|
uint32_t field_18;
|
|
};
|
|
|
|
struct t_level
|
|
{
|
|
uint32_t level;
|
|
std::string name;
|
|
uint32_t xpNxtLvl;
|
|
};
|
|
|
|
typedef std::pair<df::coord2d, df::coord2d> rect2d;
|
|
|
|
inline rect2d intersect(rect2d a, rect2d b) {
|
|
df::coord2d g1 = a.first, g2 = a.second;
|
|
df::coord2d c1 = b.first, c2 = b.second;
|
|
df::coord2d rc1 = df::coord2d(std::max(g1.x, c1.x), std::max(g1.y, c1.y));
|
|
df::coord2d rc2 = df::coord2d(std::min(g2.x, c2.x), std::min(g2.y, c2.y));
|
|
return rect2d(rc1, rc2);
|
|
}
|
|
|
|
inline rect2d mkrect_xy(int x1, int y1, int x2, int y2) {
|
|
return rect2d(df::coord2d(x1, y1), df::coord2d(x2, y2));
|
|
}
|
|
|
|
inline rect2d mkrect_wh(int x, int y, int w, int h) {
|
|
return rect2d(df::coord2d(x, y), df::coord2d(x+w-1, y+h-1));
|
|
}
|
|
|
|
inline df::coord2d rect_size(const rect2d &rect) {
|
|
return rect.second - rect.first + df::coord2d(1,1);
|
|
}
|
|
|
|
DFHACK_EXPORT int getdir(std::string dir, std::vector<std::string> &files);
|
|
DFHACK_EXPORT bool hasEnding (std::string const &fullString, std::string const &ending);
|
|
|
|
DFHACK_EXPORT df::general_ref *findRef(std::vector<df::general_ref*> &vec, df::general_ref_type type);
|
|
DFHACK_EXPORT bool removeRef(std::vector<df::general_ref*> &vec, df::general_ref_type type, int id);
|
|
|
|
DFHACK_EXPORT df::item *findItemRef(std::vector<df::general_ref*> &vec, df::general_ref_type type);
|
|
DFHACK_EXPORT df::building *findBuildingRef(std::vector<df::general_ref*> &vec, df::general_ref_type type);
|
|
DFHACK_EXPORT df::unit *findUnitRef(std::vector<df::general_ref*> &vec, df::general_ref_type type);
|
|
|
|
DFHACK_EXPORT df::specific_ref *findRef(std::vector<df::specific_ref*> &vec, df::specific_ref_type type);
|
|
DFHACK_EXPORT bool removeRef(std::vector<df::specific_ref*> &vec, df::specific_ref_type type, void *ptr);
|
|
}// namespace DFHack
|