mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-19 21:53:51 +00:00
Add --name option to esmtool to print record with the given name
This commit is contained in:
parent
315f9a98ad
commit
89132ff741
1 changed files with 12 additions and 2 deletions
|
@ -59,6 +59,7 @@ struct Arguments
|
||||||
std::string outname;
|
std::string outname;
|
||||||
|
|
||||||
std::vector<std::string> types;
|
std::vector<std::string> types;
|
||||||
|
std::string name;
|
||||||
|
|
||||||
ESMData data;
|
ESMData data;
|
||||||
ESM::ESMReader reader;
|
ESM::ESMReader reader;
|
||||||
|
@ -78,6 +79,8 @@ bool parseOptions (int argc, char** argv, Arguments &info)
|
||||||
("type,t", bpo::value< std::vector<std::string> >(),
|
("type,t", bpo::value< std::vector<std::string> >(),
|
||||||
"Show only records of this type (four character record code). May "
|
"Show only records of this type (four character record code). May "
|
||||||
"be specified multiple times. Only affects dump mode.")
|
"be specified multiple times. Only affects dump mode.")
|
||||||
|
("name,n", bpo::value<std::string>(),
|
||||||
|
"Show only the record with this name. Only affects dump mode.")
|
||||||
("plain,p", "Print contents of dialogs, books and scripts. "
|
("plain,p", "Print contents of dialogs, books and scripts. "
|
||||||
"(skipped by default)"
|
"(skipped by default)"
|
||||||
"Only affects dump mode.")
|
"Only affects dump mode.")
|
||||||
|
@ -149,6 +152,8 @@ bool parseOptions (int argc, char** argv, Arguments &info)
|
||||||
|
|
||||||
if (variables.count("type") > 0)
|
if (variables.count("type") > 0)
|
||||||
info.types = variables["type"].as< std::vector<std::string> >();
|
info.types = variables["type"].as< std::vector<std::string> >();
|
||||||
|
if (variables.count("name") > 0)
|
||||||
|
info.name = variables["name"].as<std::string>();
|
||||||
|
|
||||||
info.mode = variables["mode"].as<std::string>();
|
info.mode = variables["mode"].as<std::string>();
|
||||||
if (!(info.mode == "dump" || info.mode == "clone" || info.mode == "comp"))
|
if (!(info.mode == "dump" || info.mode == "clone" || info.mode == "comp"))
|
||||||
|
@ -265,6 +270,8 @@ void loadCell(ESM::Cell &cell, ESM::ESMReader &esm, Arguments& info)
|
||||||
std::cout << " Gold value: '" << ref.mGoldValue << "'\n";
|
std::cout << " Gold value: '" << ref.mGoldValue << "'\n";
|
||||||
std::cout << " Blocked: '" << static_cast<int>(ref.mReferenceBlocked) << "'" << std::endl;
|
std::cout << " Blocked: '" << static_cast<int>(ref.mReferenceBlocked) << "'" << std::endl;
|
||||||
std::cout << " Deleted: " << deleted << std::endl;
|
std::cout << " Deleted: " << deleted << std::endl;
|
||||||
|
if (!ref.mKey.empty())
|
||||||
|
std::cout << " Key: '" << ref.mKey << "'" << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -358,6 +365,9 @@ int load(Arguments& info)
|
||||||
if (id.empty())
|
if (id.empty())
|
||||||
id = esm.getHNOString("INAM");
|
id = esm.getHNOString("INAM");
|
||||||
|
|
||||||
|
if (!info.name.empty() && !Misc::StringUtils::ciEqual(info.name, id))
|
||||||
|
interested = false;
|
||||||
|
|
||||||
if(!quiet && interested)
|
if(!quiet && interested)
|
||||||
std::cout << "\nRecord: " << n.toString()
|
std::cout << "\nRecord: " << n.toString()
|
||||||
<< " '" << id << "'\n";
|
<< " '" << id << "'\n";
|
||||||
|
@ -385,7 +395,7 @@ int load(Arguments& info)
|
||||||
record->load(esm);
|
record->load(esm);
|
||||||
if (!quiet && interested) record->print();
|
if (!quiet && interested) record->print();
|
||||||
|
|
||||||
if (record->getType().val == ESM::REC_CELL && loadCells) {
|
if (record->getType().val == ESM::REC_CELL && loadCells && interested) {
|
||||||
loadCell(record->cast<ESM::Cell>()->get(), esm, info);
|
loadCell(record->cast<ESM::Cell>()->get(), esm, info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue