first commit
parent
2284fb32d2
commit
0d2554f829
@ -0,0 +1,458 @@
|
|||||||
|
/*
|
||||||
|
www.sourceforge.net/projects/dfhack
|
||||||
|
Copyright (c) 2009 Petr Mrázek (peterix), Kenneth Ferland (Impaler[WrG]), dorf, doomchild
|
||||||
|
|
||||||
|
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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __DFMAPS__
|
||||||
|
#define __DFMAPS__
|
||||||
|
|
||||||
|
#include "Python.h"
|
||||||
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
#include "modules/Maps.h"
|
||||||
|
#include "DF_Helpers.cpp"
|
||||||
|
|
||||||
|
using namespace DFHack;
|
||||||
|
|
||||||
|
static PyObject* BuildVein(DFHack::t_vein& v)
|
||||||
|
{
|
||||||
|
PyObject* t_dict;
|
||||||
|
PyObject* temp;
|
||||||
|
|
||||||
|
t_dict = PyDict_New();
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.vtable);
|
||||||
|
DICTADD(t_dict, "vtable", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.type);
|
||||||
|
DICTADD(t_dict, "type", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.flags);
|
||||||
|
DICTADD(t_dict, "flags", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.address_of);
|
||||||
|
DICTADD(t_dict, "address", temp);
|
||||||
|
|
||||||
|
temp = PyList_New(16);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
PyList_SET_ITEM(temp, i, PyInt_FromLong(v.assignment[i]);
|
||||||
|
|
||||||
|
DICTADD(t_dict, "assignment", temp);
|
||||||
|
|
||||||
|
return t_dict;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* BuildFrozenLiquidVein(DFHack::t_frozenliquidvein& v)
|
||||||
|
{
|
||||||
|
PyObject* t_dict;
|
||||||
|
PyObject *temp, *list;
|
||||||
|
|
||||||
|
t_dict = PyDict_New();
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.vtable);
|
||||||
|
DICTADD(t_dict, "vtable", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.address_of);
|
||||||
|
DICTADD(t_dict, "address", temp);
|
||||||
|
|
||||||
|
list = PyList_New(16);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
{
|
||||||
|
temp = PyList_New(16);
|
||||||
|
|
||||||
|
for(int j = 0; j < 16; j++)
|
||||||
|
PyList_SET_ITEM(temp, j, PyInt_FromLong(v.tiles[i][j]);
|
||||||
|
|
||||||
|
PyList_SET_ITEM(list, i, temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
DICTADD(t_dict, "tiles", list);
|
||||||
|
|
||||||
|
return t_dict;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* BuildSpatterVein(DFHack::t_spattervein& v)
|
||||||
|
{
|
||||||
|
PyObject* t_dict;
|
||||||
|
PyObject *temp, *list;
|
||||||
|
|
||||||
|
t_dict = PyDict_New();
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.vtable);
|
||||||
|
DICTADD(t_dict, "vtable", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.address_of);
|
||||||
|
DICTADD(t_dict, "address", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.mat1);
|
||||||
|
DICTADD(t_dict, "mat1", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.unk1);
|
||||||
|
DICTADD(t_dict, "unk1", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.mat2);
|
||||||
|
DICTADD(t_dict, "mat2", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(v.mat3);
|
||||||
|
DICTADD(t_dict, "mat3", temp);
|
||||||
|
|
||||||
|
list = PyList_New(16);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
{
|
||||||
|
temp = PyList_New(16);
|
||||||
|
|
||||||
|
for(int j = 0; j < 16; j++)
|
||||||
|
PyList_SET_ITEM(temp, j, PyInt_FromLong(v.intensity[i][j]);
|
||||||
|
|
||||||
|
PyList_SET_ITEM(list, i, temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
DICTADD(t_dict, "intensity", list);
|
||||||
|
|
||||||
|
return t_dict;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* BuildTileTypes40d(DFHack::tiletypes40d& types)
|
||||||
|
{
|
||||||
|
PyObject *list, *temp;
|
||||||
|
|
||||||
|
list = PyList_New(16);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
{
|
||||||
|
temp = PyList_New(16);
|
||||||
|
|
||||||
|
for(int j = 0; j < 16; j++)
|
||||||
|
PyList_SET_ITEM(temp, j, PyInt_FromLong(types[i][j]));
|
||||||
|
|
||||||
|
PyList_SET_ITEM(list, i, temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* BuildOccupancies40d(DFHack::occupancies40d& occ)
|
||||||
|
{
|
||||||
|
PyObject *list, *temp;
|
||||||
|
|
||||||
|
list = PyList_New(16);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
{
|
||||||
|
temp = PyList_New(16);
|
||||||
|
|
||||||
|
for(int j = 0; j < 16; j++)
|
||||||
|
PyList_SET_ITEM(temp, j, PyInt_FromLong(occ[i][j].whole));
|
||||||
|
|
||||||
|
PyList_SET_ITEM(list, i, temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* BuildDesignations40d(DFHack::designations40d& des)
|
||||||
|
{
|
||||||
|
PyObject *list, *temp;
|
||||||
|
|
||||||
|
list = PyList_New(16);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
{
|
||||||
|
temp = PyList_New(16);
|
||||||
|
|
||||||
|
for(int j = 0; j < 16; j++)
|
||||||
|
PyList_SET_ITEM(temp, j, PyInt_FromLong(des[i][j].whole));
|
||||||
|
|
||||||
|
PyList_SET_ITEM(list, i, temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* BuildBiomeIndices40d(DFHack::biome_indices40d& idx)
|
||||||
|
{
|
||||||
|
PyObject *list;
|
||||||
|
|
||||||
|
list = PyList_New(16);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
PyList_SET_ITEM(list, i, PyInt_FromLong(idx[i]);
|
||||||
|
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* BuildMapBlock40d(DFHack::mapblock40d& block)
|
||||||
|
{
|
||||||
|
PyObject* t_dict;
|
||||||
|
PyObject* temp;
|
||||||
|
|
||||||
|
t_dict = PyDict_New();
|
||||||
|
|
||||||
|
temp = BuildTileTypes40d(block.tiletypes);
|
||||||
|
DICTADD(t_dict, "tiletypes", temp);
|
||||||
|
|
||||||
|
temp = BuildDesignations40d(block.designation);
|
||||||
|
DICTADD(t_dict, "designation", temp);
|
||||||
|
|
||||||
|
temp = BuildOccupancies40d(block.occupancy);
|
||||||
|
DICTADD(t_dict, "occupancy", temp);
|
||||||
|
|
||||||
|
temp = BuildBiomeIdices40d(block.biome_indices);
|
||||||
|
DICTADD(t_dict, "biome_indices", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(block.origin);
|
||||||
|
DICTADD(t_dict, "origin", temp);
|
||||||
|
|
||||||
|
temp = PyInt_FromLong(block.blockflags.whole);
|
||||||
|
DICTADD(t_dict, "_blockflags", temp);
|
||||||
|
|
||||||
|
return t_dict;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct DF_Map
|
||||||
|
{
|
||||||
|
PyObject_HEAD
|
||||||
|
DFHack::Maps* m_Ptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
static PyObject* DF_Map_new(PyTypeObject* type, PyObject* args, PyObject* kwds)
|
||||||
|
{
|
||||||
|
DF_Map* self;
|
||||||
|
|
||||||
|
self = (DF_Map*)type->tp_alloc(type, 0);
|
||||||
|
|
||||||
|
if(self != NULL)
|
||||||
|
self->m_Ptr = NULL;
|
||||||
|
|
||||||
|
return (PyObject*)self;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int DF_Map_init(DF_Map* self, PyObject* args, PyObject* kwds)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void DF_Map_dealloc(DF_Map* self)
|
||||||
|
{
|
||||||
|
PySys_WriteStdout("map dealloc\n");
|
||||||
|
|
||||||
|
if(self != NULL)
|
||||||
|
{
|
||||||
|
PySys_WriteStdout("map not NULL\n");
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
PySys_WriteStdout("m_Ptr = %i\n", (int)self->m_Ptr);
|
||||||
|
|
||||||
|
delete self->m_Ptr;
|
||||||
|
|
||||||
|
PySys_WriteStdout("m_Ptr deleted\n");
|
||||||
|
|
||||||
|
self->m_Ptr = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
self->ob_type->tp_free((PyObject*)self);
|
||||||
|
}
|
||||||
|
|
||||||
|
PySys_WriteStdout("map dealloc done\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Type methods
|
||||||
|
|
||||||
|
static PyObject* DF_Map_Start(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(self->m_Ptr->Start())
|
||||||
|
Py_RETURN_TRUE;
|
||||||
|
else
|
||||||
|
Py_RETURN_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_Finish(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(self->m_Ptr->Finish())
|
||||||
|
Py_RETURN_TRUE;
|
||||||
|
else
|
||||||
|
Py_RETURN_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_IsValidBlock(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(!PyArg_ParseTuple(args, "III", &x, &y, &z))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if(self->m_Ptr->isValidBlock(x, y, z))
|
||||||
|
Py_RETURN_TRUE;
|
||||||
|
else
|
||||||
|
Py_RETURN_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_ReadTileTypes(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(!PyArg_ParseTuple(args, "III", &x, &y, &z))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
tiletypes40d t_types;
|
||||||
|
|
||||||
|
if(self->m_Ptr->ReadTileTypes(x, y, z, &t_types))
|
||||||
|
return BuildTileTypes40d(t_types);
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_ReadDesignations(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(!PyArg_ParseTuple(args, "III", &x, &y, &z))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
designations40d des;
|
||||||
|
|
||||||
|
if(self->m_Ptr->ReadDesignations(x, y, z, &des))
|
||||||
|
return BuildDesignations40d(des);
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_ReadOccupancy(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(!PyArg_ParseTuple(args, "III", &x, &y, &z))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
occupancies40d occ;
|
||||||
|
|
||||||
|
if(self->m_Ptr->ReadOccupancy(x, y, z, &occ))
|
||||||
|
return BuildOccupancies40d(occ);
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_ReadDirtyBit(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
bool bit = false;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(!PyArg_ParseTuple(args, "III", &x, &y, &z))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
self->m_Ptr->ReadDirtyBit(x, y, z, &bit)
|
||||||
|
|
||||||
|
if(bit)
|
||||||
|
Py_RETURN_TRUE;
|
||||||
|
else
|
||||||
|
Py_RETURN_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_ReadBlockFlags(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(!PyArg_ParseTuple(args, "III", &x, &y, &z))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
t_blockflags flags;
|
||||||
|
|
||||||
|
if(self->m_Ptr->ReadBlockFlags(x, y, z, &flags))
|
||||||
|
return PyInt_FromLong(flags.whole);
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject* DF_Map_ReadRegionOffsets(DF_Map* self, PyObject* args)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
if(!PyArg_ParseTuple(args, "III", &x, &y, &z))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
biome_indices40d biome;
|
||||||
|
|
||||||
|
if(self->m_Ptr->ReadRegionOffsets(x, y, z, &biome))
|
||||||
|
return BuildBiomeIndices40d(biome);
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Getter/Setter
|
||||||
|
|
||||||
|
static PyObject* DF_Map_getSize(DF_Map* self, void* closure)
|
||||||
|
{
|
||||||
|
uint32_t x, y, z;
|
||||||
|
|
||||||
|
if(self->m_Ptr != NULL)
|
||||||
|
{
|
||||||
|
self->m_Ptr->getSize(x, y, z);
|
||||||
|
|
||||||
|
return PyTuple_Pack(3, x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue