/** * Book of Immolations, chapter 1, verse 35: * Armok emerged from the hellish depths and beheld the sunny realms for the first time. * And he cursed the plants and trees for their bloodless wood, turning them into ash and smoldering ruin. * Armok was pleased and great temples were built by the dwarves, for they shared his hatred for trees and plants. */ static command_result immolations (Core * c, do_what what, bool shrubs, bool trees, bool help) { static const char * what1 = "destroys"; static const char * what2 = "burns"; if(help) { c->con.print("Without any options, this command %s a plant under the cursor.\n" "Options:\n" "shrubs - affect all shrubs\n" "trees - affect all trees\n" "all - affect all plants\n", what == do_immolate? what2 : what1 ); return CR_OK; } c->Suspend(); DFHack::Maps *maps = c->getMaps(); if (!maps->Start()) { c->con.printerr( "Cannot get map info!\n"); c->Resume(); return CR_FAILURE; } DFHack::Gui * Gui = c->getGui(); uint32_t x_max, y_max, z_max; maps->getSize(x_max, y_max, z_max); MapExtras::MapCache map(maps); DFHack::Vegetation *veg = c->getVegetation(); if (!veg->all_plants) { std::cerr << "Unable to read vegetation!" << std::endl; return CR_FAILURE; } if(shrubs || trees) { int destroyed = 0; for(size_t i = 0 ; i < veg->all_plants->size(); i++) { DFHack::df_plant *p = veg->all_plants->at(i); if(shrubs && p->is_shrub || trees && !p->is_shrub) { if (what == do_immolate) p->is_burning = true; p->hitpoints = 0; destroyed ++; } } c->con.print("Praise Armok!\n"); } else { int32_t x,y,z; if(Gui->getCursorCoords(x,y,z)) { vector<DFHack::df_plant *> * alltrees; if(maps->ReadVegetation(x/16,y/16,z,alltrees)) { bool didit = false; for(size_t i = 0 ; i < alltrees->size(); i++) { DFHack::df_plant * tree = alltrees->at(i); if(tree->x == x && tree->y == y && tree->z == z) { if(what == do_immolate) tree->is_burning = true; tree->hitpoints = 0; didit = true; break; } } /* if(!didit) { cout << "----==== There's NOTHING there! ====----" << endl; } */ } } else { c->con.printerr("No mass destruction and no cursor...\n" ); } } // Cleanup veg->Finish(); maps->Finish(); c->Resume(); return CR_OK; }
DFhackCExport command_result df_grow (Core * c, vector <string> & parameters) { for(int i = 0; i < parameters.size();i++) { if(parameters[i] == "help" || parameters[i] == "?") { c->con.print("This command turns all living saplings into full-grown trees.\n"); return CR_OK; } } c->Suspend(); DFHack::Maps *maps = c->getMaps(); Console & con = c->con; if (!maps->Start()) { con.printerr("Cannot get map info!\n"); c->Resume(); return CR_FAILURE; } //maps->getSize(x_max, y_max, z_max); MapExtras::MapCache map(maps); DFHack::Vegetation *veg = c->getVegetation(); if (!veg->all_plants) { con.printerr("Unable to read vegetation!\n"); c->Resume(); return CR_FAILURE; } DFHack::Gui *Gui = c->getGui(); int32_t x,y,z; if(Gui->getCursorCoords(x,y,z)) { vector<DFHack::df_plant *> * alltrees; if(maps->ReadVegetation(x/16,y/16,z,alltrees)) { for(size_t i = 0 ; i < alltrees->size(); i++) { DFHack::df_plant * tree = alltrees->at(i); if(tree->x == x && tree->y == y && tree->z == z) { if(DFHack::tileShape(map.tiletypeAt(DFHack::DFCoord(x,y,z))) == DFHack::SAPLING_OK) { tree->grow_counter = DFHack::sapling_to_tree_threshold; } break; } } } } else { int grown = 0; for(size_t i = 0 ; i < veg->all_plants->size(); i++) { DFHack::df_plant *p = veg->all_plants->at(i); uint16_t ttype = map.tiletypeAt(DFHack::DFCoord(p->x,p->y,p->z)); if(!p->is_shrub && DFHack::tileShape(ttype) == DFHack::SAPLING_OK) { p->grow_counter = DFHack::sapling_to_tree_threshold; } } } // Cleanup veg->Finish(); maps->Finish(); c->Resume(); return CR_OK; }