70 lines
1.9 KiB
C++
70 lines
1.9 KiB
C++
// This program exports the entire map from DF. Takes roughly 6.6 seconds for 1000 cycles on my Linux machine. ~px
|
|
|
|
#include <iostream>
|
|
#include <integers.h>
|
|
#include <vector>
|
|
#include <ctime>
|
|
using namespace std;
|
|
|
|
#include <DFTypes.h>
|
|
#include <DFHackAPI.h>
|
|
|
|
int main (void)
|
|
{
|
|
time_t start, end;
|
|
double time_diff;
|
|
|
|
uint32_t x_max,y_max,z_max;
|
|
uint32_t num_blocks = 0;
|
|
uint32_t bytes_read = 0;
|
|
uint16_t tiletypes[16][16];
|
|
t_designation designations[16][16];
|
|
t_occupancy occupancies[16][16];
|
|
|
|
DFHackAPI *pDF = CreateDFHackAPI("Memory.xml");
|
|
DFHackAPI &DF = *pDF;
|
|
if(!DF.Attach())
|
|
{
|
|
cerr << "DF not found" << endl;
|
|
return 1;
|
|
}
|
|
DF.InitMap();
|
|
DF.getSize(x_max,y_max,z_max);
|
|
|
|
time(&start);
|
|
for(uint32_t i = 0; i< 1000;i++)
|
|
{
|
|
if((i % 10) == 0)
|
|
{
|
|
int percentage = i / 10;
|
|
cout << percentage << endl;
|
|
}
|
|
for(uint32_t x = 0; x< x_max;x++)
|
|
{
|
|
for(uint32_t y = 0; y< y_max;y++)
|
|
{
|
|
for(uint32_t z = 0; z< z_max;z++)
|
|
{
|
|
if(DF.isValidBlock(x,y,z))
|
|
{
|
|
DF.ReadTileTypes(x,y,z, (uint16_t *) tiletypes);
|
|
DF.ReadDesignations(x,y,z, (uint32_t *) designations);
|
|
DF.ReadOccupancy(x,y,z, (uint32_t *) occupancies);
|
|
num_blocks ++;
|
|
bytes_read += 256 * (4 + 4 + 2);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
DF.Detach();
|
|
time(&end);
|
|
time_diff = difftime(end, start);
|
|
cout << num_blocks << " blocks read" << endl;
|
|
cout << bytes_read / (1024 * 1024) << " MB" << endl;
|
|
cout << "map export tests done in " << time_diff << " seconds." << endl;
|
|
cout << "Press any key to continue" << endl;
|
|
cin.ignore();
|
|
delete pDF;
|
|
return 0;
|
|
} |