mirror of
https://github.com/NixOS/nix
synced 2025-06-30 07:33:16 +02:00
Make subcommand construction in MultiCommand lazy
This commit is contained in:
parent
eb18aedccb
commit
a0de58f471
29 changed files with 73 additions and 282 deletions
|
@ -215,17 +215,15 @@ void Command::printHelp(const string & programName, std::ostream & out)
|
|||
}
|
||||
}
|
||||
|
||||
MultiCommand::MultiCommand(const std::vector<ref<Command>> & _commands)
|
||||
MultiCommand::MultiCommand(const Commands & commands)
|
||||
: commands(commands)
|
||||
{
|
||||
for (auto & command : _commands)
|
||||
commands.emplace(command->name(), command);
|
||||
|
||||
expectedArgs.push_back(ExpectedArg{"command", 1, true, [=](std::vector<std::string> ss) {
|
||||
assert(!command);
|
||||
auto i = commands.find(ss[0]);
|
||||
if (i == commands.end())
|
||||
throw UsageError("'%s' is not a recognised command", ss[0]);
|
||||
command = i->second;
|
||||
command = i->second();
|
||||
}});
|
||||
}
|
||||
|
||||
|
@ -246,10 +244,11 @@ void MultiCommand::printHelp(const string & programName, std::ostream & out)
|
|||
out << "Available commands:\n";
|
||||
|
||||
Table2 table;
|
||||
for (auto & command : commands) {
|
||||
auto descr = command.second->description();
|
||||
for (auto & i : commands) {
|
||||
auto command = i.second();
|
||||
auto descr = command->description();
|
||||
if (!descr.empty())
|
||||
table.push_back(std::make_pair(command.second->name(), descr));
|
||||
table.push_back(std::make_pair(command->name(), descr));
|
||||
}
|
||||
printTable(out, table);
|
||||
}
|
||||
|
|
|
@ -192,7 +192,12 @@ public:
|
|||
run() method. */
|
||||
struct Command : virtual Args
|
||||
{
|
||||
virtual std::string name() = 0;
|
||||
private:
|
||||
std::string _name;
|
||||
|
||||
public:
|
||||
std::string name() { return _name; }
|
||||
|
||||
virtual void prepare() { };
|
||||
virtual void run() = 0;
|
||||
|
||||
|
@ -209,7 +214,7 @@ struct Command : virtual Args
|
|||
void printHelp(const string & programName, std::ostream & out) override;
|
||||
};
|
||||
|
||||
typedef std::map<std::string, ref<Command>> Commands;
|
||||
typedef std::map<std::string, std::function<ref<Command>()>> Commands;
|
||||
|
||||
/* An argument parser that supports multiple subcommands,
|
||||
i.e. ‘<command> <subcommand>’. */
|
||||
|
@ -220,7 +225,7 @@ public:
|
|||
|
||||
std::shared_ptr<Command> command;
|
||||
|
||||
MultiCommand(const std::vector<ref<Command>> & commands);
|
||||
MultiCommand(const Commands & commands);
|
||||
|
||||
void printHelp(const string & programName, std::ostream & out) override;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue