Commit da4e54c3 authored by Jakub Sztandera's avatar Jakub Sztandera

Change stdin handling to be only used if needed

or if user asks for it

License: MIT
Signed-off-by: default avatarJakub Sztandera <kubuxu@protonmail.ch>
parent 79e9bd84
...@@ -244,15 +244,6 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi ...@@ -244,15 +244,6 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi
stdin = nil stdin = nil
} }
// check if stdin is coming from terminal or is being piped in
if stdin != nil {
if term, err := isTerminal(stdin); err != nil {
return nil, nil, err
} else if term {
stdin = nil // set to nil so we ignore it
}
}
// count required argument definitions // count required argument definitions
numRequired := 0 numRequired := 0
for _, argDef := range argDefs { for _, argDef := range argDefs {
...@@ -293,9 +284,18 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi ...@@ -293,9 +284,18 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi
numRequired-- numRequired--
} }
fillingVariadic := argDefIndex+1 > len(argDefs)
var err error var err error
if argDef.Type == cmds.ArgString { if argDef.Type == cmds.ArgString {
if stdin == nil { if len(inputs) > 0 {
// If argument is "-" use stdin
if inputs[0] == "-" && argDef.SupportsStdin {
stringArgs, stdin, err = appendStdinAsString(stringArgs, stdin)
if err != nil {
return nil, nil, err
}
}
// add string values // add string values
stringArgs, inputs = appendString(stringArgs, inputs) stringArgs, inputs = appendString(stringArgs, inputs)
} else if !argDef.SupportsStdin { } else if !argDef.SupportsStdin {
...@@ -307,35 +307,39 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi ...@@ -307,35 +307,39 @@ func parseArgs(inputs []string, stdin *os.File, argDefs []cmds.Argument, recursi
stringArgs, inputs = appendString(stringArgs, inputs) stringArgs, inputs = appendString(stringArgs, inputs)
} else { } else {
if len(inputs) > 0 { if stdin != nil && argDef.Required && !fillingVariadic {
// don't use stdin if we have inputs
stdin = nil
} else {
// if we have a stdin, read it in and use the data as a string value // if we have a stdin, read it in and use the data as a string value
stringArgs, stdin, err = appendStdinAsString(stringArgs, stdin) stringArgs, stdin, err = appendStdinAsString(stringArgs, stdin)
if err != nil { if err != nil {
return nil, nil, err return nil, nil, err
} }
} else {
break
} }
} }
} else if argDef.Type == cmds.ArgFile { } else if argDef.Type == cmds.ArgFile {
if stdin == nil || !argDef.SupportsStdin { if len(inputs) > 0 {
// treat stringArg values as file paths // treat stringArg values as file paths
fpath := inputs[0] fpath := inputs[0]
inputs = inputs[1:] inputs = inputs[1:]
file, err := appendFile(fpath, argDef, recursive, hidden) var file files.File
var err error
if fpath == "-" {
file = files.NewReaderFile("", "", stdin, nil)
} else {
file, err = appendFile(fpath, argDef, recursive, hidden)
}
if err != nil { if err != nil {
return nil, nil, err return nil, nil, err
} }
fileArgs[fpath] = file fileArgs[fpath] = file
} else { } else {
if len(inputs) > 0 { if stdin != nil && argDef.SupportsStdin &&
// don't use stdin if we have inputs argDef.Required && !fillingVariadic {
stdin = nil
} else {
// if we have a stdin, create a file from it
fileArgs[""] = files.NewReaderFile("", "", stdin, nil) fileArgs[""] = files.NewReaderFile("", "", stdin, nil)
} else {
break
} }
} }
} }
...@@ -431,16 +435,3 @@ func appendFile(fpath string, argDef *cmds.Argument, recursive, hidden bool) (fi ...@@ -431,16 +435,3 @@ func appendFile(fpath string, argDef *cmds.Argument, recursive, hidden bool) (fi
return files.NewSerialFile(path.Base(fpath), fpath, hidden, stat) return files.NewSerialFile(path.Base(fpath), fpath, hidden, stat)
} }
// isTerminal returns true if stdin is a Stdin pipe (e.g. `cat file | ipfs`),
// and false otherwise (e.g. nothing is being piped in, so stdin is
// coming from the terminal)
func isTerminal(stdin *os.File) (bool, error) {
stat, err := stdin.Stat()
if err != nil {
return false, err
}
// if stdin is a CharDevice, return true
return ((stat.Mode() & os.ModeCharDevice) != 0), nil
}
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