Implement feature as a script, add magma option
Functionality is exactly equivalent to the plugin, but with a new option for players who want to enable magma furnaces without spoilers.develop
parent
2ba9ef04e3
commit
842b9c5191
@ -1,113 +0,0 @@
|
|||||||
// Map feature manager - list features and discover/undiscover individual ones
|
|
||||||
|
|
||||||
#include "Core.h"
|
|
||||||
#include "Console.h"
|
|
||||||
#include "Export.h"
|
|
||||||
#include "PluginManager.h"
|
|
||||||
|
|
||||||
#include "DataDefs.h"
|
|
||||||
#include "df/world.h"
|
|
||||||
#include "df/feature_init.h"
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
using std::vector;
|
|
||||||
using std::string;
|
|
||||||
using std::endl;
|
|
||||||
using namespace DFHack;
|
|
||||||
using namespace df::enums;
|
|
||||||
|
|
||||||
DFHACK_PLUGIN("feature");
|
|
||||||
REQUIRE_GLOBAL(world);
|
|
||||||
|
|
||||||
|
|
||||||
static command_result feature(color_ostream &out, vector <string> ¶meters)
|
|
||||||
{
|
|
||||||
CoreSuspender suspend;
|
|
||||||
|
|
||||||
if (parameters.empty())
|
|
||||||
return CR_WRONG_USAGE;
|
|
||||||
|
|
||||||
string cmd = parameters[0];
|
|
||||||
|
|
||||||
if (cmd == "list")
|
|
||||||
{
|
|
||||||
if (parameters.size() != 1)
|
|
||||||
return CR_WRONG_USAGE;
|
|
||||||
for (size_t i = 0; i < world->features.map_features.size(); i++)
|
|
||||||
{
|
|
||||||
df::feature_init *feature_init = world->features.map_features[i];
|
|
||||||
string name;
|
|
||||||
feature_init->getName(&name);
|
|
||||||
out.print("Feature #%i (\"%s\", type %s) is %s\n",
|
|
||||||
i, name.c_str(), ENUM_KEY_STR(feature_type, feature_init->getType()).c_str(),
|
|
||||||
feature_init->flags.is_set(feature_init_flags::Discovered) ? "discovered" : "hidden");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(cmd == "show")
|
|
||||||
{
|
|
||||||
if (parameters.size() != 2)
|
|
||||||
return CR_WRONG_USAGE;
|
|
||||||
size_t i = atoi(parameters[1].c_str());
|
|
||||||
if ((i < 0) || (i >= world->features.map_features.size()))
|
|
||||||
{
|
|
||||||
out.print("No such feature!\n");
|
|
||||||
return CR_FAILURE;
|
|
||||||
}
|
|
||||||
df::feature_init *feature_init = world->features.map_features[i];
|
|
||||||
if (feature_init->flags.is_set(feature_init_flags::Discovered))
|
|
||||||
{
|
|
||||||
out.print("Selected feature is already discovered!\n");
|
|
||||||
return CR_OK;
|
|
||||||
}
|
|
||||||
feature_init->flags.set(feature_init_flags::Discovered);
|
|
||||||
string name;
|
|
||||||
feature_init->getName(&name);
|
|
||||||
out.print("Feature #%i (\"%s\", type %s) is now discovered\n",
|
|
||||||
i, name.c_str(), ENUM_KEY_STR(feature_type, feature_init->getType()).c_str());
|
|
||||||
}
|
|
||||||
else if(cmd == "hide")
|
|
||||||
{
|
|
||||||
if (parameters.size() != 2)
|
|
||||||
return CR_WRONG_USAGE;
|
|
||||||
size_t i = atoi(parameters[1].c_str());
|
|
||||||
if ((i < 0) || (i >= world->features.map_features.size()))
|
|
||||||
{
|
|
||||||
out.print("No such feature!\n");
|
|
||||||
return CR_FAILURE;
|
|
||||||
}
|
|
||||||
df::feature_init *feature_init = world->features.map_features[i];
|
|
||||||
if (!feature_init->flags.is_set(feature_init_flags::Discovered))
|
|
||||||
{
|
|
||||||
out.print("Selected feature is already hidden!\n");
|
|
||||||
return CR_OK;
|
|
||||||
}
|
|
||||||
feature_init->flags.clear(feature_init_flags::Discovered);
|
|
||||||
string name;
|
|
||||||
feature_init->getName(&name);
|
|
||||||
out.print("Feature #%i (\"%s\", type %s) is now hidden\n",
|
|
||||||
i, name.c_str(), ENUM_KEY_STR(feature_type, feature_init->getType()).c_str());
|
|
||||||
}
|
|
||||||
else return CR_WRONG_USAGE;
|
|
||||||
|
|
||||||
return CR_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
DFhackCExport command_result plugin_init (color_ostream &out, std::vector <PluginCommand> &commands)
|
|
||||||
{
|
|
||||||
commands.push_back(PluginCommand(
|
|
||||||
"feature", "List or manage map features.", feature, false,
|
|
||||||
" feature list\n"
|
|
||||||
" Lists all map features in the region.\n"
|
|
||||||
" feature show <ID>\n"
|
|
||||||
" Marks the specified map feature as discovered.\n"
|
|
||||||
" feature hide <ID>\n"
|
|
||||||
" Marks the specified map feature as undiscovered.\n"
|
|
||||||
));
|
|
||||||
return CR_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
DFhackCExport command_result plugin_shutdown (color_ostream &out)
|
|
||||||
{
|
|
||||||
return CR_OK;
|
|
||||||
}
|
|
@ -0,0 +1,58 @@
|
|||||||
|
-- List or manage map features & enable magma furnaces
|
||||||
|
local help = [[=begin
|
||||||
|
|
||||||
|
feature
|
||||||
|
=======
|
||||||
|
Enables management of map features.
|
||||||
|
|
||||||
|
* Discovering a magma feature (magma pool, volcano, magma sea, or curious
|
||||||
|
underground structure) permits magma workshops and furnaces to be built.
|
||||||
|
* Discovering a cavern layer causes plants (trees, shrubs, and grass) from
|
||||||
|
that cavern to grow within your fortress.
|
||||||
|
|
||||||
|
Options:
|
||||||
|
|
||||||
|
:list: Lists all map features in your current embark by index.
|
||||||
|
:magma: Enable magma furnaces (discovers a random magma feature).
|
||||||
|
:show X: Marks the selected map feature as discovered.
|
||||||
|
:hide X: Marks the selected map feature as undiscovered.
|
||||||
|
|
||||||
|
=end]]
|
||||||
|
|
||||||
|
local map_features = df.global.world.features.map_features
|
||||||
|
|
||||||
|
function toggle_feature(idx, discovered)
|
||||||
|
map_features[tonumber(idx)].flags.Discovered = discovered
|
||||||
|
end
|
||||||
|
|
||||||
|
function list_features()
|
||||||
|
for idx, feat in ipairs(map_features) do
|
||||||
|
local kind = df.feature_type[feat:getType()]:gsub('_', ' ')
|
||||||
|
local discovered = feat.flags.Discovered and 'shown. ' or 'hidden.'
|
||||||
|
print('Feature #'..idx..' is '..discovered..' It is a "'..kind..'".')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function enable_magma_funaces()
|
||||||
|
for idx, feat in ipairs(map_features) do
|
||||||
|
if tostring(feat):find('magma') ~= nil then
|
||||||
|
toggle_feature(idx, true)
|
||||||
|
print('Enabled magma furnaces.')
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
dfhack.printerr('Could not find a magma-bearing feature.')
|
||||||
|
end
|
||||||
|
|
||||||
|
local args = {...}
|
||||||
|
if args[1] == 'list' then
|
||||||
|
list_features()
|
||||||
|
elseif args[1] == 'magma' then
|
||||||
|
enable_magma_funaces()
|
||||||
|
elseif args[1] == 'show' then
|
||||||
|
toggle_feature(args[2], true)
|
||||||
|
elseif args[1] == 'hide' then
|
||||||
|
toggle_feature(args[2], false)
|
||||||
|
else
|
||||||
|
print(help)
|
||||||
|
end
|
Loading…
Reference in New Issue