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.
Andy Clement 065a854ee6
Merge pull request #116 from kriegaex/release-198
20 hours ago
.github/workflows Remove Java 8 from GitHub workflow (ECJ needs Java 11+) 3 months ago
.mvn/wrapper Remove obsolete .mvn/settings-read-github-packages.xml 8 months ago
ajbrowser Replace uses of StringBuffer with StringBuilder. 1 month ago
ajde Use StringBuilder/StringJoiner for concatenation String's in loop 1 month ago
ajde.core Replace uses of StringBuffer with StringBuilder. 1 month ago
ajdoc Use StringBuilder/StringJoiner for concatenation String's in loop 1 month ago
asm Merge pull request #103 from turbanoff/redundant_boxing 1 month ago
aspectjmatcher Set version to 1.9.8-SNAPSHOT 6 months ago
aspectjrt Set version to 1.9.8-SNAPSHOT 6 months ago
aspectjtools Set version to 1.9.8-SNAPSHOT 6 months ago
aspectjweaver Set version to 1.9.8-SNAPSHOT 6 months ago
bcel-builder Couple of basic tests for the repository optimizations 4 days ago
bridge Reduce empty array allocations 1 month ago
build Merge pull request #101 from turbanoff/use_StringBuilder_instead_of_StringBuffer 1 month ago
docs Add more content to README-198.html 22 hours ago
installer Set version to 1.9.8-SNAPSHOT 6 months ago
lib Bump download-maven-plugin to 1.6.7 4 months ago
loadtime Reduce empty array allocations 1 month ago
org.aspectj.ajdt.core Fix annotation style support for if(true) and if(false) 1 day ago
org.aspectj.lib Upgrade license from CPLv1/EPLv1 to EPLv2 7 months ago
org.aspectj.matcher Merge pull request #104 from turbanoff/use_generic_instead_of_raw_types 1 week ago
run-all-junit-tests Set version to 1.9.8-SNAPSHOT 6 months ago
runtime Update 'runtime' code to use generics 1 week ago
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. 18 years ago
taskdefs Use StringBuilder/StringJoiner for concatenation String's in loop 1 month ago
testing Merge pull request #103 from turbanoff/redundant_boxing 1 month ago
testing-client Set version to 1.9.8-SNAPSHOT 6 months ago
testing-drivers Replace uses of StringBuffer with StringBuilder. 1 month ago
testing-util Replace uses of StringBuffer with StringBuilder. 1 month ago
tests Fix annotation style support for if(true) and if(false) 1 day ago
util Reduce empty array allocations 1 month ago
weaver Merge pull request #113 from turbanoff/use_generic_in_weaver_module 4 days ago
.editorconfig Add a basic .editorconfig file 1 year ago
.gitignore Provision libraries in 'lib' automatically 8 months ago
CODE_OF_CONDUCT.md housekeeping 8 months ago
CONTRIBUTING.md ECA reference 8 months ago
LICENSE Upgrade license from CPLv1/EPLv1 to EPLv2 7 months ago
README.md Add "Setting up an AspectJ development environment" guide 5 months ago
mvnw Update to Maven 3.6.3 1 year ago
mvnw.cmd Update to Maven 3.6.3 1 year ago
pom.xml Set version to 1.9.8-SNAPSHOT 1 month 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 the org.aspectj groupID: https://search.maven.org/search?q=g:org.aspectj