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