sbt-aspectj-runner

sbt plugin for running aspectj weaver

  • Owner: kamon-io/sbt-aspectj-runner
  • Platform:
  • License:: Other
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

sbt-aspectj-runner

Build Status
Download

This project contains two sbt plugins that automatically configure your build to perform Load-time weaving (LTW)
with Aspectj when running your application from within SBT, both for regular applications and Play Framework projects
in development mode and ensure that your aspects will always be woven as expected.

SBT versions 0.13 and 1.0 are supported.

Why this plugin?

First and foremost, simplicity. Although adding the AspectJ Weaver agent is just about adding the -javaagent option
to the JVM, doing so can be challenging when running from SBT. These plugins take care of the corner cases and ensure
that hitting run will just work, regardless your project type or whether you are forking the JVM or not.

Regular Projects (non-Play)

Configuring

Add the sbt-aspectj-runner plugin to your project/plugins.sbt file using the code bellow:

resolvers += Resolver.bintrayRepo("kamon-io", "sbt-plugins")
addSbtPlugin("io.kamon" % "sbt-aspectj-runner" % "1.1.1")

Running

Just run, like you do all the time!

Here is what the plugin will do depending on your fork settings:

  • fork in run := true: The forked process will run with the -javaagent:<jarpath> and that's all.
  • fork in run := false: A custom classloader called WeavingURLClassLoader will be used. This classloader will
    perform the same load-time weaving duties done by the AspectJ Weaver agent.

Play Projects

Configuring

For Play Framework 2.7 projects add the sbt-aspectj-runner-play-2.7 to your project/plugins.sbt file:

resolvers += Resolver.bintrayIvyRepo("kamon-io", "sbt-plugins")
addSbtPlugin("io.kamon" % "sbt-aspectj-runner-play-2.7" % "1.1.2")

For Play Framework 2.6 projects add the sbt-aspectj-runner-play-2.6 to your project/plugins.sbt file:

resolvers += Resolver.bintrayIvyRepo("kamon-io", "sbt-plugins")
addSbtPlugin("io.kamon" % "sbt-aspectj-runner-play-2.6" % "1.1.2")

For Play 2.4 and 2.5 you can use the older sbt-aspectj-play-runner plugin:

resolvers += Resolver.bintrayIvyRepo("kamon-io", "sbt-plugins")
addSbtPlugin("io.kamon" % "sbt-aspectj-play-runner" % "1.0.4")

This plugin has been tested with Play 2.4.8, Play 2.5.10, Play 2.6.11 and Play 2.7.0.

Running

Just run, like you do all the time! A notice will be shown saying that you are running your application with the
AspectJ Weaver.

The Play Framework SBT plugin will not allow the JVM to be forked so this plugin will override the way class loaders are
created to use WeavingURLClassLoader instead, making sure that aspects will be woven when running on Development mode.

Examples

There are full runnable examples.

Overview

Name With Ownerkamon-io/sbt-aspectj-runner
Primary LanguageScala
Program languageScala (Language Count: 1)
Platform
License:Other
Release Count4
Last Release Namev1.1.1 (Posted on )
First Release Namev1.0.0 (Posted on 2017-01-20 13:26:58)
Created At2015-08-07 13:01:03
Pushed At2021-05-04 09:56:55
Last Commit At2019-02-22 17:59:21
Stargazers Count34
Watchers Count7
Fork Count18
Commits Count76
Has Issues Enabled
Issues Count25
Issue Open Count12
Pull Requests Count10
Pull Requests Open Count1
Pull Requests Close Count1
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private
To the top