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 cfca36da03 RELEASE.md: Deploying AspectJ installer to aspectj.dev 3 jaren geleden
.github/workflows Remove obsolete .mvn/settings-read-github-packages.xml 3 jaren geleden
.mvn/wrapper Remove obsolete .mvn/settings-read-github-packages.xml 3 jaren geleden
ajbrowser Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
ajde Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
ajde.core Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
ajdoc housekeeping 3 jaren geleden
asm Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
aspectjmatcher Set version to 1.9.7-SNAPSHOT again 3 jaren geleden
aspectjrt Set version to 1.9.7-SNAPSHOT again 3 jaren geleden
aspectjtools Set version to 1.9.7-SNAPSHOT again 3 jaren geleden
aspectjweaver Set version to 1.9.7-SNAPSHOT again 3 jaren geleden
bcel-builder Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
bridge Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
build Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
docs RELEASE.md: Deploying AspectJ installer to aspectj.dev 3 jaren geleden
installer housekeeping 3 jaren geleden
lib Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
loadtime Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
org.aspectj.ajdt.core Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
org.aspectj.lib Remove redundant 'name' and 'packaging' tags from POMs 3 jaren geleden
org.aspectj.matcher Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
run-all-junit-tests Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
runtime Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
shadows.org.eclipse.jdt.core Adrian made me put these in. We seem to need a directory containing one file in order to satisfy the build script when it builds shadows.org.eclipse.jdt.core. 20 jaren geleden
taskdefs Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
testing Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
testing-client Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
testing-drivers Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
testing-util Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
tests Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
util Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
weaver Use canonical snapshot version 1.9.7-SNAPSHOT 3 jaren geleden
.editorconfig Add a basic .editorconfig file 3 jaren geleden
.gitignore Provision libraries in 'lib' automatically 3 jaren geleden
CODE_OF_CONDUCT.md housekeeping 3 jaren geleden
CONTRIBUTING.md ECA reference 3 jaren geleden
LICENSE housekeeping 3 jaren geleden
README.md Add "how to release" guide and point to it from README.md 3 jaren geleden
mvnw Update to Maven 3.6.3 3 jaren geleden
mvnw.cmd Update to Maven 3.6.3 3 jaren geleden
pom.xml Set version to 1.9.7-SNAPSHOT again 3 jaren geleden

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

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