Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.
Alexander Kriegisch 7eeb27c730 Release version to 1.9.8.RC1 pirms 2 gadiem
.github/workflows Remove Java 8 from GitHub workflow (ECJ needs Java 11+) pirms 2 gadiem
.mvn/wrapper Remove obsolete .mvn/settings-read-github-packages.xml pirms 3 gadiem
ajbrowser Release version to 1.9.8.RC1 pirms 2 gadiem
ajde Release version to 1.9.8.RC1 pirms 2 gadiem
ajde.core Release version to 1.9.8.RC1 pirms 2 gadiem
ajdoc Release version to 1.9.8.RC1 pirms 2 gadiem
asm Release version to 1.9.8.RC1 pirms 2 gadiem
aspectjmatcher Release version to 1.9.8.RC1 pirms 2 gadiem
aspectjrt Release version to 1.9.8.RC1 pirms 2 gadiem
aspectjtools Release version to 1.9.8.RC1 pirms 2 gadiem
aspectjweaver Release version to 1.9.8.RC1 pirms 2 gadiem
bcel-builder Release version to 1.9.8.RC1 pirms 2 gadiem
bridge Release version to 1.9.8.RC1 pirms 2 gadiem
build Release version to 1.9.8.RC1 pirms 2 gadiem
docs Release version to 1.9.8.RC1 pirms 2 gadiem
installer Release version to 1.9.8.RC1 pirms 2 gadiem
lib Release version to 1.9.8.RC1 pirms 2 gadiem
loadtime Release version to 1.9.8.RC1 pirms 2 gadiem
org.aspectj.ajdt.core Release version to 1.9.8.RC1 pirms 2 gadiem
org.aspectj.lib Upgrade license from CPLv1/EPLv1 to EPLv2 pirms 2 gadiem
org.aspectj.matcher Release version to 1.9.8.RC1 pirms 2 gadiem
run-all-junit-tests Release version to 1.9.8.RC1 pirms 2 gadiem
runtime Release version to 1.9.8.RC1 pirms 2 gadiem
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. pirms 20 gadiem
taskdefs Release version to 1.9.8.RC1 pirms 2 gadiem
testing Release version to 1.9.8.RC1 pirms 2 gadiem
testing-client Release version to 1.9.8.RC1 pirms 2 gadiem
testing-drivers Release version to 1.9.8.RC1 pirms 2 gadiem
testing-util Release version to 1.9.8.RC1 pirms 2 gadiem
tests Release version to 1.9.8.RC1 pirms 2 gadiem
util Release version to 1.9.8.RC1 pirms 2 gadiem
weaver Release version to 1.9.8.RC1 pirms 2 gadiem
.editorconfig Add a basic .editorconfig file pirms 3 gadiem
.gitignore Provision libraries in 'lib' automatically pirms 3 gadiem
CODE_OF_CONDUCT.md housekeeping pirms 2 gadiem
CONTRIBUTING.md ECA reference pirms 2 gadiem
LICENSE Upgrade license from CPLv1/EPLv1 to EPLv2 pirms 2 gadiem
README.md Add "Setting up an AspectJ development environment" guide pirms 2 gadiem
mvnw Update to Maven 3.6.3 pirms 3 gadiem
mvnw.cmd Update to Maven 3.6.3 pirms 3 gadiem
pom.xml Release version to 1.9.8.RC1 pirms 2 gadiem

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