Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Hyphen to indicate take input from os.Stdin #260

Open
fbaube opened this issue Jul 10, 2024 · 3 comments
Open

Hyphen to indicate take input from os.Stdin #260

fbaube opened this issue Jul 10, 2024 · 3 comments

Comments

@fbaube
Copy link

fbaube commented Jul 10, 2024

It is a Unix convention that a hyphen as a command line argument instructs a program to take input from standard input rather than from a named file.

Would it be possible to implement this ?

It certainly comes in handy when using a program with a pipe, or when pasting input.

@alexflint
Copy link
Owner

I use this convention quite often in programs I write using go-arg too. I've found it's best to implement at the level of the application using the library, rather than right within the library. I often have a string argument that is used as a filename, with a special case for when it's set to "-". Is this what you mean? Or is it that you would read lines from standard input to populate an argument?

@fbaube
Copy link
Author

fbaube commented Jul 12, 2024

I don't mean a file named "-".

I mean, one input source is standard input (rather than a named file).

Stdin could be coming from a pipe. Stdin could be coming from interactive typing (or pasting).

For example,

// GetStringFromStdin reads os.Stdin completely and returns a string.
func GetStringFromStdin() (string, error) {
        println("==> Reading from Stdin; press ^D right after a newline to end")
        bb, e := io.ReadAll(os.Stdin)
        if e != nil {
                return "", fmt.Errorf("Cannot read from Stdin: %w", e)
        }
        // MimeType = "text/plain"
        return string(bb), nil
}

HTH!

@CompuRoot
Copy link

I also think it would be better to handle such cases on application level instead of hard-coding - in to this library. Something like

func ReadFromFile(SrcFile string) (string, error) {
    // If the "File" flag is set, then use it as source, otherwise accept data via STDIN
    var buf []byte
    var err error

    if SrcFile != "" && SrcFile != "-" {
        // disable "G304 (CWE-22): Potential file inclusion via variable"
        // #nosec G304
        buf, err = os.ReadFile(SrcFile)
    } else if SrcFile == "-" || SrcFile == "" {
        buf, err = io.ReadAll(os.Stdin)
    }
    
    if err != nil {
        return string(buf), err
    }
    
    return string(buf), nil
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants