I'd like to implement subcommands to my program. I also need the ability to have different argument options for different subcommands. What's the best way to do this using Boost.Program_options?
Subcommands are used in programs like svn, git and apt-get.
For example in GIT some of the available subcommands are:
git status
git push
git add
git pull
My question is basically the same as this guy's: http://boost.2283326.n4.nabble.com/subcommands-with-program-options-like-svn-command-td2585537.html
If I understand the problem correctly, you want to parse command line options of the following form:
Here is my example solution. For clarity I'm going to omit any validation code, but hopefully you can see how it would be added fairly simply.
In this example, we have the "ls" subcommand, and possibly others. Each subcommand has some specific options, and in addition there are generic options. So let's start by parsing the generic options and the command name.
Notice that we've created a single positional option for the command name, and multiple positional options for the command options.
Now we branch on the relevant command name and re-parse. Instead of passing in the original
argc
andargv
we now pass in the unrecognized options, in the form of an array of strings. Thecollect_unrecognized
function can provide this - all we have to do is remove the (positional) command name and re-parse with the relevantoptions_description
.Note that we used the same
variables_map
for the command-specific options as for the generic ones. From this we can perform the relevant actions.The code fragments here are taken from a compilable source file which includes some unit tests. You can find it on gist here. Please feel free to download and play with it.
You can take the subcommand name off the command line using positional options - see this tutorial.
There doesn't seem to be any built-in support for subcommands - you will need to set the
allow_unregistered
option on the top-level parser, find the command name, then run it through a second parser to get any subcommand-specific options.