Commit 48c108d5 authored by Matt Bell's avatar Matt Bell Committed by Juan Batiz-Benet

commands/cli: Made Parse return the resolved subcommand, even on error

parent 37f05a8b
......@@ -11,7 +11,7 @@ import (
// Parse parses the input commandline string (cmd, flags, and args).
// returns the corresponding command Request object.
func Parse(input []string, roots ...*cmds.Command) (cmds.Request, *cmds.Command, error) {
func Parse(input []string, roots ...*cmds.Command) (cmds.Request, *cmds.Command, *cmds.Command, error) {
var root, cmd *cmds.Command
var path, stringArgs []string
var opts map[string]interface{}
......@@ -22,7 +22,7 @@ func Parse(input []string, roots ...*cmds.Command) (cmds.Request, *cmds.Command,
p, i, c := parsePath(input, r)
o, s, err := parseOptions(i)
if err != nil {
return nil, nil, err
return nil, root, c, err
}
length := len(p)
......@@ -37,22 +37,22 @@ func Parse(input []string, roots ...*cmds.Command) (cmds.Request, *cmds.Command,
}
if maxLength == 0 {
return nil, nil, errors.New("Not a valid subcommand")
return nil, root, nil, errors.New("Not a valid subcommand")
}
args, err := parseArgs(stringArgs, cmd)
if err != nil {
return nil, nil, err
return nil, root, cmd, err
}
req := cmds.NewRequest(path, opts, args, cmd)
err = cmd.CheckArguments(req)
if err != nil {
return nil, nil, err
return nil, root, cmd, err
}
return req, root, nil
return req, root, cmd, nil
}
// parsePath separates the command path and the opts and args from a command string
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment