This document describes as scala-cli behaves if run as scala
command. See more information in SIP-46
scala
commands
This document is a specification of the scala
runner.
For now it uses documentation specific to Scala CLI but at some point it may be refactored to provide more abstract documentation.
Documentation is split into sections in the spirit of RFC keywords (MUST
, SHOULD
, NICE TO HAVE
) including the IMPLEMENTATION
category,
that is reserved for commands that need to be present for Scala CLI to work properly but should not be a part of the official API.
MUST have commands:
compile
Compile Scala code.
Specific compile configurations can be specified with both command line options and using directives defined in sources. Command line options always take priority over using directives when a clash occurs, allowing to override configurations defined in sources. Using directives can be defined in all supported input source file types.
Multiple inputs can be passed at once. Paths to directories, URLs and supported file types are accepted as inputs. Accepted file extensions: .scala, .sc, .java, .jar, .md, .jar, .c, .h, .zip For piped inputs use the corresponding alias: _.scala, _.java, _.sc, _.md All supported types of inputs can be mixed with each other.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/compile
Accepts option groups: benchmarking, compilation server, compile, coursier, cross, debug, dependency, global suppress warning, help group, input, jvm, logging, markdown, power, python, Scala.js, Scala Native, scalac, scalac extra, scope, semantic db, shared, snippet, source generator, suppress warning, verbosity, version, watch, workspace
config
Configure global settings for Scala CLI.
Syntax:
scala-cli config key value
For example, to globally set the interactive mode:
scala-cli config interactive true
Available keys:
- actions Globally enables actionable diagnostics. Enabled by default.
- github.token GitHub token.
- httpProxy.address HTTP proxy address.
- httpProxy.password HTTP proxy password (used for authentication).
- httpProxy.user HTTP proxy user (used for authentication).
- interactive Globally enables interactive mode (the '--interactive' flag).
- interactive-was-suggested Setting indicating if the global interactive mode was already suggested.
- java.properties Java properties for Scala CLI's execution.
- pgp.public-key The PGP public key, used for signing.
- pgp.secret-key The PGP secret key, used for signing.
- pgp.secret-key-password The PGP secret key password, used for signing.
- power Globally enables power mode (the '--power' launcher flag).
- publish.credentials Publishing credentials, syntax: repositoryAddress value:user value:password [realm]
- publish.user.email The 'email' user detail, used for publishing.
- publish.user.name The 'name' user detail, used for publishing.
- publish.user.url The 'url' user detail, used for publishing.
- repositories.credentials Repository credentials, syntax: repositoryAddress value:user value:password [realm]
- repositories.default Default repository, syntax: https://first-repo.company.com https://second-repo.company.com
- repositories.mirrors Repository mirrors, syntax: repositories.mirrors maven:*=https://repository.company.com/maven
- suppress-warning.deprecated-features Globally suppresses warnings about deprecated features.
- suppress-warning.directives-in-multiple-files Globally suppresses warnings about directives declared in multiple source files.
- suppress-warning.experimental-features Globally suppresses warnings about experimental features.
- suppress-warning.outdated-dependencies-files Globally suppresses warnings about outdated dependencies.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/config
Accepts option groups: config, coursier, debug, global suppress warning, jvm, logging, pgp scala signing, power, verbosity
doc
Generate Scaladoc documentation.
Multiple inputs can be passed at once. Paths to directories, URLs and supported file types are accepted as inputs. Accepted file extensions: .scala, .sc, .java, .jar, .md, .jar, .c, .h, .zip For piped inputs use the corresponding alias: _.scala, _.java, _.sc, _.md All supported types of inputs can be mixed with each other.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/doc
Accepts option groups: benchmarking, compilation server, coursier, debug, dependency, doc, global suppress warning, help group, input, jvm, logging, markdown, power, python, Scala.js, Scala Native, scalac, scalac extra, semantic db, shared, snippet, source generator, suppress warning, verbosity, version, workspace
repl
Aliases: console
Fire-up a Scala REPL.
The entire Scala CLI project's classpath is loaded to the repl.
Specific repl configurations can be specified with both command line options and using directives defined in sources. Command line options always take priority over using directives when a clash occurs, allowing to override configurations defined in sources. Using directives can be defined in all supported input source file types.
Multiple inputs can be passed at once. Paths to directories, URLs and supported file types are accepted as inputs. Accepted file extensions: .scala, .sc, .java, .jar, .md, .jar, .c, .h, .zip For piped inputs use the corresponding alias: _.scala, _.java, _.sc, _.md All supported types of inputs can be mixed with each other.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/repl
Accepts option groups: benchmarking, compilation server, coursier, cross, debug, dependency, global suppress warning, help group, input, java, java prop, jvm, logging, markdown, power, python, repl, Scala.js, Scala Native, scalac, scalac extra, scope, semantic db, shared, snippet, source generator, suppress warning, verbosity, version, watch, workspace
run
Compile and run Scala code.
Specific run configurations can be specified with both command line options and using directives defined in sources. Command line options always take priority over using directives when a clash occurs, allowing to override configurations defined in sources. Using directives can be defined in all supported input source file types.
For a run to be successful, a main method must be present on the classpath. .sc scripts are an exception, as a main class is provided in their wrapper.
Multiple inputs can be passed at once. Paths to directories, URLs and supported file types are accepted as inputs. Accepted file extensions: .scala, .sc, .java, .jar, .md, .jar, .c, .h, .zip For piped inputs use the corresponding alias: _.scala, _.java, _.sc, _.md All supported types of inputs can be mixed with each other.
To pass arguments to the actual application, just add them after --
, like:
scala-cli run Main.scala AnotherSource.scala -- first-arg second-arg
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/run
Accepts option groups: benchmarking, compilation server, coursier, cross, debug, dependency, global suppress warning, help group, input, java, java prop, jvm, logging, main class, markdown, power, python, run, Scala.js, Scala Native, scalac, scalac extra, semantic db, shared, snippet, source generator, suppress warning, verbosity, version, watch, workspace
shebang
Like run
, but handier for shebang scripts.
This command is equivalent to the run
sub-command, but it changes the way
Scala CLI parses its command-line arguments in order to be compatible
with shebang scripts.
When relying on the run
sub-command, inputs and scala-cli options can be mixed,
while program args have to be specified after --
scala-cli [command] [scala-cli_options | input]... -- [program_arguments]...
However, for the shebang
sub-command, only a single input file can be set, while all scala-cli options
have to be set before the input file.
All inputs after the first are treated as program arguments, without the need for --
scala-cli shebang [scala-cli_options]... input [program_arguments]...
Using this, it is possible to conveniently set up Unix shebang scripts. For example:
#!/usr/bin/env -S scala-cli shebang --scala-version 2.13
println("Hello, world")
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/shebang
Accepts option groups: benchmarking, compilation server, coursier, cross, debug, dependency, global suppress warning, help group, input, java, java prop, jvm, logging, main class, markdown, power, python, run, Scala.js, Scala Native, scalac, scalac extra, semantic db, shared, snippet, source generator, suppress warning, verbosity, version, watch, workspace
SHOULD have commands:
fmt
Aliases: format
, scalafmt
Formats Scala code.
scalafmt
is used to perform the formatting under the hood.
The .scalafmt.conf
configuration file is optional.
Default configuration values will be assumed by Scala CLI.
All standard Scala CLI inputs are accepted, but only Scala sources will be formatted (.scala and .sc files).
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/fmt
Accepts option groups: benchmarking, compilation server, coursier, debug, dependency, fmt, global suppress warning, help group, input, jvm, logging, markdown, power, python, Scala.js, Scala Native, scalac, scalac extra, semantic db, shared, snippet, source generator, suppress warning, verbosity, version, workspace
test
Compile and test Scala code.
Test sources are compiled separately (after the 'main' sources), and may use different dependencies, compiler options, and other configurations. A source file is treated as a test source if:
- the file name ends with
.test.scala
- the file comes from a directory that is provided as input, and the relative path from that file to its original directory contains a
test
directory - it contains the
//> using target.scope test
directive (Experimental)
Specific test configurations can be specified with both command line options and using directives defined in sources. Command line options always take priority over using directives when a clash occurs, allowing to override configurations defined in sources. Using directives can be defined in all supported input source file types.
Multiple inputs can be passed at once. Paths to directories, URLs and supported file types are accepted as inputs. Accepted file extensions: .scala, .sc, .java, .jar, .md, .jar, .c, .h, .zip For piped inputs use the corresponding alias: _.scala, _.java, _.sc, _.md All supported types of inputs can be mixed with each other.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/test
Accepts option groups: benchmarking, compilation server, coursier, cross, debug, dependency, global suppress warning, help group, input, java, java prop, jvm, logging, markdown, power, python, Scala.js, Scala Native, scalac, scalac extra, semantic db, shared, snippet, source generator, suppress warning, test, verbosity, version, watch, workspace
version
Prints the version of the Scala CLI and the default version of Scala. (which can be overridden in the project) If network connection is available, this sub-command also checks if the installed Scala CLI is up-to-date.
The version of the Scala CLI is the version of the command-line tool that runs Scala programs, which is distinct from the Scala version of the compiler. We recommend to specify the version of the Scala compiler for a project in its sources (via a using directive). Otherwise, Scala CLI falls back to the default Scala version defined by the runner.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/version
Accepts option groups: global suppress warning, logging, power, verbosity, version
Implementation-specific commands
Commands which are used within Scala CLI and should be a part of the scala
command but aren't a part of the specification.
bsp
Start BSP server.
BSP stands for Build Server Protocol. For more information refer to https://build-server-protocol.github.io/
This sub-command is not designed to be used by a human. It is normally supposed to be invoked by your IDE when a Scala CLI project is imported.
Detailed documentation can be found on our website: https://scala-cli.virtuslab.org
Accepts option groups: benchmarking, bsp, compilation server, coursier, debug, dependency, global suppress warning, help group, input, jvm, logging, markdown, power, python, Scala.js, Scala Native, scalac, scalac extra, semantic db, shared, snippet, source generator, suppress warning, verbosity, version, workspace
clean
Clean the workspace.
Passed inputs will establish the Scala CLI project, for which the workspace will be cleaned.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/clean
Accepts option groups: bsp file, global suppress warning, logging, power, verbosity, workspace
help
Print help message
Accepts option groups: global suppress warning, logging, power, verbosity
install completions
Aliases: install-completions
Installs Scala CLI completions into your shell
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/completions
Accepts option groups: global suppress warning, install completions, logging, power, verbosity
install-home
Install Scala CLI in a sub-directory of the home directory
Accepts option groups: global suppress warning, install home, logging, power, verbosity
setup-ide
Generates a BSP file that you can import into your IDE.
The setup-ide sub-command allows to pre-configure a Scala CLI project to import to an IDE with BSP support.
It is also ran implicitly when compile
, run
, shebang
or test
sub-commands are called.
The pre-configuration should be saved in a BSP json connection file under the path:
{project-root}/.bsp/scala-cli.json
Specific setup-ide configurations can be specified with both command line options and using directives defined in sources. Command line options always take priority over using directives when a clash occurs, allowing to override configurations defined in sources. Using directives can be defined in all supported input source file types.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/setup-ide
Accepts option groups: benchmarking, bsp file, compilation server, coursier, debug, dependency, global suppress warning, help group, input, jvm, logging, markdown, power, python, Scala.js, Scala Native, scalac, scalac extra, semantic db, setup IDE, shared, snippet, source generator, suppress warning, verbosity, version, workspace
uninstall
Uninstalls Scala CLI. Works only when installed with the installation script. For detailed installation instructions refer to our website: https://scala-cli.virtuslab.org/install
Accepts option groups: compilation server, coursier, global suppress warning, logging, power, uninstall, uninstall completions, verbosity
uninstall completions
Aliases: uninstall-completions
Uninstalls Scala CLI completions from your shell.
For detailed documentation refer to our website: https://scala-cli.virtuslab.org/docs/commands/completions
Accepts option groups: global suppress warning, logging, power, uninstall completions, verbosity
update
Updates Scala CLI. Works only when installed with the installation script. If Scala CLI was installed with an external tool, refer to its update methods.
For detailed installation instructions refer to our website: https://scala-cli.virtuslab.org/install
Accepts option groups: global suppress warning, logging, power, update, verbosity