Documentation

You are viewing the documentation for the 2.3.x release series. The latest stable release series is 2.4.x.

§ビルドシステム

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:

For now, we are going to concern ourselves with the /build.sbt file and the /project directory.

§The /build.sbt file.

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(
  jdbc,
  anorm,
  cache
)

lazy val root = (project in file(".")).enablePlugins(PlayScala)

The 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.

The version line provides the version of your application which is used as part of the name for the artifacts your build will produce.

The libraryDependencies line specifies the libraries that your application depends on. More on this below.

You should use the PlayJava or 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:

import sbt._
import Keys._
import play.Play.autoImport._
import PlayKeys._

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:

import com.typesafe.sbt.less.autoImport._
import LessKeys._

§/project ディレクトリ

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:

§Play plugin for sbt (/project/plugins.sbt)

The Play console and all of its development features like live reloading are implemented via an sbt plugin. It is registered in the /project/plugins.sbt file:

addSbtPlugin("com.typesafe.play" % "sbt-plugin" % playVersion) // where version is the current Play version, i.e.  "2.3.0" 

Note that build.properties and plugins.sbt must be manually updated when you are changing the play version.

§依存性とリゾルバの追加

Java サンプル zentasks のビルドファイルが示す通り、依存性の追加はシンプルです:

name := "zentask"

version := "1.0"

libraryDependencies ++= Seq(javaJdbc, javaEbean)     

lazy val root = (project in file(".")).enablePlugins(PlayJava)

…これは、リゾルバに対するリポジトリの追加も同様です:

resolvers += "Repository name" at "http://url.to/repository" 

Next: SBT セッティングについて


このドキュメントの翻訳は Play チームによってメンテナンスされているものではありません。 間違いを見つけた場合、このページのソースコードを ここ で確認することができます。 ドキュメントガイドライン を読んで、お気軽にプルリクエストを送ってください。