Interface CommandBuilder<B extends CommandBuilder<B>>
- All Superinterfaces:
CommandBuilderSupport<B>
- All Known Subinterfaces:
ScmCommandBuilder<B>
arguments
.
As this builder is free-form, it is left to the caller to ensure the validity of the command being built. This includes, among other things:
- the arguments provided
- the order the arguments are provided in
- the environment variables defined
- whether an
input handler
is supported
Methods for removing property values have two possible prefixes, where each property will only provide one:
- clear: Removes any set value, for properties that are not required
- default: Replaces any set value with an appropriate default, for properties that are required
About arguments: Each call to a method accepting an argument is expected to be provided a single argument. Providing multiple arguments separated by a space will cause the executed command to fail. Consider the following example:
CommandBuilder<Void> builder = ...;
builder.command("someCommand").argument("a b").build(someOutputHandler).call();
The argument array for the executed command will contain a single entry, "a b"
, not two entries
"a"
and "b"
. This is likely to result in usage exceptions
. This
applies to:
argument(String)
argumentAfter(String, String)
argumentAt(int, String)
argumentBefore(String, String)
rawArgument(String)
rawArgumentAfter(String, String)
rawArgumentAt(int, String)
rawArgumentBefore(String, String)
About whitespace: In general, leading and trailing whitespace for most arguments is usually a mistake, and likely to result in the command failing unexpectedly. When typing commands into a shell, the shell typically consumes leading and trailing whitespace. That behavior is emulated by the following methods:
argument(String)
argumentAfter(String, String)
argumentAt(int, String)
argumentBefore(String, String)
rawArgument(String)
rawArgumentAfter(String, String)
rawArgumentAt(int, String)
rawArgumentBefore(String, String)
Warning: Command builders are not thread-safe. Each builder should be used on a single thread. If multiple threads require builders, each thread should construct its own. Chained builders returned from any method on builder interfaces are attached to their originating build and share threading semantics. This means calling builder methods and passing the returned objects to different threads is also not supported.
-
Method Summary
Modifier and TypeMethodDescriptionAppends the provided argument, with leading and trailing whitespace trimmedargumentAfter
(String anchor, String argument) Inserts the provided argument, with leading and trailing whitespace trimmed, immediately after the specified anchor if the anchor can be found.argumentAt
(int index, String argument) Inserts the provided argument, with leading and trailing whitespace trimmed, at the specified index.argumentBefore
(String anchor, String argument) Inserts the provided argument, with leading and trailing whitespace trimmed, immediately before the specified anchor if the anchor can be found.Clears any arguments which have been set.Clears theinput handler
, if one has been set.Applies the defaulterror handler
, which will collect any output written to the error stream and provide that output to theexit handler
.errorHandler
(CommandErrorHandler value) Sets theerror handler
which will be used to process any output written to the error stream as the command runs.inputHandler
(CommandInputHandler value) Sets theinput handler
which will be used to feed data to the command's input stream.rawArgument
(String argument) Appends the provided argument, verbatimrawArgumentAfter
(String anchor, String argument) Inserts the provided argument, verbatim, immediately after the specified anchor if the anchor can be found.rawArgumentAt
(int index, String argument) Inserts the provided argument, verbatim, at the specified index.rawArgumentBefore
(String anchor, String argument) Inserts the provided argument, verbatim, immediately before the specified anchor if the anchor can be found.Methods inherited from interface com.atlassian.bitbucket.scm.CommandBuilderSupport
build, clearEnvironment, defaultExitHandler, exitHandler, removeEnvironment, withEnvironment
-
Method Details
-
argument
Appends the provided argument, with leading and trailing whitespace trimmedNote: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
argument
- the argument to append to the command- Returns:
this
- Throws:
IllegalArgumentException
- if the providedargument
is empty or blankNullPointerException
- if the providedargument
isnull
-
argumentAfter
Inserts the provided argument, with leading and trailing whitespace trimmed, immediately after the specified anchor if the anchor can be found. Otherwise, the argument is appended at the end.Note: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
anchor
- the argument serving as the anchor for the new argumentargument
- the argument to add immediately after the specified anchor- Returns:
this
- Throws:
IllegalArgumentException
- if the providedargument
is empty or blankNullPointerException
- if the providedargument
isnull
-
argumentAt
Inserts the provided argument, with leading and trailing whitespace trimmed, at the specified index.Note: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
index
- the index at which the argument should be insertedargument
- the argument to insert at the specified index- Returns:
this
- Throws:
IllegalArgumentException
- if the providedargument
is empty or blankIndexOutOfBoundsException
- if the providedindex
is out of boundsNullPointerException
- if the providedargument
isnull
-
argumentBefore
Inserts the provided argument, with leading and trailing whitespace trimmed, immediately before the specified anchor if the anchor can be found. Otherwise, the argument is appended at the end.Note: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
anchor
- the argument serving as the anchor for the new argumentargument
- the argument to add immediately before the specified anchor- Returns:
this
- Throws:
IllegalArgumentException
- if the providedargument
is empty or blankNullPointerException
- if the providedargument
isnull
-
clearArguments
Clears any arguments which have been set.- Returns:
this
-
clearInputHandler
Clears theinput handler
, if one has been set. Without an input handler, no data will be provided on the command's input stream.Some commands always read data from their input stream, rather than, or in addition to, considering arguments provided on the command line. For such commands, the caller must provide an explicit
input handler
; there is no automatic default.- Returns:
this
-
defaultErrorHandler
Applies the defaulterror handler
, which will collect any output written to the error stream and provide that output to theexit handler
.- Returns:
this
-
errorHandler
Sets theerror handler
which will be used to process any output written to the error stream as the command runs.When using a custom error handler, the
exit handler
will not receive error stream output; it is assumed that the error handler will have received and processed the output already. If the error handler throws an exception in response to error stream output, the exit handler will receive that exception.- Parameters:
value
- the handler to receive and process the command's error stream- Returns:
this
- Throws:
NullPointerException
- if the providedvalue
isnull
-
inputHandler
Sets theinput handler
which will be used to feed data to the command's input stream.Some commands require specific arguments to trigger processing data provided via an input stream. For such commands, the caller must also provide those arguments in addition to setting the input handler; the builder does not add them automatically.
- Parameters:
value
- the handler to receive and process the command's input stream- Returns:
this
- Throws:
NullPointerException
- if the providedvalue
isnull
-
rawArgument
Appends the provided argument, verbatimNote: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
argument
- the argument to append to the command- Returns:
this
- Throws:
NullPointerException
- if the providedargument
isnull
- Since:
- 6.0
-
rawArgumentAfter
Inserts the provided argument, verbatim, immediately after the specified anchor if the anchor can be found. Otherwise, the argument is appended at the end.Note: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
anchor
- the argument serving as the anchor for the new argumentargument
- the argument to add immediately after the specified anchor- Returns:
this
- Throws:
NullPointerException
- if the providedargument
isnull
- Since:
- 6.0
-
rawArgumentAt
Inserts the provided argument, verbatim, at the specified index.Note: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
index
- the index at which the argument should be insertedargument
- the argument to insert at the specified index- Returns:
this
- Throws:
IndexOutOfBoundsException
- if the providedindex
is out of boundsNullPointerException
- if the providedargument
isnull
- Since:
- 6.0
-
rawArgumentBefore
Inserts the provided argument, verbatim, immediately before the specified anchor if the anchor can be found. Otherwise, the argument is appended at the end.Note: Arguments must be provided one per invocation. There is no need to quote strings which include spaces; spaces in arguments are not interpreted. They are passed as-is to the command.
- Parameters:
anchor
- the argument serving as the anchor for the new argumentargument
- the argument to add immediately before the specified anchor- Returns:
this
- Throws:
NullPointerException
- if the providedargument
isnull
- Since:
- 6.0
-