Tilesieve devel tool
parent
1bf5080828
commit
28059a7f35
@ -1 +1 @@
|
|||||||
Subproject commit bfc15c2083e525cb1f7a9dae6d0594c6bbcaff63
|
Subproject commit ce65a57dc89a9d6f422cfa92d774e5d84f3df884
|
@ -0,0 +1,83 @@
|
|||||||
|
// This is a generic plugin that does nothing useful apart from acting as an example... of a plugin that does nothing :D
|
||||||
|
|
||||||
|
// some headers required for a plugin. Nothing special, just the basics.
|
||||||
|
#include "Core.h"
|
||||||
|
#include <Console.h>
|
||||||
|
#include <Export.h>
|
||||||
|
#include <PluginManager.h>
|
||||||
|
#include <set>
|
||||||
|
// DF data structure definition headers
|
||||||
|
#include "DataDefs.h"
|
||||||
|
//#include "df/world.h"
|
||||||
|
|
||||||
|
using namespace DFHack;
|
||||||
|
using namespace df::enums;
|
||||||
|
|
||||||
|
// Here go all the command declarations...
|
||||||
|
// mostly to allow having the mandatory stuff on top of the file and commands on the bottom
|
||||||
|
command_result tilesieve (Core * c, std::vector <std::string> & parameters);
|
||||||
|
|
||||||
|
// A plugins must be able to return its name. This must correspond to the filename - skeleton.plug.so or skeleton.plug.dll
|
||||||
|
DFhackCExport const char * plugin_name ( void )
|
||||||
|
{
|
||||||
|
return "tilesieve";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Mandatory init function. If you have some global state, create it here.
|
||||||
|
DFhackCExport command_result plugin_init ( Core * c, std::vector <PluginCommand> &commands)
|
||||||
|
{
|
||||||
|
// Fill the command list with your commands.
|
||||||
|
commands.clear();
|
||||||
|
commands.push_back(PluginCommand(
|
||||||
|
"tilesieve", "Scan map for unknown tiles.",
|
||||||
|
tilesieve, false, /* true means that the command can't be used from non-interactive user interface */
|
||||||
|
// Extended help string. Used by CR_WRONG_USAGE and the help command:
|
||||||
|
" This command scans the whole map for tiles that aren't recognized yet.\n"
|
||||||
|
));
|
||||||
|
return CR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This is called right before the plugin library is removed from memory.
|
||||||
|
DFhackCExport command_result plugin_shutdown ( Core * c )
|
||||||
|
{
|
||||||
|
return CR_OK;
|
||||||
|
}
|
||||||
|
struct xyz
|
||||||
|
{
|
||||||
|
int x;
|
||||||
|
int y;
|
||||||
|
int z;
|
||||||
|
};
|
||||||
|
|
||||||
|
command_result tilesieve(DFHack::Core * c, std::vector<std::string> & params)
|
||||||
|
{
|
||||||
|
Console & con = c->con;
|
||||||
|
CoreSuspender suspend(c);
|
||||||
|
if (!Maps::IsValid())
|
||||||
|
{
|
||||||
|
c->con.printerr("Map is not available!\n");
|
||||||
|
return CR_FAILURE;
|
||||||
|
}
|
||||||
|
c->con.print("Scanning.\n");
|
||||||
|
std::set <df::tiletype> seen;
|
||||||
|
for (auto iter = world->map.map_blocks.begin(); iter != world->map.map_blocks.end(); iter++)
|
||||||
|
{
|
||||||
|
df::map_block *block = *iter;
|
||||||
|
df::tiletype tt;
|
||||||
|
const char * name = tileName(tt);
|
||||||
|
// for each tile in block
|
||||||
|
for (uint32_t x = 0; x < 16; x++) for (uint32_t y = 0; y < 16; y++)
|
||||||
|
{
|
||||||
|
tt = block.tiletypes[x][y];
|
||||||
|
if(tileShape(tt) != df::tiletype_shape::None )
|
||||||
|
continue;
|
||||||
|
if(name && strlen(name) != 0)
|
||||||
|
continue;
|
||||||
|
if(seen.count(tt))
|
||||||
|
continue;
|
||||||
|
seen.insert(tt);
|
||||||
|
c->con.print("Found tile %d @ %d %d %d\n", tt, seen.map_pos.x + x, seen.map_pos.y + y, seen.map_pos.z);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return CR_OK;
|
||||||
|
}
|
Loading…
Reference in New Issue