§The Build System
The Play build system uses sbt, a high-performance integrated build for Scala and Java projects. Using
sbt as our build tool brings certain requirements to play which are explained on this page.
§Play application directory structure
Most people get started with Play using the
activator new foo command which produces a directory structure like this:
/: The root folder of your application
/README: A text file describing your application that will get deployed with it.
/app: Where your application code will be stored.
/build.sbt: The sbt settings that describe building your application.
/conf: Configuration files for your application
/project: Further build description information
/public: Where static, public assets for your application are stored.
/test: Where your application’s test code will be stored.
For now, we are going to concern ourselves with the
/build.sbt file and the
When you use the
activator new foo command, the build description file,
/build.sbt, will be generated like this:
name := "foo"
version := "1.0-SNAPSHOT"
libraryDependencies ++= Seq(
lazy val root = (project in file(".")).enablePlugins(PlayScala)
name line defines the name of your application and it will be the same as the name of your application’s root directory,
/, which is derived from the argument that you gave to the
activator new command.
version line provides the version of your application which is used as part of the name for the artifacts your build will produce.
libraryDependencies line specifies the libraries that your application depends on. More on this below.
You should use the
PlayScala plugin to configure sbt for Java or Scala respectively.
§Using scala for building
Activator is also able to construct the build requirements from scala files inside your project’s
project folder. The recommended practice is to use
build.sbt but there are times when using scala directly is required. If you find yourself, perhaps because you’re migrating an older project, then here are a few useful imports:
The line indicating
autoImport is the correct means of importing an sbt plugin’s automatically declared properties. Along the same lines, if you’re importing an sbt-web plugin then you might well:
Everything related to building your project is kept in the
/project directory underneath your application directory. This is an sbt requirement. Inside that directory, there are two files:
/project/build.properties: This is a marker file that declares the sbt version used.
/project/plugins.sbt: SBT plugins used by the project build including Play itself.
§Play plugin for sbt (
The Play console and all of its development features like live reloading are implemented via an sbt plugin. It is registered in the
addSbtPlugin("com.typesafe.play" % "sbt-plugin" % playVersion) // where version is the current Play version, i.e. "2.3.0"
plugins.sbtmust be manually updated when you are changing the play version.
§Adding dependencies and resolvers
Adding dependencies is simple as the build file for the
zentasks Java sample shows:
name := "zentask"
version := "1.0"
libraryDependencies ++= Seq(javaJdbc, javaEbean)
lazy val root = (project in file(".")).enablePlugins(PlayJava)
…and so are resolvers for adding in additional repositories:
resolvers += "Repository name" at "https://url.to/repository"
Next: About SBT Settings
Found an error in this documentation? The source code for this page can be found here. After reading the documentation guidelines, please feel free to contribute a pull request. Have questions or advice to share? Go to our community forums to start a conversation with the community.