Skip to content
marmbrus edited this page Dec 22, 2010 · 27 revisions

Installing SBT

  1. Make sure you have a sun jvm 1.6+ installed
  2. Create a shell script called "sbt" (optionally: somewhere in your path) with the following in it (note, some settings like the mesos path and the heap size (-Xmx) should but customized for your setup):
#!/bin/bash
java -noverify -Djava.library.path=/usr/local/mesos/lib/java -Xmx7G -XX:MaxPermSize=3G \
-XX:+UseParNewGC -XX:+UseConcMarkSweepGC -jar `dirname $0`/sbt-launch.jar "$@"
  1. download sbt-launch from http://cs.berkeley.edu/~marmbrus/tmp/sbt-launch.jar and put it into the same directory as the above sbt script
  2. try it out by running sbt while in the top level directory of SCADS

Troubleshooting

If you get an error that looks anything like the following, you should delete ~/.m2/repository and ~/.ivy2/cache, and try again.

:: problems summary ::
:::: WARNINGS
		[NOT FOUND  ] org.scala-lang#scala-compiler;2.8.0!scala-compiler.jar (76ms)

If you get the error java.lang.NoClassDefFoundError: org/apache/avro/Schema try updating and then restarting sbt.

Adding subprojects to SBT

SBT is configured by the scala program in project/built/ScadsProject.scala. Subprojects are specified as lazy vals in the following form:

lazy val subProjectName = project("path to subproject", "subproject name", new ScadsSubProject(_) {
    val bdb = "com.sleepycat" % "je" % "4.0.71" //Dependencies are specified using maven style: groupId % artifactId % version
}, config, avro, comm) //any dependencies on other scads components are listed last.

Directory layout for the subproject is the same as with maven (I.e source files go in <subproject dir>/src/main/scala. If you are creating a subproject in a nested directory each directory should be its own string and the / operator should be used for concatenation (Ex: "piql" / "scadr").

SBT Command Reference

SBT commands can either be run one at a time by running sbt <command> or from the an sbt shell which can be invoked by running sbt by itself. The shell supports tab completion and successive commands will take advantage of JIT and thus run faster. Unlike with maven all sbt commands should be run from the root of the SCADS checkout, regardless of which subproject you are working on. More commands can be found on the SBT wiki

  • update - download all managed dependencies jars, note in contrast to maven this must be run explicitly. This only needs to be run once unless dependencies have been added to the project.
  • projects - list all of the available subprojects
  • project <subproject name> - switch to the specified subproject, subsequent commands will be run only on this project and its dependencies
  • clean - delete class files for the current subproject and all dependent sub-projects
  • compile - build the current project and all its dependencies
  • write-packaged-classpath - build jars for the current subproject and all of its dependencies, then output two files: classpath and allJars. These contain the absolute path to the current subproject's jars and all of its dependencies. These files are used by the shell scripts described in the next section.
  • run - run the mainclass for the current subproject, if there are multiple choices you will be prompted for which one you want to run
  • test - run the testcases for the current subproject and all its dependencies

Any of the above commands can be prefixed with a tilde (ex: ~compile). SBT will then rerun the command anytime any sourcefile is changed.

Helpful shell scripts

Note the following scripts rely on the presence of the classpath and alljars files which are produced by running write-packaged-classpath

  • bin/mvnconsole - starts up a scala console
  • bin/assembly - builds an uberjar of the current subproject and all its dependencies. the output file will be names scads.jar
Clone this wiki locally