2011-10-29 19:50:29 -06:00
|
|
|
// Dry Buckets : Remove all "water" objects from buckets scattered around the fortress
|
|
|
|
#include <iostream>
|
|
|
|
#include <iomanip>
|
|
|
|
#include <sstream>
|
|
|
|
#include <climits>
|
|
|
|
#include <vector>
|
|
|
|
#include <set>
|
|
|
|
using namespace std;
|
|
|
|
|
2011-12-31 04:48:42 -07:00
|
|
|
#include "Core.h"
|
|
|
|
#include <Console.h>
|
|
|
|
#include <Export.h>
|
|
|
|
#include <PluginManager.h>
|
2011-10-29 19:50:29 -06:00
|
|
|
#include <vector>
|
|
|
|
#include <string>
|
|
|
|
#include <algorithm>
|
2011-12-31 04:48:42 -07:00
|
|
|
#include <modules/Items.h>
|
2011-10-29 19:50:29 -06:00
|
|
|
|
|
|
|
using namespace DFHack;
|
|
|
|
|
|
|
|
DFhackCExport command_result df_drybuckets (Core * c, vector <string> & parameters);
|
|
|
|
|
|
|
|
DFhackCExport const char * plugin_name ( void )
|
|
|
|
{
|
|
|
|
return "drybuckets";
|
|
|
|
}
|
|
|
|
|
|
|
|
DFhackCExport command_result plugin_init ( Core * c, std::vector <PluginCommand> &commands)
|
|
|
|
{
|
|
|
|
commands.clear();
|
|
|
|
commands.push_back(PluginCommand("drybuckets", "Removes water from buckets.", df_drybuckets));
|
|
|
|
return CR_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
DFhackCExport command_result plugin_shutdown ( Core * c )
|
|
|
|
{
|
|
|
|
return CR_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
DFhackCExport command_result df_drybuckets (Core * c, vector <string> & parameters)
|
|
|
|
{
|
|
|
|
if(parameters.size() > 0)
|
|
|
|
{
|
|
|
|
string & p = parameters[0];
|
|
|
|
if(p == "?" || p == "help")
|
|
|
|
{
|
|
|
|
c->con.print("This utility removes all objects of type LIQUID_MISC:NONE and material WATER:NONE - that is, water stored in buckets.\n");
|
|
|
|
return CR_OK;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
c->Suspend();
|
|
|
|
DFHack::Items * Items = c->getItems();
|
|
|
|
|
|
|
|
vector <df_item *> p_items;
|
|
|
|
if(!Items->readItemVector(p_items))
|
|
|
|
{
|
|
|
|
c->con.printerr("Can't access the item vector.\n");
|
|
|
|
c->Resume();
|
|
|
|
return CR_FAILURE;
|
|
|
|
}
|
|
|
|
std::size_t numItems = p_items.size();
|
|
|
|
|
|
|
|
int dried_total = 0;
|
|
|
|
for (std::size_t i = 0; i < numItems; i++)
|
|
|
|
{
|
|
|
|
df_item *item = p_items[i];
|
2011-10-30 14:32:43 -06:00
|
|
|
if ((item->getType() == Items::LIQUID_MISC) && (item->getMaterial() == Materials::WATER))
|
2011-10-29 19:50:29 -06:00
|
|
|
{
|
|
|
|
item->flags.garbage_colect = 1;
|
|
|
|
dried_total++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
c->Resume();
|
|
|
|
c->con.print("Done. %d buckets of water emptied.\n", dried_total);
|
|
|
|
return CR_OK;
|
|
|
|
}
|