aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndy Clement <aclement@pivotal.io>2021-05-10 11:21:46 -0700
committerGitHub <noreply@github.com>2021-05-10 11:21:46 -0700
commit47b9a0dfa872a316e8668b718fbdd63346e88fca (patch)
tree49e7cecf8930dbbef992d1ea3dff896383d7ffb0
parentbdb89385dd387464ab02d7655ac8d5486d32c2fc (diff)
parenta57efcafcfbab31635048cac9e02bbc55276573c (diff)
downloadaspectj-47b9a0dfa872a316e8668b718fbdd63346e88fca.tar.gz
aspectj-47b9a0dfa872a316e8668b718fbdd63346e88fca.zip
Merge pull request #46 from kriegaex/lib-auto-provisioning
Provision libraries in `lib` automatically
-rw-r--r--.github/workflows/maven.yml3
-rw-r--r--.gitignore3
-rw-r--r--ajde.core/pom.xml5
-rw-r--r--ajdoc/pom.xml6
-rw-r--r--aspectjtools/pom.xml2
-rw-r--r--bcel-builder/pom.xml8
-rw-r--r--build/pom.xml5
-rw-r--r--docs/pom.xml9
-rw-r--r--lib/pom.xml1268
-rw-r--r--org.aspectj.ajdt.core/pom.xml6
-rw-r--r--pom.xml51
-rw-r--r--run-all-junit-tests/pom.xml6
-rw-r--r--taskdefs/pom.xml6
-rw-r--r--testing-util/pom.xml5
-rw-r--r--testing/pom.xml6
-rw-r--r--tests/pom.xml6
-rw-r--r--util/pom.xml9
-rw-r--r--weaver/pom.xml6
18 files changed, 774 insertions, 636 deletions
diff --git a/.github/workflows/maven.yml b/.github/workflows/maven.yml
index bd6b9de64..585f75ac3 100644
--- a/.github/workflows/maven.yml
+++ b/.github/workflows/maven.yml
@@ -31,9 +31,6 @@ jobs:
./mvnw -B --version
ant -version
- - name: Download + install test libraries
- run: ./mvnw -B --settings .mvn/settings-read-github-packages.xml --file lib/pom.xml compile
-
- name: Compile + package code
run: ./mvnw -B --settings .mvn/settings-read-github-packages.xml --file pom.xml -DskipTests package
diff --git a/.gitignore b/.gitignore
index 002bcb352..d0b7450be 100644
--- a/.gitignore
+++ b/.gitignore
@@ -31,7 +31,8 @@ log.txt
# No idea where these come from
bin/
-# Downloaded libraries used during tests
+# Downloaded libraries used during tests + marker file
+/lib/provisioned.marker
/lib/ant/
/lib/commons/
/lib/docbook/
diff --git a/ajde.core/pom.xml b/ajde.core/pom.xml
index 59b588f69..3121c4f49 100644
--- a/ajde.core/pom.xml
+++ b/ajde.core/pom.xml
@@ -13,6 +13,11 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>
diff --git a/ajdoc/pom.xml b/ajdoc/pom.xml
index 787f27600..e071e10c3 100644
--- a/ajdoc/pom.xml
+++ b/ajdoc/pom.xml
@@ -29,6 +29,12 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>
diff --git a/aspectjtools/pom.xml b/aspectjtools/pom.xml
index 7860f3a5a..7f9f1063a 100644
--- a/aspectjtools/pom.xml
+++ b/aspectjtools/pom.xml
@@ -11,7 +11,7 @@
</parent>
<artifactId>aspectjtools</artifactId>
- <name>AspectJ Compiler</name>
+ <name>AspectJ Tools (Compiler)</name>
<build>
<plugins>
diff --git a/bcel-builder/pom.xml b/bcel-builder/pom.xml
index b1c8038bb..2188c7918 100644
--- a/bcel-builder/pom.xml
+++ b/bcel-builder/pom.xml
@@ -11,4 +11,12 @@
<artifactId>bcel-builder</artifactId>
+ <dependencies>
+ <dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ </dependency>
+ </dependencies>
+
</project>
diff --git a/build/pom.xml b/build/pom.xml
index 477689b27..302d90388 100644
--- a/build/pom.xml
+++ b/build/pom.xml
@@ -13,6 +13,11 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ </dependency>
+ <dependency>
<!-- Identical to lib/ant/lib/ant.jar, a former system-scoped dependency -->
<groupId>ant</groupId>
<artifactId>ant</artifactId>
diff --git a/docs/pom.xml b/docs/pom.xml
index bc20408d8..edefc4f93 100644
--- a/docs/pom.xml
+++ b/docs/pom.xml
@@ -87,6 +87,15 @@
</plugins>
</build>
+
+ <dependencies>
+ <dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ </dependency>
+ </dependencies>
+
</profile>
</profiles>
diff --git a/lib/pom.xml b/lib/pom.xml
index 1e624c460..e2a186b38 100644
--- a/lib/pom.xml
+++ b/lib/pom.xml
@@ -12,7 +12,6 @@
<artifactId>lib</artifactId>
- <name>AspectJ Test Libraries</name>
<description>
This module downloads + installs libraries used by many tests, especially those running as Ant jobs. You should not
build this module during every build because it is somewhat slow, downloading stuff from 3rd-party websites,
@@ -33,626 +32,719 @@
<!-- TODO: Add lib (for now, then finally lib) to .gitignore -->
<properties>
+ <lib.provisioned.marker>provisioned.marker</lib.provisioned.marker>
<lib.ant.name>apache-ant</lib.ant.name>
<lib.ant.artifact>${lib.ant.name}-${lib.ant.version}</lib.ant.artifact>
</properties>
- <build>
- <plugins>
+ <profiles>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-enforcer-plugin</artifactId>
- <executions>
- <execution>
- <!--
- Deactivate this execution from the parent, because here it would be counter-productive, given the fact
- that this module must be built before the enforcer rule can even pass elsewhere.
- -->
- <id>enforce-libraries-exist</id>
- <phase>none</phase>
- </execution>
- </executions>
- </plugin>
+ <!-- Profile for provisioning - i.e. downloading and (un)zipping - libraries needed during the build -->
+ <profile>
+ <id>provision-libs</id>
- <plugin>
- <groupId>com.googlecode.maven-download-plugin</groupId>
- <artifactId>download-maven-plugin</artifactId>
- <version>1.6.1</version>
- <executions>
- <execution>
- <id>download-ant-binaries</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://archive.apache.org/dist/ant/binaries/${lib.ant.artifact}-bin.zip</url>
- <outputDirectory>ant</outputDirectory>
- <sha1>3fa9f816a0c4c63249efad8e6225f2e83794f0c0</sha1>
- </configuration>
- </execution>
- <execution>
- <id>download-ant-sources</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://archive.apache.org/dist/ant/source/${lib.ant.artifact}-src.zip</url>
- <outputDirectory>ant</outputDirectory>
- <sha1>b9f3c8c31bb6c9069ad5b655059a17769af12f20</sha1>
- </configuration>
- </execution>
- <execution>
- <id>download-beanutils-sources</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://github.com/apache/commons-beanutils/archive/refs/tags/${lib.commons.beanutils.tag}.zip</url>
- <outputDirectory>commons</outputDirectory>
- <outputFileName>commons-beanutils-${lib.commons.beanutils.version}-sources.jar</outputFileName>
- <sha1>b2c02afe7e6475cd7c811932b8415d171a8afa00</sha1>
- </configuration>
- </execution>
- <execution>
- <id>download-collections-sources</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://github.com/apache/commons-collections/archive/refs/tags/${lib.commons.collections.tag}.zip</url>
- <outputDirectory>commons</outputDirectory>
- <outputFileName>commons-collections-${lib.commons.collections.version}-sources.jar</outputFileName>
- <sha1>824cacd0aafe21a94fb142388fd62f28a12df5ef</sha1>
- </configuration>
- </execution>
- <execution>
- <id>download-digester-sources</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://github.com/apache/commons-digester/archive/refs/tags/${lib.commons.digester.tag}.zip</url>
- <outputDirectory>commons</outputDirectory>
- <outputFileName>commons-digester-${lib.commons.digester.version}-sources.jar</outputFileName>
- <sha1>49f653c7ea726301c564f9662b72c051fee9390a</sha1>
- </configuration>
- </execution>
- <execution>
- <id>download-logging-sources</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://github.com/apache/commons-logging/archive/refs/tags/${lib.commons.logging.tag}.zip</url>
- <outputDirectory>commons</outputDirectory>
- <outputFileName>commons-logging-${lib.commons.logging.version}-sources.jar</outputFileName>
- <sha1>c61a373f6d50ff8fcfba900934f7254d44f9735b</sha1>
- </configuration>
- </execution>
- <execution>
- <id>download-docbook-dtd</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://www.oasis-open.org/docbook/xml/4.1.2/docbkx412.zip</url>
- <outputDirectory>docbook</outputDirectory>
- <outputFileName>docbkx412.zip</outputFileName>
- <sha1>b9ae7a41056bfaf885581812d60651b7b5531519</sha1>
- </configuration>
- </execution>
- <execution>
- <id>download-docbook-xsl</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://sourceforge.net/projects/docbook/files/OldFiles/docbook-xsl-1.44.zip/download</url>
- <outputDirectory>docbook</outputDirectory>
- <outputFileName>docbook-xsl-1.44.zip</outputFileName>
- <sha1>626e7bee806ea14812f6f95cc2d187ab6ba9114a</sha1>
- </configuration>
- </execution>
- <!--
- Obsolete because we uploaded both binary and source JARs to GitHub Packages, so we can use JDiff as a
- normal dependency. Keep this for reference, so we can remember where we found it.
- -->
- <!--
- <execution>
- <id>download-jdiff</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>wget</goal>
- </goals>
- <configuration>
- <url>https://downloads.sourceforge.net/project/jedit-plugins/JDiffPlugin/1.3/JDiffPlugin-1.3.zip</url>
- <outputDirectory>jdiff</outputDirectory>
- <outputFileName>JDiffPlugin-1.3.zip</outputFileName>
- <sha1>eba63fd845203c6b245fbcb81c0de8e2c83d16c7</sha1>
- </configuration>
- </execution>
- -->
- </executions>
- </plugin>
+ <!-- If marker file is missing, activate profile and provision all libraries -->
+ <activation>
+ <file>
+ <missing>${lib.provisioned.marker}</missing>
+ </file>
+ </activation>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-dependency-plugin</artifactId>
- <version>3.1.2</version>
- <executions>
- <execution>
- <id>copy</id>
- <phase>generate-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <artifactItems>
-
- <artifactItem>
- <!-- Available from GitHub Packages (needs special repository declaration) -->
- <groupId>org.aspectj</groupId>
- <artifactId>org.eclipse.jdt.core</artifactId>
- <version>${jdt.core.version}</version>
- <type>jar</type>
- <overWrite>false</overWrite>
- <outputDirectory>jdtcore-aj</outputDirectory>
- <destFileName>jdtcore-for-aspectj.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Available from GitHub Packages (needs special repository declaration) -->
- <groupId>org.aspectj</groupId>
- <artifactId>org.eclipse.jdt.core</artifactId>
- <version>${jdt.core.version}</version>
- <type>java-source</type>
- <classifier>sources</classifier>
- <overWrite>false</overWrite>
- <outputDirectory>jdtcore-aj</outputDirectory>
- <destFileName>jdtcore-for-aspectj-src.zip</destFileName>
- </artifactItem>
-
- <artifactItem>
- <!-- Binary is identical to committed version in branch 'jdtcore-new' -->
- <groupId>com.googlecode.jarjar</groupId>
- <artifactId>jarjar</artifactId>
- <version>1.3</version>
- <type>jar</type>
- <overWrite>false</overWrite>
- <outputDirectory>jarjar</outputDirectory>
- <destFileName>jarjar-1.3.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <version>3.8.1</version>
- <type>jar</type>
- <overWrite>false</overWrite>
- <outputDirectory>junit</outputDirectory>
- <destFileName>junit.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <!-- TODO: Is this redundant JUnit JAR in ant/lib really necessary? If so, why? -->
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <version>3.8.1</version>
- <type>jar</type>
- <overWrite>false</overWrite>
- <outputDirectory>ant/lib</outputDirectory>
- <destFileName>junit.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <version>3.8.1</version>
- <type>jar</type>
- <classifier>sources</classifier>
- <overWrite>false</overWrite>
- <outputDirectory>junit</outputDirectory>
- <destFileName>junit-src.zip</destFileName>
- </artifactItem>
-
- <!-- Jython does not seem to be used anywhere in AspectJ -->
-
- <artifactItem>
- <!-- Binary is a bit newer than committed version, but produces identical results in 'docs' -->
- <groupId>saxon</groupId>
- <artifactId>saxon</artifactId>
- <version>6.5.3</version>
- <type>jar</type>
- <overWrite>false</overWrite>
- <outputDirectory>saxon</outputDirectory>
- <destFileName>saxon.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <groupId>regexp</groupId>
- <artifactId>regexp</artifactId>
- <version>${lib.regexp.version}</version>
- <type>jar</type>
- <overWrite>false</overWrite>
- <outputDirectory>regexp</outputDirectory>
- <destFileName>jakarta-regexp-1.2.jar</destFileName>
- </artifactItem>
-
- <!--
- About commons.jar + commons-src.zip:
- - Beanutils Binaries are commons-beanutils:commons-beanutils:1.4 (no sources on Maven Central, but
- https://github.com/apache/commons-beanutils/archive/refs/tags/BEANUTILS_1_4.zip)
- - Collections: Binaries are commons-collections:commons-collections:2.0 (no sources on Maven Central, but
- https://github.com/apache/commons-collections/archive/refs/tags/collections-2.0.zip)
- - Digester: Binaries are commons-digester:commons-digester:1.3 (no sources on Maven Central, but
- https://github.com/apache/commons-digester/archive/refs/tags/DIGESTER_1_3.zip)
- - Logging: Binaries are commons-logging:commons-logging:1.0.1 (no sources on Maven Central, but
- https://github.com/apache/commons-logging/archive/refs/tags/LOGGING_1_0_1.zip)
- -->
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <!-- TODO: not used anywhere -> remove -->
- <groupId>commons-beanutils</groupId>
- <artifactId>commons-beanutils</artifactId>
- <version>${lib.commons.beanutils.version}</version>
- <type>jar</type>
- <overWrite>false</overWrite>
+ <build>
+ <plugins>
+
+ <!-- Download libraries + source code which are unavailable in Maven repositories like Maven Central -->
+ <plugin>
+ <groupId>com.googlecode.maven-download-plugin</groupId>
+ <artifactId>download-maven-plugin</artifactId>
+ <version>1.6.3</version>
+ <executions>
+ <execution>
+ <id>download-ant-binaries</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://archive.apache.org/dist/ant/binaries/${lib.ant.artifact}-bin.zip</url>
+ <outputDirectory>ant</outputDirectory>
+ <sha1>3fa9f816a0c4c63249efad8e6225f2e83794f0c0</sha1>
+ </configuration>
+ </execution>
+ <execution>
+ <id>download-ant-sources</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://archive.apache.org/dist/ant/source/${lib.ant.artifact}-src.zip</url>
+ <outputDirectory>ant</outputDirectory>
+ <sha1>b9f3c8c31bb6c9069ad5b655059a17769af12f20</sha1>
+ </configuration>
+ </execution>
+ <execution>
+ <id>download-beanutils-sources</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://github.com/apache/commons-beanutils/archive/refs/tags/${lib.commons.beanutils.tag}.zip</url>
<outputDirectory>commons</outputDirectory>
- <destFileName>commons-beanutils-${lib.commons.beanutils.version}.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <!-- TODO: not used anywhere -> remove -->
- <groupId>commons-collections</groupId>
- <artifactId>commons-collections</artifactId>
- <version>2.0</version>
- <type>jar</type>
- <overWrite>false</overWrite>
+ <outputFileName>commons-beanutils-${lib.commons.beanutils.version}-sources.jar</outputFileName>
+ <sha1>b2c02afe7e6475cd7c811932b8415d171a8afa00</sha1>
+ </configuration>
+ </execution>
+ <execution>
+ <id>download-collections-sources</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://github.com/apache/commons-collections/archive/refs/tags/${lib.commons.collections.tag}.zip</url>
<outputDirectory>commons</outputDirectory>
- <destFileName>commons-collections-2.0.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <!-- TODO: used in module 'testing' -->
- <groupId>commons-digester</groupId>
- <artifactId>commons-digester</artifactId>
- <version>${lib.commons.digester.version}</version>
- <type>jar</type>
- <overWrite>false</overWrite>
+ <outputFileName>commons-collections-${lib.commons.collections.version}-sources.jar</outputFileName>
+ <sha1>824cacd0aafe21a94fb142388fd62f28a12df5ef</sha1>
+ </configuration>
+ </execution>
+ <execution>
+ <id>download-digester-sources</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://github.com/apache/commons-digester/archive/refs/tags/${lib.commons.digester.tag}.zip</url>
<outputDirectory>commons</outputDirectory>
- <destFileName>commons-digester-${lib.commons.digester.version}.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <!-- TODO: used in modules 'org.aspectj.matcher' -->
- <groupId>commons-logging</groupId>
- <artifactId>commons-logging</artifactId>
- <version>${lib.commons.logging.version}</version>
- <type>jar</type>
- <overWrite>false</overWrite>
+ <outputFileName>commons-digester-${lib.commons.digester.version}-sources.jar</outputFileName>
+ <sha1>49f653c7ea726301c564f9662b72c051fee9390a</sha1>
+ </configuration>
+ </execution>
+ <execution>
+ <id>download-logging-sources</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://github.com/apache/commons-logging/archive/refs/tags/${lib.commons.logging.tag}.zip</url>
<outputDirectory>commons</outputDirectory>
- <destFileName>commons-logging-${lib.commons.logging.version}.jar</destFileName>
- </artifactItem>
-
- <!-- Libraries used to create HTML docs from XML DocBook files -->
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <groupId>fop</groupId>
- <artifactId>fop</artifactId>
- <version>0.20.5</version>
- <type>jar</type>
- <overWrite>false</overWrite>
+ <outputFileName>commons-logging-${lib.commons.logging.version}-sources.jar</outputFileName>
+ <sha1>c61a373f6d50ff8fcfba900934f7254d44f9735b</sha1>
+ </configuration>
+ </execution>
+ <execution>
+ <id>download-docbook-dtd</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://www.oasis-open.org/docbook/xml/4.1.2/docbkx412.zip</url>
<outputDirectory>docbook</outputDirectory>
- <destFileName>fop.jar</destFileName>
- </artifactItem>
- <artifactItem>
- <!-- Binary is identical to committed version -->
- <groupId>batik</groupId>
- <artifactId>batik-1.5-fop</artifactId>
- <version>0.20-5</version>
- <type>jar</type>
- <overWrite>false</overWrite>
+ <outputFileName>docbkx412.zip</outputFileName>
+ <sha1>b9ae7a41056bfaf885581812d60651b7b5531519</sha1>
+ </configuration>
+ </execution>
+ <execution>
+ <id>download-docbook-xsl</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://sourceforge.net/projects/docbook/files/OldFiles/docbook-xsl-1.44.zip/download</url>
<outputDirectory>docbook</outputDirectory>
- <destFileName>batik.jar</destFileName>
- </artifactItem>
+ <outputFileName>docbook-xsl-1.44.zip</outputFileName>
+ <sha1>626e7bee806ea14812f6f95cc2d187ab6ba9114a</sha1>
+ </configuration>
+ </execution>
+ <!--
+ Obsolete because we uploaded both binary and source JARs to GitHub Packages, so we can use JDiff as a
+ normal dependency. Keep this for reference, so we can remember where we found it.
+ -->
+ <!--
+ <execution>
+ <id>download-jdiff</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>wget</goal>
+ </goals>
+ <configuration>
+ <url>https://downloads.sourceforge.net/project/jedit-plugins/JDiffPlugin/1.3/JDiffPlugin-1.3.zip</url>
+ <outputDirectory>jdiff</outputDirectory>
+ <outputFileName>JDiffPlugin-1.3.zip</outputFileName>
+ <sha1>eba63fd845203c6b245fbcb81c0de8e2c83d16c7</sha1>
+ </configuration>
+ </execution>
+ -->
+ </executions>
+ </plugin>
- </artifactItems>
- </configuration>
- </execution>
- </executions>
- </plugin>
+ <!-- Download libraries + source code which are available in Maven repositories like Maven Central -->
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-dependency-plugin</artifactId>
+ <version>3.1.2</version>
+ <executions>
+ <execution>
+ <id>copy</id>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <artifactItems>
- <plugin>
- <groupId>org.codehaus.mojo</groupId>
- <artifactId>truezip-maven-plugin</artifactId>
- <version>1.2</version>
- <!--
- The TrueZIP plugin can seamlessly copy out of or into (nested) ZIP files as if they were normal file system
- paths. No additional moves and deletes with Antrun are necessary.
- -->
- <executions>
- <execution>
- <id>unzip-ant-binaries</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>ant/${lib.ant.artifact}-bin.zip/${lib.ant.artifact}</directory>
- <outputDirectory>ant</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-ant-sources</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>ant/${lib.ant.artifact}-src.zip/${lib.ant.artifact}/src/main</directory>
- <outputDirectory>ant/ant-src.zip</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-beanutils-binaries</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-beanutils-${lib.commons.beanutils.version}.jar</directory>
- <outputDirectory>commons/commons.jar</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-collections-binaries</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-collections-${lib.commons.collections.version}.jar</directory>
- <outputDirectory>commons/commons.jar</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-digester-binaries</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-digester-${lib.commons.digester.version}.jar</directory>
- <outputDirectory>commons/commons.jar</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-logging-binaries</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-logging-${lib.commons.logging.version}.jar</directory>
- <outputDirectory>commons/commons.jar</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-beanutils-sources</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-beanutils-${lib.commons.beanutils.version}-sources.jar/commons-beanutils-${lib.commons.beanutils.tag}/src/java</directory>
- <outputDirectory>commons/commons-src.zip</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-collections-sources</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-collections-${lib.commons.collections.version}-sources.jar/commons-collections-${lib.commons.collections.tag}/src/java</directory>
- <outputDirectory>commons/commons-src.zip</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-digester-sources</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-digester-${lib.commons.digester.version}-sources.jar/commons-digester-${lib.commons.digester.tag}/src/java</directory>
- <outputDirectory>commons/commons-src.zip</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-logging-sources</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>commons/commons-logging-${lib.commons.logging.version}-sources.jar/commons-logging-${lib.commons.logging.tag}/src/java</directory>
- <outputDirectory>commons/commons-src.zip</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>unzip-docbook-dtd</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>docbook/docbkx412.zip</directory>
- <outputDirectory>docbook/docbook-dtd</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>unzip-docbook-xsl</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>docbook/docbook-xsl-1.44.zip/docbook-xsl-1.44</directory>
- <outputDirectory>docbook/docbook-xsl</outputDirectory>
- </fileset>
- </configuration>
- </execution>
- <!--
- Obsolete because we uploaded both binary and source JARs to GitHub Packages, so we can use JDiff as a normal
- dependency. Keep this for reference, so we can remember how we built it. After download + zip the deployment
- was made right from the lib/jdiff directory, using the following commands (without the line breaks):
+ <artifactItem>
+ <!-- Available from GitHub Packages (needs special repository declaration) -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>org.eclipse.jdt.core</artifactId>
+ <version>${jdt.core.version}</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>jdtcore-aj</outputDirectory>
+ <destFileName>jdtcore-for-aspectj.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Available from GitHub Packages (needs special repository declaration) -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>org.eclipse.jdt.core</artifactId>
+ <version>${jdt.core.version}</version>
+ <type>java-source</type>
+ <classifier>sources</classifier>
+ <overWrite>false</overWrite>
+ <outputDirectory>jdtcore-aj</outputDirectory>
+ <destFileName>jdtcore-for-aspectj-src.zip</destFileName>
+ </artifactItem>
- mvn -Dfile=jdiff.jar -DrepositoryId=github -Durl=https://maven.pkg.github.com/kriegaex/aspectj-packages
- -DgroupId=jdiff -DartifactId=jdiff -Dpackaging=jar -Dversion=1.3
- deploy:deploy-file
+ <artifactItem>
+ <!-- Binary is identical to committed version in branch 'jdtcore-new' -->
+ <groupId>com.googlecode.jarjar</groupId>
+ <artifactId>jarjar</artifactId>
+ <version>1.3</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>jarjar</outputDirectory>
+ <destFileName>jarjar-1.3.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <groupId>junit</groupId>
+ <artifactId>junit</artifactId>
+ <version>3.8.1</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>junit</outputDirectory>
+ <destFileName>junit.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <!-- TODO: Is this redundant JUnit JAR in ant/lib really necessary? If so, why? -->
+ <groupId>junit</groupId>
+ <artifactId>junit</artifactId>
+ <version>3.8.1</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>ant/lib</outputDirectory>
+ <destFileName>junit.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <groupId>junit</groupId>
+ <artifactId>junit</artifactId>
+ <version>3.8.1</version>
+ <type>jar</type>
+ <classifier>sources</classifier>
+ <overWrite>false</overWrite>
+ <outputDirectory>junit</outputDirectory>
+ <destFileName>junit-src.zip</destFileName>
+ </artifactItem>
- mvn -Dfile=jdiff-src.zip -DrepositoryId=github -Durl=https://maven.pkg.github.com/kriegaex/aspectj-packages
- -DgroupId=jdiff -DartifactId=jdiff -Dpackaging=jar -Dversion=1.3
- -Dtypes=java-source -Dclassifier=sources
- deploy:deploy-file
+ <!-- Jython does not seem to be used anywhere in AspectJ -->
+
+ <artifactItem>
+ <!-- Binary is a bit newer than committed version, but produces identical results in 'docs' -->
+ <groupId>saxon</groupId>
+ <artifactId>saxon</artifactId>
+ <version>6.5.3</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>saxon</outputDirectory>
+ <destFileName>saxon.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <groupId>regexp</groupId>
+ <artifactId>regexp</artifactId>
+ <version>${lib.regexp.version}</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>regexp</outputDirectory>
+ <destFileName>jakarta-regexp-1.2.jar</destFileName>
+ </artifactItem>
+
+ <!--
+ About commons.jar + commons-src.zip:
+ - Beanutils Binaries are commons-beanutils:commons-beanutils:1.4 (no sources on Maven Central, but
+ https://github.com/apache/commons-beanutils/archive/refs/tags/BEANUTILS_1_4.zip)
+ - Collections: Binaries are commons-collections:commons-collections:2.0 (no sources on Maven Central, but
+ https://github.com/apache/commons-collections/archive/refs/tags/collections-2.0.zip)
+ - Digester: Binaries are commons-digester:commons-digester:1.3 (no sources on Maven Central, but
+ https://github.com/apache/commons-digester/archive/refs/tags/DIGESTER_1_3.zip)
+ - Logging: Binaries are commons-logging:commons-logging:1.0.1 (no sources on Maven Central, but
+ https://github.com/apache/commons-logging/archive/refs/tags/LOGGING_1_0_1.zip)
+ -->
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <!-- TODO: not used anywhere -> remove -->
+ <groupId>commons-beanutils</groupId>
+ <artifactId>commons-beanutils</artifactId>
+ <version>${lib.commons.beanutils.version}</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>commons</outputDirectory>
+ <destFileName>commons-beanutils-${lib.commons.beanutils.version}.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <!-- TODO: not used anywhere -> remove -->
+ <groupId>commons-collections</groupId>
+ <artifactId>commons-collections</artifactId>
+ <version>2.0</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>commons</outputDirectory>
+ <destFileName>commons-collections-2.0.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <!-- TODO: used in module 'testing' -->
+ <groupId>commons-digester</groupId>
+ <artifactId>commons-digester</artifactId>
+ <version>${lib.commons.digester.version}</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>commons</outputDirectory>
+ <destFileName>commons-digester-${lib.commons.digester.version}.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <!-- TODO: used in modules 'org.aspectj.matcher' -->
+ <groupId>commons-logging</groupId>
+ <artifactId>commons-logging</artifactId>
+ <version>${lib.commons.logging.version}</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>commons</outputDirectory>
+ <destFileName>commons-logging-${lib.commons.logging.version}.jar</destFileName>
+ </artifactItem>
+
+ <!-- Libraries used to create HTML docs from XML DocBook files -->
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <groupId>fop</groupId>
+ <artifactId>fop</artifactId>
+ <version>0.20.5</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>docbook</outputDirectory>
+ <destFileName>fop.jar</destFileName>
+ </artifactItem>
+ <artifactItem>
+ <!-- Binary is identical to committed version -->
+ <groupId>batik</groupId>
+ <artifactId>batik-1.5-fop</artifactId>
+ <version>0.20-5</version>
+ <type>jar</type>
+ <overWrite>false</overWrite>
+ <outputDirectory>docbook</outputDirectory>
+ <destFileName>batik.jar</destFileName>
+ </artifactItem>
+
+ </artifactItems>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+
+ <!-- (Un)zip downloaded libraries the way our build needs them -->
+ <plugin>
+ <groupId>org.codehaus.mojo</groupId>
+ <artifactId>truezip-maven-plugin</artifactId>
+ <version>1.2</version>
+ <!--
+ The TrueZIP plugin can seamlessly copy out of or into (nested) ZIP files as if they were normal file system
+ paths. No additional moves and deletes with Antrun are necessary.
+ -->
+ <executions>
+ <execution>
+ <id>unzip-ant-binaries</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>ant/${lib.ant.artifact}-bin.zip/${lib.ant.artifact}</directory>
+ <outputDirectory>ant</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-ant-sources</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>ant/${lib.ant.artifact}-src.zip/${lib.ant.artifact}/src/main</directory>
+ <outputDirectory>ant/ant-src.zip</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-beanutils-binaries</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-beanutils-${lib.commons.beanutils.version}.jar</directory>
+ <outputDirectory>commons/commons.jar</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-collections-binaries</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-collections-${lib.commons.collections.version}.jar</directory>
+ <outputDirectory>commons/commons.jar</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-digester-binaries</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-digester-${lib.commons.digester.version}.jar</directory>
+ <outputDirectory>commons/commons.jar</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-logging-binaries</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-logging-${lib.commons.logging.version}.jar</directory>
+ <outputDirectory>commons/commons.jar</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-beanutils-sources</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-beanutils-${lib.commons.beanutils.version}-sources.jar/commons-beanutils-${lib.commons.beanutils.tag}/src/java</directory>
+ <outputDirectory>commons/commons-src.zip</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-collections-sources</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-collections-${lib.commons.collections.version}-sources.jar/commons-collections-${lib.commons.collections.tag}/src/java</directory>
+ <outputDirectory>commons/commons-src.zip</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-digester-sources</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-digester-${lib.commons.digester.version}-sources.jar/commons-digester-${lib.commons.digester.tag}/src/java</directory>
+ <outputDirectory>commons/commons-src.zip</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-logging-sources</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>commons/commons-logging-${lib.commons.logging.version}-sources.jar/commons-logging-${lib.commons.logging.tag}/src/java</directory>
+ <outputDirectory>commons/commons-src.zip</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>unzip-docbook-dtd</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>docbook/docbkx412.zip</directory>
+ <outputDirectory>docbook/docbook-dtd</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>unzip-docbook-xsl</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>docbook/docbook-xsl-1.44.zip/docbook-xsl-1.44</directory>
+ <outputDirectory>docbook/docbook-xsl</outputDirectory>
+ </fileset>
+ </configuration>
+ </execution>
+ <!--
+ Obsolete because we uploaded both binary and source JARs to GitHub Packages, so we can use JDiff as a normal
+ dependency. Keep this for reference, so we can remember how we built it. After download + zip the deployment
+ was made right from the lib/jdiff directory, using the following commands (without the line breaks):
+
+ mvn -Dfile=jdiff.jar -DrepositoryId=github -Durl=https://maven.pkg.github.com/kriegaex/aspectj-packages
+ -DgroupId=jdiff -DartifactId=jdiff -Dpackaging=jar -Dversion=1.3
+ deploy:deploy-file
+
+ mvn -Dfile=jdiff-src.zip -DrepositoryId=github -Durl=https://maven.pkg.github.com/kriegaex/aspectj-packages
+ -DgroupId=jdiff -DartifactId=jdiff -Dpackaging=jar -Dversion=1.3
+ -Dtypes=java-source -Dclassifier=sources
+ deploy:deploy-file
+
+ The second command yields an error, trying to re-upload a POM, but that is no problem because the POM would
+ be identical to the one already uploaded with the first command.
+ -->
+ <!--
+ <execution>
+ <id>zip-jdiff-binaries</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>jdiff/JDiffPlugin-1.3.zip/JDiffPlugin.jar</directory>
+ <outputDirectory>jdiff/jdiff.jar</outputDirectory>
+ <includes>
+ <include>**/*.class</include>
+ </includes>
+ <excludes>
+ <exclude>jdiff/options/**</exclude>
+ <exclude>jdiff/*.class</exclude>
+ </excludes>
+ </fileset>
+ </configuration>
+ </execution>
+ <execution>
+ <id>zip-jdiff-sources</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>copy</goal>
+ </goals>
+ <configuration>
+ <verbose>true</verbose>
+ <fileset>
+ <directory>jdiff/JDiffPlugin-1.3.zip/JDiffPlugin</directory>
+ <outputDirectory>jdiff/jdiff-src.zip</outputDirectory>
+ <includes>
+ <include>**/*.java</include>
+ </includes>
+ <excludes>
+ <exclude>jdiff/options/**</exclude>
+ <exclude>jdiff/*.java</exclude>
+ </excludes>
+ </fileset>
+ </configuration>
+ </execution>
+ -->
+ </executions>
+ </plugin>
- The second command yields an error, trying to re-upload a POM, but that is no problem because the POM would
- be identical to the one already uploaded with the first command.
- -->
<!--
- <execution>
- <id>zip-jdiff-binaries</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>jdiff/JDiffPlugin-1.3.zip/JDiffPlugin.jar</directory>
- <outputDirectory>jdiff/jdiff.jar</outputDirectory>
- <includes>
- <include>**/*.class</include>
- </includes>
- <excludes>
- <exclude>jdiff/options/**</exclude>
- <exclude>jdiff/*.class</exclude>
- </excludes>
- </fileset>
- </configuration>
- </execution>
- <execution>
- <id>zip-jdiff-sources</id>
- <phase>process-resources</phase>
- <goals>
- <goal>copy</goal>
- </goals>
- <configuration>
- <verbose>true</verbose>
- <fileset>
- <directory>jdiff/JDiffPlugin-1.3.zip/JDiffPlugin</directory>
- <outputDirectory>jdiff/jdiff-src.zip</outputDirectory>
- <includes>
- <include>**/*.java</include>
- </includes>
- <excludes>
- <exclude>jdiff/options/**</exclude>
- <exclude>jdiff/*.java</exclude>
- </excludes>
- </fileset>
- </configuration>
- </execution>
+ After all libraries have been provisioned successfully, create a marker file in order to avoid provisioning
+ them again during the next build
-->
- </executions>
- </plugin>
+ <plugin>
+ <groupId>org.codehaus.mojo</groupId>
+ <artifactId>build-helper-maven-plugin</artifactId>
+ <executions>
+ <execution>
+ <id>create-marker-file</id>
+ <phase>process-resources</phase>
+ <goals>
+ <goal>bsh-property</goal>
+ </goals>
+ <configuration>
+ <source><![CDATA[
+ myFile = new File(project.getBasedir(), "${lib.provisioned.marker}");
+ print("Finished provisioning libraries, creating marker file " + myFile.getCanonicalPath());
+ myFile.createNewFile();
+ ]]></source>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+
+ </plugins>
+ </build>
+ <dependencies>
+ <dependency>
+ <groupId>org.aspectj</groupId>
+ <artifactId>org.eclipse.jdt.core</artifactId>
+ </dependency>
+ </dependencies>
+
+ </profile>
+
+ <!-- Profile for including provisioned libraries when running 'mvn clean'; inactive by default, activate manually -->
+ <profile>
+ <id>clean-libs</id>
+
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-clean-plugin</artifactId>
+ <executions>
+ <execution>
+ <id>clean-up-libs</id>
+ <phase>clean</phase>
+ <goals>
+ <goal>clean</goal>
+ </goals>
+ <configuration>
+ <filesets>
+ <fileset>
+ <directory>.</directory>
+ <includes>
+ <include>${lib.provisioned.marker}</include>
+ <include>ant/**</include>
+ <include>commons/**</include>
+ <include>docbook/**</include>
+ <include>jarjar/**</include>
+ <!-- Obsolete because JDiff is on GitHub Packages now. Keep for reference. -->
+ <!--<include>jdiff/**</include>-->
+ <include>jdtcore-aj/**</include>
+ <include>junit/**</include>
+ <include>regexp/**</include>
+ <include>saxon/**</include>
+ </includes>
+ <followSymlinks>false</followSymlinks>
+ </fileset>
+ </filesets>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+ </plugins>
+ </build>
+
+ </profile>
+
+ </profiles>
+
+ <build>
+ <plugins>
+ <!--
+ Heuristic consistency check for existence of provisioned library files. Do not just rely on
+ ${lib.provisioned.marker} file.
+ -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-clean-plugin</artifactId>
+ <artifactId>maven-enforcer-plugin</artifactId>
<executions>
<execution>
- <id>clean-up-libs</id>
- <phase>clean</phase>
+ <id>enforce-libraries-exist</id>
+ <phase>compile</phase>
<goals>
- <goal>clean</goal>
+ <goal>enforce</goal>
</goals>
<configuration>
- <filesets>
- <fileset>
- <directory>.</directory>
- <includes>
- <include>ant/**</include>
- <include>commons/**</include>
- <include>docbook/**</include>
- <include>jarjar/**</include>
- <!-- Obsolete because JDiff is on GitHub Packages now. Keep for reference. -->
- <!--<include>jdiff/**</include>-->
- <include>jdtcore-aj/**</include>
- <include>junit/**</include>
- <include>regexp/**</include>
- <include>saxon/**</include>
- </includes>
- <followSymlinks>false</followSymlinks>
- </fileset>
- </filesets>
+ <rules>
+ <requireFilesExist>
+ <!--
+ Do NOT insert any line breaks + indentation inside the message, keep it on a single line.
+ Maven Enforcer does not strip any whitespace or unindent, which looks quite ugly on the console.
+ -->
+ <message>
+ There is an inconsistency in module subdirectory 'lib'. Please run 'mvn --projects lib -P clean-libs clean compile'. This should take care of cleaning and freshly downloading all necessary libraries to that directory, where some tests expect them to be.
+ </message>
+ <files>
+ <file>${lib.provisioned.marker}</file>
+ <file>ant/bin/ant.bat</file>
+ <file>ant/lib/junit.jar</file>
+ <file>commons/commons.jar</file>
+ <file>docbook/docbook-dtd/docbookx.dtd</file>
+ <file>docbook/docbook-xsl/html/chunk.xsl</file>
+ <file>docbook/fop.jar</file>
+ <file>docbook/batik.jar</file>
+ <file>jarjar/jarjar-1.3.jar</file>
+ <file>jdtcore-aj/jdtcore-for-aspectj.jar</file>
+ <file>junit/junit.jar</file>
+ <file>regexp/jakarta-regexp-1.2.jar</file>
+ <file>saxon/saxon.jar</file>
+ </files>
+ </requireFilesExist>
+ </rules>
+ <fail>true</fail>
</configuration>
</execution>
</executions>
</plugin>
-
</plugins>
</build>
- <dependencies>
- <dependency>
- <groupId>org.aspectj</groupId>
- <artifactId>org.eclipse.jdt.core</artifactId>
- </dependency>
- </dependencies>
-
</project>
diff --git a/org.aspectj.ajdt.core/pom.xml b/org.aspectj.ajdt.core/pom.xml
index f77796cb2..747fce918 100644
--- a/org.aspectj.ajdt.core/pom.xml
+++ b/org.aspectj.ajdt.core/pom.xml
@@ -13,6 +13,12 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>bridge</artifactId>
<version>${project.version}</version>
diff --git a/pom.xml b/pom.xml
index 8f5a31b2a..a6da6f707 100644
--- a/pom.xml
+++ b/pom.xml
@@ -27,7 +27,6 @@
<lib.commons.logging.version>1.0.1</lib.commons.logging.version>
<lib.commons.logging.tag>LOGGING_1_0_1</lib.commons.logging.tag>
<asm.version>9.1</asm.version>
- <lib.directory>${maven.multiModuleProjectDirectory}/lib</lib.directory>
</properties>
<repositories>
@@ -47,6 +46,7 @@
</repositories>
<modules>
+ <module>lib</module>
<module>util</module>
<module>bridge</module>
<module>testing-util</module>
@@ -73,7 +73,6 @@
<!-- FYI: These are NOT meant to be sub-modules but a stand-alone projects built and deployed independently. -->
<!--
<module>asm-renamed</module>
- <module>lib</module>
-->
<!-- create the important artifacts we care about -->
@@ -279,51 +278,11 @@
<ignoredUnusedDeclaredDependencies>
<!-- Declared in parent POM for convenience, but not used in every module -->
<ignoredUnusedDeclaredDependency>junit:junit:jar</ignoredUnusedDeclaredDependency>
+ <ignoredUnusedDeclaredDependency>org.aspectj:lib:jar</ignoredUnusedDeclaredDependency>
</ignoredUnusedDeclaredDependencies>
</configuration>
</plugin>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-enforcer-plugin</artifactId>
- <executions>
- <execution>
- <id>enforce-libraries-exist</id>
- <goals>
- <goal>enforce</goal>
- </goals>
- <configuration>
- <rules>
- <requireFilesExist>
- <!--
- Do NOT insert any line breaks + indentation inside the message, keep it on a single line.
- Maven Enforcer does not strip any whitespace or unindent, which looks quite ugly on the console.
- -->
- <message>
- Please go to module subdirectory 'lib' and run 'mvn compile' there. This should take care of downloading all necessary libraries to that directory, where some tests expect them to be.
- </message>
- <files>
- <file>${lib.directory}/ant/bin/ant.bat</file>
- <file>${lib.directory}/ant/lib/junit.jar</file>
- <file>${lib.directory}/commons/commons.jar</file>
- <file>${lib.directory}/docbook/docbook-dtd/docbookx.dtd</file>
- <file>${lib.directory}/docbook/docbook-xsl/html/chunk.xsl</file>
- <file>${lib.directory}/docbook/fop.jar</file>
- <file>${lib.directory}/docbook/batik.jar</file>
- <file>${lib.directory}/jarjar/jarjar-1.3.jar</file>
- <file>${lib.directory}/jdtcore-aj/jdtcore-for-aspectj.jar</file>
- <file>${lib.directory}/junit/junit.jar</file>
- <file>${lib.directory}/regexp/jakarta-regexp-1.2.jar</file>
- <file>${lib.directory}/saxon/saxon.jar</file>
- </files>
- </requireFilesExist>
- </rules>
- <fail>true</fail>
- </configuration>
- </execution>
- </executions>
- </plugin>
-
</plugins>
</build>
@@ -364,6 +323,12 @@
<artifactId>asm-renamed</artifactId>
<version>${asm.version}</version>
</dependency>
+ <dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <version>${project.version}</version>
+ </dependency>
</dependencies>
</dependencyManagement>
diff --git a/run-all-junit-tests/pom.xml b/run-all-junit-tests/pom.xml
index fb21ee685..c1d3a1fe4 100644
--- a/run-all-junit-tests/pom.xml
+++ b/run-all-junit-tests/pom.xml
@@ -14,6 +14,12 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>
diff --git a/taskdefs/pom.xml b/taskdefs/pom.xml
index db1c8a3cc..d44faf2ca 100644
--- a/taskdefs/pom.xml
+++ b/taskdefs/pom.xml
@@ -13,6 +13,12 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>
diff --git a/testing-util/pom.xml b/testing-util/pom.xml
index 384852893..0acc00a08 100644
--- a/testing-util/pom.xml
+++ b/testing-util/pom.xml
@@ -13,6 +13,11 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>
diff --git a/testing/pom.xml b/testing/pom.xml
index eeb45de81..dfd975838 100644
--- a/testing/pom.xml
+++ b/testing/pom.xml
@@ -13,6 +13,12 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>
diff --git a/tests/pom.xml b/tests/pom.xml
index ae2fbcca4..95f91d838 100644
--- a/tests/pom.xml
+++ b/tests/pom.xml
@@ -14,6 +14,12 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>
diff --git a/util/pom.xml b/util/pom.xml
index fd34a7700..4d65e69ec 100644
--- a/util/pom.xml
+++ b/util/pom.xml
@@ -11,4 +11,13 @@
<artifactId>util</artifactId>
+ <dependencies>
+ <dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ </dependencies>
+
</project>
diff --git a/weaver/pom.xml b/weaver/pom.xml
index acac5dfde..b812ffba1 100644
--- a/weaver/pom.xml
+++ b/weaver/pom.xml
@@ -13,6 +13,12 @@
<dependencies>
<dependency>
+ <!-- All modules referencing files inside 'lib' need this dependency -->
+ <groupId>org.aspectj</groupId>
+ <artifactId>lib</artifactId>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
<groupId>org.aspectj</groupId>
<artifactId>util</artifactId>
<version>${project.version}</version>