parent
839e255d17
commit
9589617d98
@ -0,0 +1,107 @@
|
||||
// Just show some position data
|
||||
|
||||
#include <iostream>
|
||||
#include <iomanip>
|
||||
#include <climits>
|
||||
#include <integers.h>
|
||||
#include <vector>
|
||||
#include <sstream>
|
||||
#include <ctime>
|
||||
#include <cstdio>
|
||||
using namespace std;
|
||||
|
||||
#include <DFTypes.h>
|
||||
#include <DFHackAPI.h>
|
||||
#include <DFProcess.h>
|
||||
#include <DFMemInfo.h>
|
||||
#include <DFVector.h>
|
||||
#include <DFTypes.h>
|
||||
#include <modules/Vegetation.h>
|
||||
#include <modules/Materials.h>
|
||||
#include <modules/Position.h>
|
||||
#include "miscutils.h"
|
||||
|
||||
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");
|
||||
try
|
||||
{
|
||||
DF.Attach();
|
||||
}
|
||||
catch (exception& e)
|
||||
{
|
||||
cerr << e.what() << endl;
|
||||
#ifndef LINUX_BUILD
|
||||
cin.ignore();
|
||||
#endif
|
||||
return 1;
|
||||
}
|
||||
|
||||
DFHack::Process* p = DF.getProcess();
|
||||
DFHack::memory_info* mem = DF.getMemoryInfo();
|
||||
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();
|
||||
|
||||
#ifndef LINUX_BUILD
|
||||
cout << "Done. Press any key to continue" << endl;
|
||||
cin.ignore();
|
||||
#endif
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue