2010-03-05 14:19:27 -07:00
|
|
|
// Just show some position data
|
|
|
|
|
|
|
|
#include <iostream>
|
2010-04-07 04:49:37 -06:00
|
|
|
#include <iomanip>
|
2010-03-05 14:19:27 -07:00
|
|
|
#include <climits>
|
|
|
|
#include <integers.h>
|
|
|
|
#include <vector>
|
|
|
|
#include <sstream>
|
|
|
|
#include <ctime>
|
2010-04-06 05:05:54 -06:00
|
|
|
#include <cstdio>
|
2010-03-05 14:19:27 -07:00
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
#include <DFTypes.h>
|
|
|
|
#include <DFHackAPI.h>
|
|
|
|
#include <DFProcess.h>
|
2010-03-14 06:37:39 -06:00
|
|
|
#include <DFMemInfo.h>
|
2010-04-02 07:47:08 -06:00
|
|
|
#include <DFVector.h>
|
2010-04-06 05:05:54 -06:00
|
|
|
#include <DFTypes.h>
|
2010-04-07 04:49:37 -06:00
|
|
|
#include <modules/Vegetation.h>
|
|
|
|
#include <modules/Materials.h>
|
|
|
|
#include <modules/Position.h>
|
2010-04-02 07:47:08 -06:00
|
|
|
|
|
|
|
void DumpObjStr0Vector (const char * name, DFHack::Process *p, uint32_t addr)
|
|
|
|
{
|
|
|
|
cout << "----==== " << name << " ====----" << endl;
|
|
|
|
DFHack::DfVector vect(p,addr,4);
|
|
|
|
for(int i = 0; i < vect.getSize();i++)
|
|
|
|
{
|
|
|
|
uint32_t addr = *(uint32_t *) vect[i];
|
|
|
|
cout << p->readSTLString(addr) << endl;
|
|
|
|
}
|
|
|
|
cout << endl;
|
|
|
|
}
|
2010-04-06 05:05:54 -06:00
|
|
|
void DumpObjVtables (const char * name, DFHack::Process *p, uint32_t addr)
|
|
|
|
{
|
|
|
|
cout << "----==== " << name << " ====----" << endl;
|
|
|
|
DFHack::DfVector vect(p,addr,4);
|
|
|
|
for(int i = 0; i < vect.getSize();i++)
|
|
|
|
{
|
|
|
|
uint32_t addr = *(uint32_t *) vect[i];
|
|
|
|
uint32_t vptr = p->readDWord(addr);
|
|
|
|
cout << p->readClassName(vptr) << endl;
|
|
|
|
}
|
|
|
|
cout << endl;
|
|
|
|
}
|
2010-04-02 07:47:08 -06:00
|
|
|
void DumpDWordVector (const char * name, DFHack::Process *p, uint32_t addr)
|
|
|
|
{
|
|
|
|
cout << "----==== " << name << " ====----" << endl;
|
|
|
|
DFHack::DfVector vect(p,addr,4);
|
|
|
|
for(int i = 0; i < vect.getSize();i++)
|
|
|
|
{
|
|
|
|
uint32_t number = *(uint32_t *) vect[i];
|
|
|
|
cout << number << endl;
|
|
|
|
}
|
|
|
|
cout << endl;
|
|
|
|
}
|
2010-03-05 14:19:27 -07:00
|
|
|
|
2010-04-07 04:49:37 -06:00
|
|
|
/*
|
|
|
|
address = absolute address of dump start
|
|
|
|
length = length in lines. 1 line = 16 bytes
|
|
|
|
*/
|
|
|
|
void hexdump (DFHack::API& DF, uint32_t address, uint32_t length)
|
|
|
|
{
|
|
|
|
char *buf = new char[length * 16];
|
|
|
|
|
|
|
|
DF.ReadRaw(address, length * 16, (uint8_t *) buf);
|
|
|
|
for (int i = 0; i < length; i++)
|
|
|
|
{
|
|
|
|
// leading offset
|
|
|
|
cout << "0x" << hex << setw(4) << i*16 << " ";
|
|
|
|
// groups
|
|
|
|
for(int j = 0; j < 4; j++)
|
|
|
|
{
|
|
|
|
// bytes
|
|
|
|
for(int k = 0; k < 4; k++)
|
|
|
|
{
|
|
|
|
int idx = i * 16 + j * 4 + k;
|
|
|
|
|
|
|
|
cout << hex << setw(2) << int(static_cast<unsigned char>(buf[idx])) << " ";
|
|
|
|
}
|
|
|
|
cout << " ";
|
|
|
|
}
|
|
|
|
cout << endl;
|
|
|
|
}
|
|
|
|
delete buf;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-03-05 14:19:27 -07:00
|
|
|
int main (int numargs, const char ** args)
|
|
|
|
{
|
|
|
|
uint32_t addr;
|
|
|
|
if (numargs == 2)
|
|
|
|
{
|
|
|
|
istringstream input (args[1],istringstream::in);
|
|
|
|
input >> std::hex >> addr;
|
|
|
|
}
|
|
|
|
DFHack::API DF("Memory.xml");
|
2010-03-26 06:01:46 -06:00
|
|
|
try
|
2010-03-05 14:19:27 -07:00
|
|
|
{
|
2010-03-26 06:01:46 -06:00
|
|
|
DF.Attach();
|
2010-03-05 14:19:27 -07:00
|
|
|
}
|
2010-03-26 06:01:46 -06:00
|
|
|
catch (exception& e)
|
2010-03-05 14:19:27 -07:00
|
|
|
{
|
2010-03-26 06:01:46 -06:00
|
|
|
cerr << e.what() << endl;
|
|
|
|
#ifndef LINUX_BUILD
|
|
|
|
cin.ignore();
|
2010-03-05 14:19:27 -07:00
|
|
|
#endif
|
2010-03-26 06:01:46 -06:00
|
|
|
return 1;
|
2010-03-05 14:19:27 -07:00
|
|
|
}
|
2010-03-26 06:01:46 -06:00
|
|
|
|
|
|
|
DFHack::Process* p = DF.getProcess();
|
|
|
|
DFHack::memory_info* mem = DF.getMemoryInfo();
|
2010-04-02 07:47:08 -06:00
|
|
|
//const vector<string> * names = mem->getClassIDMapping();
|
2010-04-06 05:05:54 -06:00
|
|
|
/*
|
|
|
|
string name="Stuff";
|
|
|
|
cout << "----==== " << name << " ====----" << endl;
|
|
|
|
DFHack::DfVector vect(p,0x165b290,4);
|
|
|
|
for(int i = 0; i < vect.getSize();i++)
|
|
|
|
{
|
|
|
|
uint32_t addr = *(uint32_t *) vect[i];
|
|
|
|
DFHack::t_construction_df40d constr;
|
|
|
|
DF.ReadRaw(addr, sizeof(constr), (uint8_t *) &constr);
|
|
|
|
printf("0x%x %dX %dY %dZ: %d:%d\n", addr, constr.x, constr.y, constr.z,
|
|
|
|
constr.material.type,constr.material.index);
|
|
|
|
}
|
2010-04-02 07:47:08 -06:00
|
|
|
|
|
|
|
|
2010-04-06 05:05:54 -06:00
|
|
|
cout << endl;
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
DumpObjVtables("Constructions?",p,0x165b278);
|
|
|
|
DumpObjVtables("Constructions?",p,0x166edb8);
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
DumpObjStr0Vector("Material templates",p, mem->getAddress("mat_templates"));
|
|
|
|
*/
|
2010-04-07 04:49:37 -06:00
|
|
|
/*
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Inorganics",p, mem->getAddress("mat_inorganics"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-06 05:05:54 -06:00
|
|
|
cout << "----==== Inorganics ====----" << endl;
|
|
|
|
DFHack::DfVector vect(p,addr,4);
|
|
|
|
for(int i = 0; i < vect.getSize();i++)
|
|
|
|
{
|
|
|
|
uint32_t addr = *(uint32_t *) vect[i];
|
|
|
|
cout << p->readSTLString(addr) << endl;
|
|
|
|
}
|
|
|
|
cout << endl;
|
2010-04-07 04:49:37 -06:00
|
|
|
*/
|
2010-04-06 05:05:54 -06:00
|
|
|
/*
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Organics - all",p, mem->getAddress("mat_organics_all"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Organics - plants",p, mem->getAddress("mat_organics_plants"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpDWordVector("Maybe map between all organics and plants",p, mem->getAddress("mat_unk1_numbers"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Trees/wood",p, mem->getAddress("mat_organics_trees"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpDWordVector("Maybe map between all organics and trees",p, mem->getAddress("mat_unk2_numbers"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Body material templates",p, mem->getAddress("mat_body_material_templates"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Body detail plans",p, mem->getAddress("mat_body_detail_plans"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Bodies",p, mem->getAddress("mat_bodies"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Bodygloss",p, mem->getAddress("mat_bodygloss"));
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-04-02 14:00:33 -06:00
|
|
|
DumpObjStr0Vector("Creature variations",p, mem->getAddress("mat_creature_variations"));
|
|
|
|
|
|
|
|
DumpObjStr0Vector("Creature types",p, mem->getAddress("mat_creature_types"));
|
2010-04-06 05:05:54 -06:00
|
|
|
*/
|
2010-04-07 04:49:37 -06:00
|
|
|
DFHack::Position * pos = DF.getPosition();
|
|
|
|
DFHack::Vegetation * v = DF.getVegetation();
|
|
|
|
DFHack::Materials * mat = DF.getMaterials();
|
|
|
|
vector<DFHack::t_matgloss> organics;
|
|
|
|
mat->ReadOrganicMaterials(organics);
|
|
|
|
|
|
|
|
int32_t x,y,z;
|
|
|
|
pos->getCursorCoords(x,y,z);
|
|
|
|
|
|
|
|
|
|
|
|
uint32_t numVegs = 0;
|
|
|
|
v->Start(numVegs);
|
|
|
|
if(x == -30000)
|
|
|
|
{
|
|
|
|
cout << "----==== Trees ====----" << endl;
|
|
|
|
for(uint32_t i =0; i < numVegs; i++)
|
|
|
|
{
|
|
|
|
DFHack::t_tree tree;
|
|
|
|
v->Read(i,tree);
|
|
|
|
printf("%d/%d/%d, %d:%d\n",tree.x,tree.y,tree.z,tree.type,tree.material);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
cout << "----==== Tree at "<< x << "/" << y << "/" << z << " ====----" << endl;
|
|
|
|
for(uint32_t i =0; i < numVegs; i++)
|
|
|
|
{
|
|
|
|
DFHack::t_tree tree;
|
|
|
|
v->Read(i,tree);
|
|
|
|
if(tree.x == x && tree.y == y && tree.z == z)
|
|
|
|
{
|
|
|
|
printf("%d:%d = ",tree.type,tree.material);
|
|
|
|
if(tree.type == 1 || tree.type == 3)
|
|
|
|
{
|
|
|
|
cout << "near-water ";
|
|
|
|
}
|
|
|
|
cout << organics[tree.material].id << " ";
|
|
|
|
if(tree.type == 0 || tree.type == 1)
|
|
|
|
{
|
|
|
|
cout << "tree";
|
|
|
|
}
|
|
|
|
if(tree.type == 2 || tree.type == 3)
|
|
|
|
{
|
|
|
|
cout << "shrub";
|
|
|
|
}
|
|
|
|
cout << endl;
|
|
|
|
printf("Address: 0x%x\n", tree.address);
|
|
|
|
hexdump(DF,tree.address,13);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
v->Finish();
|
2010-04-02 07:47:08 -06:00
|
|
|
|
2010-03-05 14:19:27 -07:00
|
|
|
#ifndef LINUX_BUILD
|
|
|
|
cout << "Done. Press any key to continue" << endl;
|
|
|
|
cin.ignore();
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|