dfhack/tools/examples/buildingsdump.cpp

150 lines
4.8 KiB
C++

// Creature dump
#include <iostream>
#include <iomanip>
#include <sstream>
#include <climits>
#include <vector>
2010-06-04 16:02:02 -06:00
#include <stdio.h>
//using namespace std;
2010-06-04 16:02:02 -06:00
#define DFHACK_WANT_MISCUTILS
2010-05-25 22:48:23 -06:00
#include <DFHack.h>
int main (int argc,const char* argv[])
{
int lines = 16;
int mode = 0;
if (argc < 2 || argc > 3)
{
/*
cout << "usage:" << endl;
cout << argv[0] << " object_name [number of lines]" << endl;
#ifndef LINUX_BUILD
cout << "Done. Press any key to continue" << endl;
cin.ignore();
#endif
return 0;
*/
}
else if(argc == 3)
{
2010-06-04 16:02:02 -06:00
std::string s = argv[2]; //blah. I don't care
std::istringstream ins; // Declare an input string stream.
ins.str(s); // Specify string to read.
ins >> lines; // Reads the integers from the string.
mode = 1;
}
2010-06-04 16:02:02 -06:00
std::map <uint32_t, std::string> custom_workshop_types;
2010-05-23 15:06:10 -06:00
DFHack::ContextManager DFMgr ("Memory.xml");
DFHack::Context *DF;
try
{
2010-05-23 15:06:10 -06:00
DF = DFMgr.getSingleContext();
DF->Attach();
}
2010-06-04 16:02:02 -06:00
catch (std::exception& e)
{
2010-06-04 16:02:02 -06:00
std::cerr << e.what() << std::endl;
#ifndef LINUX_BUILD
cin.ignore();
#endif
return 1;
}
2010-04-12 16:03:29 -06:00
2010-05-23 15:06:10 -06:00
DFHack::memory_info * mem = DF->getMemoryInfo();
DFHack::Buildings * Bld = DF->getBuildings();
DFHack::Position * Pos = DF->getPosition();
uint32_t numBuildings;
if(Bld->Start(numBuildings))
{
2010-04-12 16:03:29 -06:00
Bld->ReadCustomWorkshopTypes(custom_workshop_types);
if(mode)
{
2010-06-04 16:02:02 -06:00
std::cout << numBuildings << std::endl;
std::vector < uint32_t > addresses;
for(uint32_t i = 0; i < numBuildings; i++)
{
DFHack::t_building temp;
Bld->Read(i, temp);
if(temp.type != 0xFFFFFFFF) // check if type isn't invalid
{
2010-06-04 16:02:02 -06:00
std::string typestr;
mem->resolveClassIDToClassname(temp.type, typestr);
2010-06-04 16:02:02 -06:00
std::cout << typestr << std::endl;
if(typestr == argv[1])
{
//cout << buildingtypes[temp.type] << " 0x" << hex << temp.origin << endl;
//hexdump(DF, temp.origin, 16);
2010-07-26 20:48:47 -06:00
addresses.push_back(temp.origin);
}
}
else
{
// couldn't translate type, print out the vtable
2010-06-04 16:02:02 -06:00
std::cout << "unknown vtable: " << temp.vtable << std::endl;
}
}
interleave_hex(DF,addresses,lines / 4);
}
else // mode
{
int32_t x,y,z;
Pos->getCursorCoords(x,y,z);
if(x != -30000)
{
for(uint32_t i = 0; i < numBuildings; i++)
{
DFHack::t_building temp;
Bld->Read(i, temp);
2010-05-23 15:06:10 -06:00
if( (uint32_t)x >= temp.x1
&& (uint32_t)x <= temp.x2
&& (uint32_t)y >= temp.y1
&& (uint32_t)y <= temp.y2
&& (uint32_t)z == temp.z
)
{
2010-06-04 16:02:02 -06:00
std::string typestr;
mem->resolveClassIDToClassname(temp.type, typestr);
printf("Address 0x%x, type %d (%s), %d/%d/%d\n",temp.origin, temp.type, typestr.c_str(), temp.x1,temp.y1,temp.z);
2010-04-09 16:24:41 -06:00
printf("Material %d %d\n", temp.material.type, temp.material.index);
2010-04-12 16:03:29 -06:00
int32_t custom;
if((custom = Bld->GetCustomWorkshopType(temp)) != -1)
{
printf("Custom workshop type %s (%d)\n",custom_workshop_types[custom].c_str(),custom);
}
hexdump(DF,temp.origin,120);
}
}
}
else
{
2010-06-04 16:02:02 -06:00
std::cout << numBuildings << std::endl;
for(uint32_t i = 0; i < numBuildings; i++)
{
DFHack::t_building temp;
Bld->Read(i, temp);
2010-06-04 16:02:02 -06:00
std::string typestr;
mem->resolveClassIDToClassname(temp.type, typestr);
printf("Address 0x%x, type %d (%s), %d/%d/%d\n",temp.origin, temp.type, typestr.c_str(), temp.x1,temp.y1,temp.z);
}
}
}
Bld->Finish();
}
else
{
2010-06-04 16:02:02 -06:00
std::cerr << "buildings not supported for this DF version" << std::endl;
}
2010-05-23 15:06:10 -06:00
DF->Detach();
#ifndef LINUX_BUILD
2010-06-04 16:02:02 -06:00
std::cout << "Done. Press any key to continue" << std::endl;
cin.ignore();
#endif
return 0;
}