Introducing Scastie - An interactive playground for Scala


The Scala Center team is happy to announce the Beta of Scastie.

Aleh Aleshka (OlegYch) is the original author of this project. His goal was to create a collaborative debugging tool where you can share and reproduce bugs. The Scala Center has extended Scastie to become an interactive environment for the community.

What can I do with Scastie?

Scastie can run any Scala program with any library in your browser. You don’t need to download or install anything.


We run your code in an isolated Java Virtual Machine on our servers. We allow you to specify the scala version, add libraries and much more. By default, we instrument your code to provide a REPL like environment. You can also format your code with scala-fmt. We integrated a scaladex interface to allow you to search the Scala ecosystem and include any published Scala library in your project. You don’t need to remember the latest version of a specific library anymore!

Let’s see it in action.

In this example, we use scrimage, which is a simple image library. We download an image, apply a sepia filter and serve both images back to the browser.

How does Scastie work?

When a user evaluates their code, the browser sends all its input to our server. Based on the configuration, it will forward the evaluation to an sbt instance. The output will be streamed back to the user. A specific protocol will allow the client to interpret different events such as compiler errors, runtime exceptions, instrumentation, console output, etc.

Using sbt behind the scenes makes it possible for us to support a large range of platforms (Scalac, Dotty, Scala.js, Scala-Native and Typelevel’s Scala). In our beta, we’ve included support for any version of Scalac as well as all published versions of Dotty. Support for other platforms, such as Scala.js or Scala Native is forthcoming. Basing Scastie on sbt allows us to support newer Scala versions and resolve libraries dependencies.

We also enable a worksheet mode, which feels much like a worksheet in an IDE. This lets a user write code as top-level expressions, without having to put code inside of a class or object with a main method. Worksheet mode gives you two ways to interleave your results; on the one hand, when an expression is evaluated, you can see the value and type of the evaluated expression to the right of the code that you wrote. On the other hand, worksheet mode also makes it possible to do a kind of literate programming; that is, you may interleave code and HTML blocks much like in notebook environments like iPython notebooks.

What’s next?

  • Improve the sharing model. For example, we could use a similar approach as gist or JS Fiddle where you can fork and edit code snippets.
  • Support Scala.js and Scala-Native. Vote on which one you’d like to see first! (Vote for Scala.js or vote for Scala Native)
  • Make it possible to embed Scastie in your project’s documentation.

Want to try it?

Since Scastie is a new project, we want to work out the kinks with it before everyone jumps on it and starts using it. In particular, the UI is currently a bit rough, and we’re working on catching bugs in the general usage of Scastie.

For that reason, we’re opening up Scastie to a handful of beta users. Do you want to help us work out the kinks with Scastie? If so, head over to to join the beta. We’ll gradually be adding more users, so if you don’t get immediate access, just hang on for a day or so and we’ll ping you to let you know when you can try out Scastie.

And remember, please give us feedback! Let us know what is confusing, if something doesn’t work as expected, or if there’s anything you think we can improve! There are links in Scastie back to our Gitter channels and GitHub issue tracker.

Talk to us!

Thoughts or opinions about Scastie? Join us over on Scala Contributors to contribute to the discussion.


This looks very exciting!

Sorry I don’t have a smarter question, but how do you pronounce scastie?


My guess is: SK - ACE - TEE. @OlegYch choosed the name :stuck_out_tongue:


Quick link:

The beta is full right now. We have more than 700 users registered with 500 spots open. I’m fixing mirror issues and I will increase the limit to 1000 so more people will have a chance to try it out!

Here is a summary of what will be improved shortly: (V2 Column).

Thanks a lot for the feedback, we are really happy with the community reaction for this announcement.


The Scala Center team is extremely happy to announce that Scastie is out of beta! You don’t need to be logged in to GitHub to access the site. We also improved the UI and added support for Scala.js. Check it out!


The mobile interface is still not really optimal on my phone, if I may say so.


Is broken for me … I cannot run the default program


Looks great! Except maybe for a lack of UI clarity for where the editor ends and where the output begins. The library features are really nice. It would be even nicer if the libraries were listed in SBT format so Scastie could be used to easily alter SBT builds instead of having to jump out to ScalaDex.

This was covered by tweets, but the scala/center gitter room was missed (I just reposted the blog there). Any other places it should be announced that might have been overlooked?


This is really interesting! I’ve been trying it out and would like to include it in my standard workflow, though it isn’t the fastest. Are there plans to publish a self hosting setup guide?
Thanks for the hard work!


There used to be an endpoint at – is there an equivalent on