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 47db35bb48 New abstract class JavaVersionSpecificXMLBasedAjcTestCase 2 months ago
.github Add 'AspectJ_JDK_Update' hint in various places 2 months ago
.mvn/wrapper Remove obsolete .mvn/settings-read-github-packages.xml 3 years ago
ajde LangUtil: remove methods like 'is11VMOrGreater', 'is1dot5VMOrGreater' 2 months ago
ajde.core LangUtil: remove methods like 'is11VMOrGreater', 'is1dot5VMOrGreater' 2 months ago
ajdoc LangUtil: remove methods like 'is11VMOrGreater', 'is1dot5VMOrGreater' 2 months ago
asm Set version to 1.9.22-SNAPSHOT 2 months ago
aspectjmatcher Run Antrun post-javadoc task depending on Javadoc execution 2 months ago
aspectjrt Run Antrun post-javadoc task depending on Javadoc execution 2 months ago
aspectjtools Run Antrun post-javadoc task depending on Javadoc execution 2 months ago
aspectjweaver Run Antrun post-javadoc task depending on Javadoc execution 2 months ago
bcel-builder Remove most MINOR_*, MINOR_* BCEL class file versions 2 months ago
bridge LangUtil: remove methods like 'is11VMOrGreater', 'is1dot5VMOrGreater' 2 months ago
build Remove obsolete stuff from module 'build' and lib/build 2 months ago
docs Add 'AspectJ_JDK_Update' hint in various places 2 months ago
installer Set version to 1.9.22-SNAPSHOT 2 months ago
lib Remove obsolete stuff from module 'build' and lib/build 2 months ago
loadtime Set version to 1.9.22-SNAPSHOT 2 months ago
org.aspectj.ajdt.core LangUtil: remove methods like 'is11VMOrGreater', 'is1dot5VMOrGreater' 2 months ago
org.aspectj.matcher LangUtil: remove methods like 'is11VMOrGreater', 'is1dot5VMOrGreater' 2 months ago
run-all-junit-tests Set version to 1.9.22-SNAPSHOT 2 months ago
runtime Set version to 1.9.22-SNAPSHOT 2 months ago
taskdefs New abstract class JavaVersionSpecificXMLBasedAjcTestCase 2 months ago
testing New abstract class JavaVersionSpecificXMLBasedAjcTestCase 2 months ago
testing-client Set version to 1.9.22-SNAPSHOT 2 months ago
testing-drivers Set version to 1.9.22-SNAPSHOT 2 months ago
testing-util Globally replace "http:" by "https:" in non-XML files 2 months ago
tests New abstract class JavaVersionSpecificXMLBasedAjcTestCase 2 months ago
util New abstract class JavaVersionSpecificXMLBasedAjcTestCase 2 months ago
weaver LangUtil: remove methods like 'is11VMOrGreater', 'is1dot5VMOrGreater' 2 months ago
.editorconfig Add a basic .editorconfig file 3 years ago
.gitignore Remove obsolete DocBook build config in favour of Asciidoctor 4 months ago
.mailmap Add Git .mailmap file 2 months ago
CODE_OF_CONDUCT.md housekeeping 3 years ago
CONTRIBUTING.md Replace old by new AspectJ GitHub URL 3 months ago
LICENSE Upgrade license from CPLv1/EPLv1 to EPLv2 2 years ago
README.md Fix some docs links 2 months ago
mvnw Update to Maven 3.6.3 3 years ago
mvnw.cmd Update to Maven 3.6.3 3 years ago
pom.xml Add 'AspectJ_JDK_Update' hint in various places 2 months ago

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.