DEPRECATED: use https://github.com/ymasory/sbt.g8
Warning: you must use sbt version 0.11.3-2 or higher to launch this project. After that sbt will automatically retrieve the correct version of sbt all by itself.
Please let me know if any software is out of date. That includes scala version, sbt version, and plugin versions.
- sbt-assembly. Generate a single (executable) jar of your project.
$ sbt
> assembly
[info] Including scalaz-core_2.9.2-7.0.0-M2.jar
[info] Including scalaz-effect_2.9.2-7.0.0-M2.jar
[info] Including scala-library.jar
[info] Merging 'META-INF/MANIFEST.MF' with strategy 'discard'
[info] Packaging /Users/yuvi/workspace/ymasory/sbt-prototype/target/prototype-project-assembly-1.0.0-SNAPSHOT.jar ...
[info] Done packaging.
[success] Total time: 11 s, completed Aug 16, 2012 1:00:42 AM
> exit
$ java -jar target/prototype-project-assembly-1.0.0-SNAPSHOT.jar
hello, prototype-project v1.0.0-SNAPSHOT running with Scala v2.9.2 on sbt v0.11.3
- sbt-dependency-graph. Visualize your artifact dependency graph.
$ sbt
> dependency-graph
[info] com.example:prototype-project_2.9.2:1.0.0-SNAPSHOT
[info] +-org.scala-lang:scala-library:2.9.2
[info] +-org.scalaz:scalaz-core_2.9.2:6.0.4
[info] +-org.scala-lang:scala-library:2.9.2
[info]
[success] Total time: 0 s, completed May 26, 2012 1:30:29 PM
- sbt-git-plugin. Control git directly from the sbt shell.
$ sbt
> git status
# On branch master
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: README.md
#
no changes added to commit (use "git add" and/or "git commit -a")
> git add .
> git status
# On branch master
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# modified: README.md
#
> git commit -m 'add-to-readme'
[master 5a18b87] 'add-to-readme'
1 file changed, 17 insertions(+), 1 deletion(-)
> git status
# On branch master
# Your branch is ahead of 'origin/master' by 1 commit.
#
nothing to commit (working directory clean)
> git push
[error] To git@github.com:ymasory/sbt-prototype.git
[error] 2af9c45..5a18b87 master -> master
> git status
# On branch master
nothing to commit (working directory clean)
- sbt-man. Access scaladocs and scalex.com directly from the sbt shell.
$ sbt
> man List
[man] scala
[man] def List: collection.immutable.List.type
> man List
[man] scala
[man] def List: collection.immutable.List.type
> man List ::
[man] scala.collection.immutable.List
[man] def ::(x: A): List[A]
[man] Adds an element at the beginning of this list.
> man Ordering
[man] scala
[man] def Ordering: math.Ordering.type
> man scalaz.Ordering
[man] scalaz.IntW
[man] def ordering: Ordering
- xsbt-start-script-plugin. Generate a start script so you're not using
sbt run
in production.
$ sbt
> start-script
[info] Wrote start script for mainClass := Some(com.example.Main) to /Users/yuvi/workspace/ymasory/sbt-prototype/target/start
[success] Total time: 0 s, completed May 26, 2012 2:14:18 PM
> exit
$ ./target/start
hello, prototype-project v1.0.0-SNAPSHOT running with Scala v2.9.2 on sbt v0.11.3
-
sbt-buildinfo. Access sbt properties at runtime. This is already integrated. As you can see,
Main.scala
has access to the artifact name, version, etc. -
ensime-sbt-cmd. Generate your
.ensime
file for ENSIME integration.
$ sbt
> ensime generate
[info] Gathering project information...
[info] Processing project: ProjectRef(file:/Users/yuvi/workspace/ymasory/sbt-prototype/,default-0e69ae)...
[info] Reading setting: name...
[info] Reading setting: organization...
[info] Reading setting: version...
[info] Reading setting: scala-version...
[info] Reading setting: module-name...
[info] Evaluating task: project-dependencies...
[info] Evaluating task: unmanaged-classpath...
[info] Evaluating task: managed-classpath...
[info] Evaluating task: internal-dependency-classpath...
[info] Evaluating task: unmanaged-classpath...
[info] Evaluating task: managed-classpath...
[info] Evaluating task: internal-dependency-classpath...
[info] Evaluating task: exported-products...
[info] Evaluating task: unmanaged-classpath...
[info] Evaluating task: managed-classpath...
[info] Evaluating task: internal-dependency-classpath...
[info] Evaluating task: exported-products...
[info] Reading setting: source-directories...
[info] Reading setting: source-directories...
[info] Reading setting: class-directory...
[info] Reading setting: ensime-config...
[info] Wrote configuration to .ensime
- ScalaCheck. Write specification based tests that write lots of unit tests for you.
$ sbt
> test
[info] + Main.startsWith: OK, passed 100 tests.
[info] + Main.endsWith: OK, passed 100 tests.
[info] Passed: : Total 2, Failed 0, Errors 0, Passed 2, Skipped 0
[success] Total time: 1 s, completed May 26, 2012 2:18:01 PM
- gitignore. The
.gitignore
file is ready to go. - sbt tweaks. E.g., stack traces are reduce to be less distracting, main class is specified. See
built.sbt
to learn about all tweaks.
- Change all the references in
build.sbt
andMain.scala
fromcom.example
to your package. - Change the artifact name in
build.sbt
fromprototype-project
to your desired project name. - Change the artifact version in
build.sbt
from1.0.0-SNAPSHOT
to your desired version. - Fill in the
LICENSE
file with the text of your program's license. - Change this
README.md
file to something about your project.