Commit 015bd06c authored by Matt Bell's avatar Matt Bell

commands/cli: Fixed stdin arg handling

parent 0b509098
...@@ -167,7 +167,7 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi ...@@ -167,7 +167,7 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi
fileArgs := make([]cmds.File, 0, numInputs) fileArgs := make([]cmds.File, 0, numInputs)
argDefIndex := 0 // the index of the current argument definition argDefIndex := 0 // the index of the current argument definition
for i, input := range inputs { for i := 0; i < numInputs; i++ {
// get the argument definiton (should be argDefs[argDefIndex], // get the argument definiton (should be argDefs[argDefIndex],
// but if argDefIndex > len(argDefs) we use the last argument definition) // but if argDefIndex > len(argDefs) we use the last argument definition)
var argDef cmds.Argument var argDef cmds.Argument
...@@ -187,7 +187,7 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi ...@@ -187,7 +187,7 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi
if argDef.Type == cmds.ArgString { if argDef.Type == cmds.ArgString {
if stdin == nil { if stdin == nil {
// add string values // add string values
stringArgs = append(stringArgs, input) stringArgs = append(stringArgs, inputs[0])
inputs = inputs[1:] inputs = inputs[1:]
} else if argDef.SupportsStdin { } else if argDef.SupportsStdin {
...@@ -204,7 +204,7 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi ...@@ -204,7 +204,7 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi
} else if argDef.Type == cmds.ArgFile { } else if argDef.Type == cmds.ArgFile {
if stdin == nil { if stdin == nil {
// treat stringArg values as file paths // treat stringArg values as file paths
path := input path := inputs[0]
inputs = inputs[1:] inputs = inputs[1:]
file, err := os.Open(path) file, err := os.Open(path)
...@@ -220,17 +220,17 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi ...@@ -220,17 +220,17 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi
if stat.IsDir() { if stat.IsDir() {
if !argDef.Recursive { if !argDef.Recursive {
err = fmt.Errorf("Invalid path '%s', argument '%s' does not support directories", err = fmt.Errorf("Invalid path '%s', argument '%s' does not support directories",
input, argDef.Name) path, argDef.Name)
return nil, nil, err return nil, nil, err
} }
if !recursive { if !recursive {
err = fmt.Errorf("'%s' is a directory, use the '-%s' flag to specify directories", err = fmt.Errorf("'%s' is a directory, use the '-%s' flag to specify directories",
input, cmds.RecShort) path, cmds.RecShort)
return nil, nil, err return nil, nil, err
} }
} }
fileArg, err := getFile(file, input) fileArg, err := getFile(file, path)
if err != nil { if err != nil {
return nil, nil, err return nil, nil, err
} }
......
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