You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Alexander Kriegisch bbe629bc4a Always use ":leveloffset: +1" with ":doctype: book" 3 kuukautta sitten
.github Attach installer to CI build 4 kuukautta sitten
.mvn/wrapper Remove obsolete .mvn/settings-read-github-packages.xml 3 vuotta sitten
ajde Workaround for defining classes during LTW 4 kuukautta sitten
ajde.core Workaround for defining classes during LTW 4 kuukautta sitten
ajdoc Workaround for defining classes during LTW 4 kuukautta sitten
asm Set version to 1.9.21.1-SNAPSHOT 5 kuukautta sitten
aspectjmatcher Remove unnecessary agent manifest entries from aspectjmatcher POM 4 kuukautta sitten
aspectjrt Update assemblies to include AspectJ licence 4 kuukautta sitten
aspectjtools Workaround for defining classes during LTW 4 kuukautta sitten
aspectjweaver Workaround for defining classes during LTW 4 kuukautta sitten
bcel-builder Set version to 1.9.21.1-SNAPSHOT 5 kuukautta sitten
bridge Delete obsolete files 4 kuukautta sitten
build Update InstallContext.onWindowsPro for Windows 11+ 4 kuukautta sitten
docs Always use ":leveloffset: +1" with ":doctype: book" 3 kuukautta sitten
installer Update assemblies to include AspectJ licence 4 kuukautta sitten
lib Replace HTML content of readme-lib-module.adoc by asciidoc 4 kuukautta sitten
loadtime Workaround for defining classes during LTW 4 kuukautta sitten
org.aspectj.ajdt.core Workaround for defining classes during LTW 4 kuukautta sitten
org.aspectj.matcher Globally replace HTTP links to eclipse.org by HTTPS 4 kuukautta sitten
run-all-junit-tests Workaround for defining classes during LTW 4 kuukautta sitten
runtime Globally fix spelling error "dependancy/dependancies" 4 kuukautta sitten
taskdefs Workaround for defining classes during LTW 4 kuukautta sitten
testing Workaround for defining classes during LTW 4 kuukautta sitten
testing-client Set version to 1.9.21.1-SNAPSHOT 5 kuukautta sitten
testing-drivers Workaround for defining classes during LTW 4 kuukautta sitten
testing-util Globally replace HTTP links to eclipse.org by HTTPS 4 kuukautta sitten
tests Remove some old files relating to AspectJ Debugger ajdb 3 kuukautta sitten
util Set version to 1.9.21.1-SNAPSHOT 5 kuukautta sitten
weaver Workaround for defining classes during LTW 4 kuukautta sitten
.editorconfig Add a basic .editorconfig file 3 vuotta sitten
.gitignore Remove obsolete DocBook build config in favour of Asciidoctor 4 kuukautta sitten
CODE_OF_CONDUCT.md housekeeping 3 vuotta sitten
CONTRIBUTING.md ECA reference 3 vuotta sitten
LICENSE Upgrade license from CPLv1/EPLv1 to EPLv2 3 vuotta sitten
README.md README.md: Beautify link to Maven Central 4 kuukautta sitten
mvnw Update to Maven 3.6.3 3 vuotta sitten
mvnw.cmd Update to Maven 3.6.3 3 vuotta sitten
pom.xml Bump asciidoctor-maven-plugin to 2.2.5 4 kuukautta sitten

README.md

AspectJ

AspectJ is:

  • a seamless aspect-oriented extension to the Java programming language
  • Java platform compatible
  • easy to learn and use

AspectJ enables:

  • clean modularization of crosscutting concerns, such as error checking and handling, synchronization, context-sensitive behavior, performance optimizations, monitoring and logging, debugging support, and multi-object protocols

Building

AspectJ has a multi-module Maven build. Although various modules produce intermediate results, the key artifacts at the end of the build are:

  • aspectjrt - the AspectJ runtime
  • aspectjweaver - the AspectJ weaver
  • aspectjtools - the AspectJ compiler
  • aspectjmatcher - the AspectJ matcher

These are the artifacts published to Maven Central for each release. In addition, there is an installer that can be run with java -jar to install AspectJ onto Windows/Mac/Linux. This installer is produced by the installer sub-module.

In the root of a cloned AspectJ simply run:

./mvnw clean install

You can also use a reasonably recent (3.6.3+), locally installed Maven installation instead of the Maven wrapper script.

This will build all the modules, run all the tests and install the key artifacts in your local repository. Once built, access the Maven dependencies from your local repository or run the installer to install AspectJ locally:

java -jar installer/target/aspectj-<VERSION>.jar

Running the tests in Eclipse

Once you have imported all the projects using m2e, there is a special module called run-all-junit-tests and within that a RunTheseBeforeYouCommitTests class that can be run with the JUnit launcher to execute thousands of tests. Ensure you run this with a JDK - the more recent the better since some tests will not execute on older JDKs - tests that verify language features that only exist in the more up to date JDK version.

Documentation for AspectJ users

Documentation for AspectJ developers

Maven releases

AspectJ is published to Maven Central under group ID org.aspectj.