Skip to main content

Custom Toolkit

Similar to the Scala Toolkit and Typelevel toolkit, it is possible to create your own, custom toolkit. Having a custom toolkit with common libraries can speed up the development using scala-cli.

Let's look at how we can create a new toolkit.

For example, to create a LiHaoyi ecosystem toolkit, we can name the file as LiHaoyiToolkit.scala and add the required libraries as dependency directives:

//> using scala 2.13 3
//> using publish.name toolkit
//> using dep com.lihaoyi::upickle::4.0.2
//> using dep com.lihaoyi::os-lib::0.11.3
//> using dep com.lihaoyi::requests::0.9.0
//> using dep com.lihaoyi::fansi::0.5.0

This toolkit is a combination of 4 libraries from com.lihaoyi organization as defined before. The key publish.name must have the value toolkit to be used as a toolkit.

Similarly, define the scalajs version of toolkit in LiHaoyiToolkit.js.scala file. Notice the js.scala extension. It should also have publish.name as toolkit.

If testkit is supported, it can also be added as another file, LiHaoyiToolkitTest.scala with publish.name as toolkit-test:

//> using scala 2.13 3
//> using publish.name toolkit-test
//> using dep com.lihaoyi::utest::0.8.4

Additionally, more configurations needed for publishing the toolkit can be kept in a conf file, for example, publish-conf.scala:

//> using publish.organization com.yadavan88
//> using publish.version 0.1.1-SNAPSHOT
//> using publish.url https://github.com/yadavan88/lihaoyi-toolkit
//> using publish.license Apache-2.0
//> using publish.repository central
//> using publish.developer "yadavan88|Yadu Krishnan|https://github.com/yadavan88"
//> using repository sonatype:public

The toolkit can be published locally using the command:

scala-cli --power publish local --cross LiHaoyiToolkit.scala publish-conf.scala

Similarly, it is also possible to publish to a central repository. Refer to the GitHub Action workflow for more details.

Once it is published, it can be accessed using the org-name with which it got published. For example, with the published toolkit under the organization com.yadavan88, it can be accessed as:

//> using toolkit com.yadavan88:0.1.1-SNAPSHOT

@main
def main() = {
println(fansi.Color.Blue("Hello world!"))
println("path is: " + os.pwd)
}

This brings in all the dependencies mentioned in the custom toolkit file.