Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type RunOption ¶
type RunOption func(*runOptions)
RunOption is an option for Run.
func RunWithArgs ¶
RunWithArgs returns a new RunOption that sets the arguments other than the name.
The default is no arguments.
func RunWithDir ¶
RunWithDir returns a new RunOption that sets the working directory.
The default is the current working directory.
func RunWithEnv ¶
RunWithEnv returns a new RunOption that sets the environment variables.
The default is to use the single environment variable __EMPTY_ENV__=1 as we cannot explicitly set an empty environment with the exec package.
func RunWithStderr ¶
RunWithStderr returns a new RunOption that sets the stderr.
The default is the null device (os.DevNull).
func RunWithStdin ¶
RunWithStdin returns a new RunOption that sets the stdin.
The default is ioextended.DiscardReader.
func RunWithStdout ¶
RunWithStdout returns a new RunOption that sets the stdout.
The default is the null device (os.DevNull).
type Runner ¶
type Runner interface { // Run runs the external command. // // This should be used instead of exec.CommandContext(...).Run(). Run(ctx context.Context, name string, options ...RunOption) error }
Runner runs external commands.
A Runner will limit the number of concurrent commands, as well as explicitly set stdin, stdout, stderr, and env to nil/empty values if not set with options.
All external commands in buf MUST use command.Runner instead of exec.Command, exec.CommandContext.
type RunnerOption ¶
type RunnerOption func(*runner)
RunnerOption is an option for a new Runner.
func RunnerWithParallelism ¶
func RunnerWithParallelism(parallelism int) RunnerOption
RunnerWithParallelism returns a new Runner that sets the number of external commands that can be run concurrently.
The default is thread.Parallelism().