Scala Runner specification
This document describes proposed specification for Scala runner based on Scala CLI documentation as requested per SIP-46
Commands and options are marked with MUST and SHOULD (in the RFC style) for ones applicable for Scala Runner.
Options and commands marked as Implementation are needed for smooth running of Scala CLI.
We recommend for those options and commands to be supported by the scala
command (when based on Scala CLI) but not to be a part of the Scala Runner specification.
The proposed Scala runner specification should also contain supported Using directives
defined in the dedicated document]
Scalac options forwarding
All options that start with:
-g
-language
-opt
-P
-target
-V
-W
-X
-Y
are assumed to be Scala compiler options and will be propagated to Scala Compiler. This applies to all commands that uses compiler directly or indirectly.
Scalac options that are directly supported in scala CLI (so can be provided as is, without any prefixes etc.):
-encoding
-release
-color
-nowarn
-feature
-deprecation
-indent
-no-indent
-unchecked
-rewrite
-old-syntax
-new-syntax
MUST have commands
compile
command
MUST have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
--watch
Run the application in the background, automatically wake the thread and re-run if sources have been changed
Aliases: -w
--restart
Run the application in the background, automatically kill the process and restart if sources have been changed
Aliases: --revolver
--print-class-path
Print the resulting class path
Aliases: -p
,--print-classpath
--test
Include test scope
Aliases: --test-scope
,--with-test-scope
,--with-test
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
config
command
MUST have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
SHOULD have options
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--unset
Remove an entry from config
Aliases: --remove
--force
Force overwriting values for key
Aliases: -f
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--dump
Dump config DB as JSON
doc
command
MUST have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
--output
Set the destination path
Aliases: -o
--force
Overwrite the destination directory, if it exists
Aliases: -f
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
--default-scaladoc-options
Control if Scala CLI should use default options for scaladoc, true by default. Use --default-scaladoc-opts:false
to not include default options.
Aliases: --default-scaladoc-opts
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
repl
command
MUST have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
--java-opt
Set Java options, such as -Xmx1g
Aliases: -J
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
--watch
Run the application in the background, automatically wake the thread and re-run if sources have been changed
Aliases: -w
--restart
Run the application in the background, automatically kill the process and restart if sources have been changed
Aliases: --revolver
--test
Include test scope
Aliases: --test-scope
,--with-test-scope
,--with-test
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
--java-prop-option
Add java properties. Note that options equal -Dproperty=value
are assumed to be java properties and don't require to be passed after --java-prop
.
Aliases: --java-prop
--repl-dry-run
Don't actually run the REPL, just fetch it
run
command
MUST have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
--java-opt
Set Java options, such as -Xmx1g
Aliases: -J
--main-class
Specify which main class to run
Aliases: -M
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
--watch
Run the application in the background, automatically wake the thread and re-run if sources have been changed
Aliases: -w
--restart
Run the application in the background, automatically kill the process and restart if sources have been changed
Aliases: --revolver
--main-class-ls
List main classes available in the current context
Aliases: --main-class-list
,--list-main-class
,--list-main-classes
--command
Print the command that would have been run (one argument per line), rather than running it
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
--java-prop-option
Add java properties. Note that options equal -Dproperty=value
are assumed to be java properties and don't require to be passed after --java-prop
.
Aliases: --java-prop
--scratch-dir
Temporary / working directory where to write generated launchers
--use-manifest
Run Java commands using a manifest-based class path (shortens command length)
shebang
command
MUST have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
--java-opt
Set Java options, such as -Xmx1g
Aliases: -J
--main-class
Specify which main class to run
Aliases: -M
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
--watch
Run the application in the background, automatically wake the thread and re-run if sources have been changed
Aliases: -w
--restart
Run the application in the background, automatically kill the process and restart if sources have been changed
Aliases: --revolver
--main-class-ls
List main classes available in the current context
Aliases: --main-class-list
,--list-main-class
,--list-main-classes
--command
Print the command that would have been run (one argument per line), rather than running it
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
--java-prop-option
Add java properties. Note that options equal -Dproperty=value
are assumed to be java properties and don't require to be passed after --java-prop
.
Aliases: --java-prop
--scratch-dir
Temporary / working directory where to write generated launchers
--use-manifest
Run Java commands using a manifest-based class path (shortens command length)
SHOULD have commands
fmt
command
SHOULD have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
--check
Check if sources are well formatted
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
--respect-project-filters
Use project filters defined in the configuration. Turned on by default, use --respect-project-filters:false
to disable it.
--save-scalafmt-conf
Saves .scalafmt.conf file if it was created or overwritten
--os-arch-suffix
--scalafmt-tag
--scalafmt-github-org-name
--scalafmt-extension
--scalafmt-launcher
--scalafmt-arg
Pass an argument to scalafmt.
Aliases: -F
--scalafmt-conf
Custom path to the scalafmt configuration file.
Aliases: --scalafmt-config
--scalafmt-conf-str
Pass configuration as a string.
Aliases: --scalafmt-config-str
,--scalafmt-conf-snippet
--scalafmt-dialect
Pass a global dialect for scalafmt. This overrides whatever value is configured in the .scalafmt.conf file or inferred based on Scala version used.
Aliases: --dialect
--scalafmt-version
Pass scalafmt version before running it (3.8.5 by default). If passed, this overrides whatever value is configured in the .scalafmt.conf file.
Aliases: --fmt-version
test
command
SHOULD have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
--java-opt
Set Java options, such as -Xmx1g
Aliases: -J
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
--watch
Run the application in the background, automatically wake the thread and re-run if sources have been changed
Aliases: -w
--restart
Run the application in the background, automatically kill the process and restart if sources have been changed
Aliases: --revolver
--test-framework
Name of the test framework's runner class to use while running tests
--require-tests
Fail if no test suites were run
--test-only
Specify a glob pattern to filter the tests suite to be run.
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
--java-prop-option
Add java properties. Note that options equal -Dproperty=value
are assumed to be java properties and don't require to be passed after --java-prop
.
Aliases: --java-prop
version
command
SHOULD have for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--cli-version
Show plain Scala CLI version only
Aliases: --cli
--scala-version
Show plain Scala version only
Aliases: --scala
--gh-token
A github token used to access GitHub. Not needed in most cases.
--offline
Don't check for the newest available Scala CLI version upstream
IMPLEMENTATION specific commands
bsp
command
IMPLEMENTATION specific for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
--json-options
Command-line options JSON file
--json-launcher-options
Command-line launcher options JSON file
--envs
Command-line options environment variables file
Aliases: --envs-file
clean
command
IMPLEMENTATION specific for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--bsp-directory
Custom BSP configuration location
Aliases: --bsp-dir
--bsp-name
Name of BSP
Aliases: --name
--workspace
Directory where .scala-build is written
help
command
IMPLEMENTATION specific for Scala Runner specification.
Print help message
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
install-completions
command
IMPLEMENTATION specific for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--format
Name of the shell, either zsh or bash
Aliases: --shell
--rc-file
Path to *rc
file, defaults to .bashrc
or .zshrc
depending on shell
--output
Completions output directory
Aliases: -o
--banner
Custom banner in comment placed in rc file
--name
Custom completions name
--env
Print completions to stdout
install-home
command
IMPLEMENTATION specific for Scala Runner specification.
Install Scala CLI in a sub-directory of the home directory
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--scala-cli-binary-path
--force
Overwrite if it exists
Aliases: -f
--binary-name
Binary name
--env
Print the update to env
variable
--bin-dir
Binary directory
setup-ide
command
IMPLEMENTATION specific for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
--dependency
Add dependencies
Aliases: --dep
--compile-only-dependency
Add compile-only dependencies
Aliases: --compile-dep
,--compile-lib
--compiler-plugin
Add compiler plugin dependencies
Aliases: -P
,--plugin
--scala-version
Set the Scala version (3.6.3 by default)
Aliases: -S
,--scala
--scala-binary-version
Set the Scala binary version
Aliases: -B
,--scala-binary
,--scala-bin
--extra-jars
Add extra JARs and compiled classes to the class path
Aliases: --jar
,--jars
,--extra-jar
,--class
,--extra-class
,--classes
,--extra-classes
,-classpath
,-cp
,--classpath
,--class-path
,--extra-class-path
--resource-dirs
Add a resource directory
Aliases: --resource-dir
--with-compiler
Allows to include the Scala compiler artifacts on the classpath.
Aliases: --with-scala-compiler
,-with-compiler
--compilation-output
Copy compilation results to output directory using either relative or absolute path
Aliases: -d
,--output-directory
,--destination
,--compile-output
,--compile-out
SHOULD have options
--js
Enable Scala.js. To show more options for Scala.js pass --help-js
--js-version
The Scala.js version (1.18.1 by default).
--js-mode
The Scala.js mode, for fastLinkJS
use one of [dev
, fastLinkJS
or fast
], for fullLinkJS
use one of [release
, fullLinkJS
, full
]
--js-module-kind
The Scala.js module kind: commonjs/common, esmodule/es, nomodule/none
--js-check-ir
--js-emit-source-maps
Emit source maps
--js-source-maps-path
Set the destination path of source maps
--js-es-module-import-map
A file relative to the root directory containing import maps for ES module imports
--js-dom
Enable jsdom
--js-header
A header that will be added at the top of generated .js files
--js-es-version
The Scala.js ECMA Script version: es5_1, es2015, es2016, es2017, es2018, es2019, es2020, es2021
--native
Enable Scala Native. To show more options for Scala Native pass --help-native
--native-version
Set the Scala Native version (0.5.6 by default).
--native-mode
Set Scala Native compilation mode (debug by default): debug, release-fast, release-size, release-full
--native-lto
Link-time optimisation mode (none by default): none, full, thin
--native-gc
Set the Scala Native garbage collector (immix by default): immix, commix, boehm, none
--native-linking
Extra options passed to clang
verbatim during linking
--native-compile
List of compile options
--native-target
Build target type
--embed-resources
Embed resources into the Scala Native binary (can be read with the Java resources API)
--native-multithreading
Enable/disable Scala Native multithreading support
--repository
Add repositories for dependency resolution.
Accepts predefined repositories supported by Coursier (like sonatype:snapshots
or m2Local
) or a URL of the root of Maven repository
Aliases: -r
,--repo
--debug
Turn debugging on
--debug-port
Debug port (5005 by default)
--debug-mode
Debug mode (attach by default)
--java-home
Set the Java home directory
--jvm
Use a specific JVM, such as 14
, adopt:11
, or graalvm:21
, or system
. scala-cli uses coursier to fetch JVMs, so you can use cs java --available
to list the available JVMs.
Aliases: -j
--javac-plugin
Javac plugin dependencies or files
--javac-option
Javac options
Aliases: --javac-opt
--script-snippet
Allows to execute a passed string as a Scala script
--execute-script
A synonym to --script-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
Aliases: -e
,--execute-scala-script
,--execute-sc
--scala-snippet
Allows to execute a passed string as Scala code
--extra-compile-only-jars
Add extra JARs in the compilaion class path. Mainly using to run code in managed environments like Spark not to include certain depenencies on runtime ClassPath.
Aliases: --compile-only-jar
,--compile-only-jars
,--extra-compile-only-jar
--extra-source-jars
Add extra source JARs
Aliases: --source-jar
,--source-jars
,--extra-source-jar
--platform
Specify platform
--semantic-db
Generate SemanticDBs
Aliases: --semanticdb
--semantic-db-target-root
SemanticDB target root (default to the compiled classes destination directory)
Aliases: --semanticdb-target-root
,--semanticdb-targetroot
--semantic-db-source-root
SemanticDB source root (default to the project root directory)
Aliases: --semanticdb-source-root
,--semanticdb-sourceroot
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--suppress-directives-in-multiple-files-warning
Suppress warnings about using directives in multiple files
Aliases: --suppress-warning-directives-in-multiple-files
--suppress-outdated-dependency-warning
Suppress warnings about outdated dependencies in project
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--js-no-opt
Disable optimalisation for Scala.js, overrides --js-mode
--js-allow-big-ints-for-longs
Primitive Longs may be compiled as primitive JavaScript bigints
--js-avoid-classes
Avoid class'es when using functions and prototypes has the same observable semantics.
--js-avoid-lets-and-consts
Avoid lets and consts when using vars has the same observable semantics.
--js-module-split-style
The Scala.js module split style: fewestmodules, smallestmodules, smallmodulesfor
--js-small-module-for-package
Create as many small modules as possible for the classes in the passed packages and their subpackages.
--js-linker-path
Path to the Scala.js linker
--js-cli-version
Scala.js CLI version to use for linking (1.18.1 by default).
--js-cli-java-arg
Scala.js CLI Java options
--js-cli-on-jvm
Whether to run the Scala.js CLI on the JVM or using a native executable
--native-clang
Path to the Clang command
--native-clangpp
Path to the Clang++ command
--native-linking-defaults
Use default linking settings
--native-compile-defaults
Use default compile options
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--args-file
File with scalac options.
--scalac-option
Add a scalac
option. Note that options starting with -g
, -language
, -opt
, -P
, -target
, -V
, -W
, -X
, and -Y
are assumed to be Scala compiler options and don't require to be passed after -O
or --scalac-option
.
Aliases: --scala-opt
,-O
,--scala-option
--jvm-index
JVM index URL
--jvm-index-os
Operating system to use when looking up in the JVM index
--jvm-index-arch
CPU architecture to use when looking up in the JVM index
--bsp-debug-port
Port for BSP debugging
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--workspace
Directory where .scala-build is written
--scalac-help
Show help for scalac. This is an alias for --scalac-option -help
Aliases: --help-scalac
--scalac-verbose
Turn verbosity on for scalac. This is an alias for --scalac-option -verbose
Aliases: --verbose-scalac
--execute-scala
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--java-snippet
Allows to execute a passed string as Java code
--execute-java
A synonym to --scala-snippet, which defaults the sub-command to run
when no sub-command is passed explicitly
--scala-library
--java
Do not add dependency to Scala Standard library. This is useful, when Scala CLI works with pure Java projects.
--runner
Should include Scala CLI runner on the runtime ClassPath. Runner is added by default for application running on JVM using standard Scala versions. Runner is used to make stack traces more readable in case of application failure.
--default-forbidden-directories
--forbid
--help-envs
Show environment variable help
Aliases: --help-env
,--env-help
,--envs-help
--help-js
Show options for ScalaJS
--help-native
Show options for ScalaNative
--help-scaladoc
Show options for Scaladoc
Aliases: --help-doc
,--scaladoc-help
,--doc-help
--help-repl
Show options for Scala REPL
Aliases: --repl-help
--help-scalafmt
Show options for Scalafmt
Aliases: --help-fmt
,--scalafmt-help
,--fmt-help
--strict-bloop-json-check
--with-toolkit
Add toolkit to classPath (not supported in Scala 2.12), 'default' version for Scala toolkit: 0.5.0, 'default' version for typelevel toolkit: 0.1.29
Aliases: --toolkit
--exclude
Exclude sources
--bsp-directory
Custom BSP configuration location
Aliases: --bsp-dir
--bsp-name
Name of BSP
Aliases: --name
--charset
uninstall
command
IMPLEMENTATION specific for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--bloop-bsp-protocol
Protocol to use to open a BSP connection with Bloop
--bloop-bsp-socket
Socket file to use to open a BSP connection with Bloop
--bloop-host
Host the compilation server should bind to
--bloop-port
Port the compilation server should bind to (pass -1
to pick a random port)
--bloop-daemon-dir
Daemon directory of the Bloop daemon (directory with lock, pid, and socket files)
--bloop-version
If Bloop isn't already running, the version we should start
--bloop-bsp-timeout
Maximum duration to wait for the BSP connection to be opened
--bloop-bsp-check-period
Duration between checks of the BSP connection state
--bloop-startup-timeout
Maximum duration to wait for the compilation server to start up
--bloop-default-java-opts
Include default JVM options for Bloop
--bloop-java-opt
Pass java options to use by Bloop server
--bloop-global-options-file
Bloop global options file
--bloop-jvm
JVM to use to start Bloop (e.g. 'system|17', 'temurin:21', …)
--bloop-working-dir
Working directory for Bloop, if it needs to be started
--server
Enable / disable usage of Bloop compilation server. Bloop is used by default so use --server=false
to disable it. Disabling compilation server allows to test compilation in more controlled mannter (no caching or incremental compiler) but has a detrimental effect of performance.
--ttl
Specify a TTL for changing dependencies, such as snapshots
--cache
Set the coursier cache location
--coursier-validate-checksums
Enable checksum validation of artifacts downloaded by coursier
--rc-file
Path to *rc
file, defaults to .bashrc
or .zshrc
depending on shell
--banner
Custom banner in comment placed in rc file
--name
Custom completions name
--force
Force scala-cli uninstall
Aliases: -f
--skip-cache
Don't clear Scala CLI cache
--binary-name
Binary name
--bin-dir
Binary directory
uninstall-completions
command
IMPLEMENTATION specific for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--rc-file
Path to *rc
file, defaults to .bashrc
or .zshrc
depending on shell
--banner
Custom banner in comment placed in rc file
--name
Custom completions name
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
update
command
IMPLEMENTATION specific for Scala Runner specification.
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
MUST have options
--power
Allows to use restricted & experimental features
Implementantation specific options
--usage
Print usage and exit
--help
Print help message and exit
Aliases: -h
,-help
--help-full
Print help message, including hidden options, and exit
Aliases: --full-help
,-help-full
,-full-help
--verbose
Increase verbosity (can be specified multiple times)
Aliases: -v
,-verbose
--interactive
Interactive mode
Aliases: -i
--actions
Enable actionable diagnostics
--quiet
Decrease logging verbosity
Aliases: -q
--progress
Use progress bars
--suppress-experimental-feature-warning
Suppress warnings about using experimental features
Aliases: --suppress-experimental-warning
--suppress-deprecated-feature-warning
Suppress warnings about using deprecated features
Aliases: --suppress-deprecated-warning
,--suppress-deprecated-warnings
,--suppress-deprecated-feature-warnings
--binary-name
Binary name
--bin-dir
Binary directory
--force
Force update Scala CLI if it is outdated
Aliases: -f
--is-internal-run
--gh-token
A github token used to access GitHub. Not needed in most cases.