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 80e0c5adc8 Replace more usages of StringBuffer with StringBuilder преди 2 години
.github/workflows Remove Java 8 from GitHub workflow (ECJ needs Java 11+) преди 2 години
.mvn/wrapper Remove obsolete .mvn/settings-read-github-packages.xml преди 3 години
ajbrowser Replace uses of StringBuffer with StringBuilder. преди 2 години
ajde Replace uses of StringBuffer with StringBuilder. преди 2 години
ajde.core Replace uses of StringBuffer with StringBuilder. преди 2 години
ajdoc Replace more usages of StringBuffer with StringBuilder преди 2 години
asm Replace uses of StringBuffer with StringBuilder. преди 2 години
aspectjmatcher Set version to 1.9.8-SNAPSHOT преди 3 години
aspectjrt Set version to 1.9.8-SNAPSHOT преди 3 години
aspectjtools Set version to 1.9.8-SNAPSHOT преди 3 години
aspectjweaver Set version to 1.9.8-SNAPSHOT преди 3 години
bcel-builder Replace more usages of StringBuffer with StringBuilder преди 2 години
bridge Replace uses of StringBuffer with StringBuilder. преди 2 години
build Merge pull request #101 from turbanoff/use_StringBuilder_instead_of_StringBuffer преди 2 години
docs Set version to 1.9.8-SNAPSHOT преди 2 години
installer Set version to 1.9.8-SNAPSHOT преди 3 години
lib Bump download-maven-plugin to 1.6.7 преди 2 години
loadtime Replace uses of StringBuffer with StringBuilder. преди 2 години
org.aspectj.ajdt.core Replace more usages of StringBuffer with StringBuilder преди 2 години
org.aspectj.lib Upgrade license from CPLv1/EPLv1 to EPLv2 преди 3 години
org.aspectj.matcher Replace more usages of StringBuffer with StringBuilder преди 2 години
run-all-junit-tests Set version to 1.9.8-SNAPSHOT преди 3 години
runtime Replace uses of StringBuffer with StringBuilder. преди 2 години
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 години
taskdefs Merge pull request #101 from turbanoff/use_StringBuilder_instead_of_StringBuffer преди 2 години
testing Merge pull request #101 from turbanoff/use_StringBuilder_instead_of_StringBuffer преди 2 години
testing-client Set version to 1.9.8-SNAPSHOT преди 3 години
testing-drivers Replace uses of StringBuffer with StringBuilder. преди 2 години
testing-util Replace uses of StringBuffer with StringBuilder. преди 2 години
tests Merge pull request #102 from turbanoff/trim_trailing_whitespaces преди 2 години
util Replace more usages of StringBuffer with StringBuilder преди 2 години
weaver Merge pull request #102 from turbanoff/trim_trailing_whitespaces преди 2 години
.editorconfig Add a basic .editorconfig file преди 3 години
.gitignore Provision libraries in 'lib' automatically преди 3 години
CODE_OF_CONDUCT.md housekeeping преди 3 години
CONTRIBUTING.md ECA reference преди 3 години
LICENSE Upgrade license from CPLv1/EPLv1 to EPLv2 преди 3 години
README.md Add "Setting up an AspectJ development environment" guide преди 2 години
mvnw Update to Maven 3.6.3 преди 3 години
mvnw.cmd Update to Maven 3.6.3 преди 3 години
pom.xml Set version to 1.9.8-SNAPSHOT преди 2 години

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