sbt-scrooge is an sbt 0.12 plugin that adds support for using scrooge to perform thrift code generation.
The plugin is forked from Twitter's sbt-scrooge repo that is not maintained anymore.
The plugin registers itself as a source generator for the compile phase.
It fetches scrooge from Ivy2 repository, caches it in your
project, and runs it against your thrift folder (usually src/main/thrift
).
The generated code folder (usually target/src_managed
) is then added to your
compile path.
Add following to your project/plugins.sbt
file:
resolvers += Resolver.url("Koofr repo", url("https://koofr.github.io/repo/releases/"))
addSbtPlugin("net.koofr" % "sbt-scrooge" % "3.1.1")
And build.sbt
:
import net.koofr.sbt._
CompileThriftScrooge.newSettings
name := "yourproject"
organization := "com.example"
version := "1.0.0-SNAPSHOT"
scalaVersion := "2.10.4"
libraryDependencies ++= Seq(
"org.apache.thrift" % "libthrift" % "0.8.0" intransitive,
"com.twitter" %% "finagle-core" % "6.2.0",
"com.twitter" %% "finagle-thrift" % "6.2.0",
"com.twitter" %% "finagle-ostrich4" % "6.2.0",
"com.twitter" %% "finagle-redis" % "6.2.0",
"com.twitter" % "scrooge-runtime" % "3.0.43"
)
CompileThriftScrooge.scroogeBuildOptions := List("--finagle")
A full list of settings is in the (only) source file. Here are the ones you're most likely to want to edit:
-
scroogeVersion: String
to use a different version of scrooge than the current default
-
scroogeCacheFolder: File
to unpack the downloaded scrooge release into a different folder
-
scroogeBuildOptions: Seq[String]
list of command-line arguments to pass to scrooge (default:
Seq("--finagle", "--ostrich", "--verbose")
) -
scroogeThriftIncludeFolders: Seq[File]
list of folders to search when processing "include" directives (default: none)
-
scroogeThriftSourceFolder: File
where to find thrift files to compile (default:
src/main/thrift/
) -
scroogeThriftOutputFolder: File
where to put the generated scala files (default:
target/<scala-ver>/src_managed
)
To build the plugin locally and publish it to your local filesystem:
$ sbt publish
To change the publish path add the following to local.sbt
:
publishTo := Some(Resolver.file("file", new File("/path/to/maven/")))
To test the plugin run scripted
command in sbt:
$ sbt scripted