This is an index of common methods, types, and values you might find in an sbt build definition. For command names, see Running. For available plugins, see the plugins list.
Compile
, Test
, Runtime
, Provided
, and Optional
are
predefined configurations.
See the Getting Started Guide for details.
:=
, +=
, ++=
These construct a
Setting, which is the fundamental
type in the settings system.
value
This uses the value of another setting or task in the
definition of a new setting or task. This method is special (it is a
macro) and cannot be used except in the argument of one of the
setting definition methods above (:=, …) or in the standalone
construction methods Def.setting and Def.task. See
Task-Graph for
details.
in
specifies the Scope or part of the
Scope of a setting being referenced. See
scopes.
See RichFile, PathFinder, and Paths for the full documentation.
/
When called on a single File, this is new File(x,y)
. For
Seq[File], this is applied for each member of the sequence..
*
and **
are methods for selecting children (*
) or descendants
(**
) of a File or Seq[File] that match a filter.
|
, ||
, &&
, &
, -
, and --
are methods for combining
filters, which are often used for selecting Files. See
NameFilter and
FileFilter. Note that methods with
these names also exist for other types, such as collections (like
Seq) and Parser (see
Parsing Input).
pair
Used to construct mappings from a File
to another File
or
to a String. See Mapping Files.
get
forces a PathFinder (a
call-by-name data structure) to a strict Seq[File]
representation.
This is a common name in Scala, used by types like Option.
See Library Management for full documentation.
%
This is used to build up a ModuleID.
%%
This is similar to %
except that it identifies a dependency
that has been cross built.
from
Used to specify the fallback URL for a dependency
classifier
Used to specify the classifier for a dependency.
at
Used to define a Maven-style resolver.
intransitive
Marks a dependency or
Configuration as being
intransitive.
hide
Marks a Configuration as
internal and not to be included in the published metadata.
These methods are used to build up Parsers from smaller Parsers. They closely follow the names of the standard library’s parser combinators. See Parsing Input for the full documentation. These are used for Input Tasks and Commands.
~
, ~>
, <~
Sequencing methods.
??
, ?
Methods for making a Parser optional. ?
is postfix.
id
Used for turning a Char or String literal into a Parser. It is
generally used to trigger an implicit conversion to a Parser.
|
, ||
Choice methods. These are common method names in Scala.
^^^
Produces a constant value when a Parser matches.
+
, *
Postfix repetition methods. These are common method names
in Scala.
map
, flatMap
Transforms the result of a Parser. These are common
method names in Scala.
filter
Restricts the inputs that a Parser matches on. This is a
common method name in Scala.
-
Prefix negation. Only matches the input when the original parser
doesn’t match the input.
examples
, token
Tab completion
!!!
Provides an error message to use when the original parser
doesn’t match the input.
These methods are used to
fork external processes. Note that this API
has been included in the Scala standard library for version 2.9.
ProcessBuilder is the builder type
and Process is the type representing the
actual forked process. The methods to combine processes start with #
so that they share the same precedence.
run
, !
, !!
, !<
, lines
, lines_!
are different ways to
start a process once it has been defined. The lines variants produce
a Stream[String] to obtain the output lines.
#<
, #<<
, #>
are used to get input for a process from a source
or send the output of a process to a sink.
#|
is used to pipe output from one process into the input of
another.
#||
, #&&
, ###
sequence processes in different ways.