This is a buildpack for Scala apps. It uses sbt 0.11.0+.
Example usage:
$ ls
Procfile build.sbt project src
$ cctrlapp APP_NAME create java
$ cctrlapp APP_NAME push
[...]
-----> Receiving push
-----> Installing OpenJDK 1.7...-----> Installing OpenJDK 1.7(openjdk7.b32.tar.gz)...
done
-----> Downloading SBT...done
-----> Running: sbt compile stage
[...]
-----> Building image
-----> Uploading image (80M)
To ssh://[email protected]/repository.git
* [new branch] master -> master
The buildpack will detect your app as Scala if it has the project/build.properties and either .sbt or .scala based build config. It vendors a version of sbt and your populuated .ivy/cache into your image. The .ivy2 directory will be cached between builds to allow for faster build times.
To use this buildpack, fork it on Github. Push up changes to your fork, then create a test app with --buildpack <your-github-url>
and push to it.
For example, to reduce your image size by not including the .ivy2/cache, you could add the following.
for DIR in $CACHED_DIRS ; do
rm -rf $CACHE_DIR/$DIR
mkdir -p $CACHE_DIR/$DIR
cp -r $DIR/. $CACHE_DIR/$DIR
# The following 2 lines are what you would add
echo "-----> Dropping ivy cache from the image"
rm -rf $SBT_USER_HOME/.ivy2
Note: You will need to have your build copy the necessary jars to run your application to a place that will remain included with the image.
Commit and push the changes to your buildpack to your Github fork, then push your sample app to test. You should see:
...
-----> Dropping ivy cache from the image
Licensed under the MIT License. See LICENSE file.