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.
Andrey Turbanov 57dd44a35a Do not use String literal as synchronized lock 2 lat temu
.github CI build: attach main artifacts to build 2 lat temu
.mvn/wrapper Remove obsolete .mvn/settings-read-github-packages.xml 3 lat temu
ajde Reduce 'Object' class usage 2 lat temu
ajde.core Reduce 'Object' class usage 2 lat temu
ajdoc Remove redundant casts after generics update 2 lat temu
asm Reduce 'Object' class usage 2 lat temu
aspectjmatcher Set version to 1.9.10-SNAPSHOT 2 lat temu
aspectjrt Set version to 1.9.10-SNAPSHOT 2 lat temu
aspectjtools Remove AspectJ Browser (ajbrowser) code and documentation 2 lat temu
aspectjweaver Set version to 1.9.10-SNAPSHOT 2 lat temu
bcel-builder Remove redundant casts after generics update 2 lat temu
bridge Set version to 1.9.10-SNAPSHOT 2 lat temu
build Reduce 'Object' class usage 2 lat temu
docs JavaVersionCompatibility.md: add link to "Java language changes since Java 9" 2 lat temu
installer Set version to 1.9.10-SNAPSHOT 2 lat temu
lib Remove obsolete comments in POM mentioning GitHub Packages 2 lat temu
loadtime Do not use String literal as synchronized lock 2 lat temu
org.aspectj.ajdt.core Reduce 'Object' class usage 2 lat temu
org.aspectj.matcher Reduce 'Object' class usage 2 lat temu
run-all-junit-tests Remove AspectJ Browser (ajbrowser) code and documentation 2 lat temu
runtime Remove redundant casts after generics update 2 lat temu
taskdefs Reduce 'Object' class usage 2 lat temu
testing Set version to 1.9.10-SNAPSHOT 2 lat temu
testing-client Set version to 1.9.10-SNAPSHOT 2 lat temu
testing-drivers Set version to 1.9.10-SNAPSHOT 2 lat temu
testing-util Set version to 1.9.10-SNAPSHOT 2 lat temu
tests Remove AspectJ Browser (ajbrowser) code and documentation 2 lat temu
util Remove redundant casts after generics update 2 lat temu
weaver Remove redundant casts after generics update 2 lat temu
.editorconfig Add a basic .editorconfig file 3 lat temu
.gitignore Provision libraries in 'lib' automatically 3 lat temu
CODE_OF_CONDUCT.md housekeeping 2 lat temu
CONTRIBUTING.md ECA reference 2 lat temu
LICENSE Upgrade license from CPLv1/EPLv1 to EPLv2 2 lat temu
README.md Docs: add AspectJ Java version compatibility table 2 lat temu
mvnw Update to Maven 3.6.3 3 lat temu
mvnw.cmd Update to Maven 3.6.3 3 lat temu
pom.xml Remove AspectJ Browser (ajbrowser) code and documentation 2 lat temu

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 the org.aspectj groupID: https://search.maven.org/search?q=g:org.aspectj