aboutsummaryrefslogtreecommitdiffstats
path: root/aspectjtools
diff options
context:
space:
mode:
authorAlexander Kriegisch <Alexander@Kriegisch.name>2021-04-16 12:14:31 +0700
committerAlexander Kriegisch <Alexander@Kriegisch.name>2021-04-16 12:14:31 +0700
commitd35885bc5faef4936aa5c4207da8f9a3a855630a (patch)
tree60a0679ccfe0b74e29f118d7c9894dbc1631f391 /aspectjtools
parent2f981bdde6263a1ab9f5e26ce202cbd8ed51ca70 (diff)
downloadaspectj-d35885bc5faef4936aa5c4207da8f9a3a855630a.tar.gz
aspectj-d35885bc5faef4936aa5c4207da8f9a3a855630a.zip
Use dependencies instead of copies under 'lib' for assemblies
This is one step to get rid of org.aspectj:org.eclipse.jdt.core and org.aspectj:asm-renamed in the 'lib' directory. AspectJ tools + weaver uber JAR builds now use dependencies in the POM in order to deal with creating binary + source assemblies. They no longer rely on manually updated copies under 'lib'. Details: - Binaries are copied via 'dependencySets' in the assembly descriptor. - Sources are unzipped via Maven Dependency Plugin before including them into the source uber JAR via assembly descriptor. - NEW: This also includes ASM-renamed sources which so far were ignored. It is a positive side-effect from the fact that for ASM-renamed Maven Shade automatically creates a source JAR. - Maven Ant Run is no longer used for unzipping binary + source JARs. - While working in parallel with JDT Core and AspectJ it is now much easier to produce up to date artifacts, e.g. for consumption by AJDT, because it does not matter anymore if we forget to run the build in module 'lib' in order to update the JDT Core copy. Status quo: - Folder lib/asm is no longer used and will be removed in a subsequent commit. - Folder lib/jdtcore-aj is no longer used by the Maven build, but still referenced in a few UNIX shell scripts and Ant build files. TODO: Find out if those are still actively used. If yes, refactor them to look for the file in the local Mavven repository. Otherwise, delete the referencing files and also lib/jdtcore-aj. Signed-off-by: Alexander Kriegisch <Alexander@Kriegisch.name>
Diffstat (limited to 'aspectjtools')
-rw-r--r--aspectjtools/aspectjtools-assembly.xml34
-rw-r--r--aspectjtools/aspectjtools-sources-assembly.xml22
-rw-r--r--aspectjtools/pom.xml77
3 files changed, 50 insertions, 83 deletions
diff --git a/aspectjtools/aspectjtools-assembly.xml b/aspectjtools/aspectjtools-assembly.xml
index 310dbe098..fbf45c808 100644
--- a/aspectjtools/aspectjtools-assembly.xml
+++ b/aspectjtools/aspectjtools-assembly.xml
@@ -1,15 +1,25 @@
-<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.0.0"
+<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.1.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.0.0 http://maven.apache.org/xsd/assembly-2.0.0.xsd">
+ xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.1.0 http://maven.apache.org/xsd/assembly-2.1.0.xsd">
<id>aspectjtools</id>
-
+
<formats>
<format>jar</format>
</formats>
<includeBaseDirectory>false</includeBaseDirectory>
+ <dependencySets>
+ <dependencySet>
+ <unpack>true</unpack>
+ <includes>
+ <include>org.aspectj:org.eclipse.jdt.core</include>
+ <include>org.aspectj:asm-renamed</include>
+ </includes>
+ </dependencySet>
+ </dependencySets>
+
<fileSets>
<!-- runtime -->
<fileSet>
@@ -70,16 +80,7 @@
<exclude>META-INF/maven/**</exclude>
</excludes>
</fileSet>
- <fileSet>
- <directory>target/asm-unzipped</directory>
- <outputDirectory>.</outputDirectory>
- <excludes>
- <exclude>META-INF/maven/**</exclude>
- <exclude>org/**</exclude>
- <exclude>META-INF/MANIFEST.MF</exclude>
- </excludes>
- </fileSet>
-
+
<!-- tools -->
<fileSet>
<directory>../ajbrowser/target/classes</directory>
@@ -123,13 +124,6 @@
<exclude>META-INF/maven/**</exclude>
</excludes>
</fileSet>
- <fileSet>
- <directory>target/jdtcore-unzipped</directory>
- <outputDirectory>.</outputDirectory>
- <excludes>
- <exclude>META-INF/MANIFEST.MF</exclude>
- </excludes>
- </fileSet>
</fileSets>
</assembly>
diff --git a/aspectjtools/aspectjtools-sources-assembly.xml b/aspectjtools/aspectjtools-sources-assembly.xml
index a382e5e8b..7b54c09b2 100644
--- a/aspectjtools/aspectjtools-sources-assembly.xml
+++ b/aspectjtools/aspectjtools-sources-assembly.xml
@@ -1,8 +1,8 @@
-<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.0.0"
+<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.1.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.0.0 http://maven.apache.org/xsd/assembly-2.0.0.xsd">
+ xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.1.0 http://maven.apache.org/xsd/assembly-2.1.0.xsd">
- <id>sources</id>
+<id>aspectjtools-sources</id>
<formats>
<format>jar</format>
@@ -11,6 +11,7 @@
<includeBaseDirectory>false</includeBaseDirectory>
<fileSets>
+
<fileSet>
<directory>../weaver/src/main/java</directory>
<outputDirectory>.</outputDirectory>
@@ -43,14 +44,8 @@
<directory>../loadtime/src/main/java</directory>
<outputDirectory>.</outputDirectory>
</fileSet>
- <!--
- <fileSet>
- <directory>target/asm-unzipped</directory>
- <outputDirectory>.</outputDirectory>
- </fileSet>
- -->
-
- <!-- tools -->
+
+ <!-- Tools -->
<fileSet>
<directory>../ajbrowser/src/main/java</directory>
<outputDirectory>.</outputDirectory>
@@ -75,10 +70,13 @@
<directory>../taskdefs/src/main/java</directory>
<outputDirectory>.</outputDirectory>
</fileSet>
+
+ <!-- Dependencies -->
<fileSet>
- <directory>target/jdtcore-unzipped-src</directory>
+ <directory>target/unzipped-sources</directory>
<outputDirectory>.</outputDirectory>
</fileSet>
+
</fileSets>
</assembly>
diff --git a/aspectjtools/pom.xml b/aspectjtools/pom.xml
index b14b2fe01..cac9b9e2f 100644
--- a/aspectjtools/pom.xml
+++ b/aspectjtools/pom.xml
@@ -14,14 +14,6 @@
<packaging>pom</packaging>
<name>AspectJ Compiler</name>
- <dependencies>
- <dependency>
- <groupId>org.aspectj</groupId>
- <artifactId>org.aspectj.ajdt.core</artifactId>
- <version>${project.version}</version>
- </dependency>
- </dependencies>
-
<build>
<plugins>
@@ -37,58 +29,24 @@
</executions>
</plugin>
-
<plugin>
<groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-antrun-plugin</artifactId>
- <version>3.0.0</version>
+ <artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
- <id>unzipasm</id>
- <phase>prepare-package</phase>
- <configuration>
- <target>
- <echo message="unzip jarjar'd asm" />
- <unzip
- src="${project.basedir}/../lib/asm/asm-9.1.renamed.jar"
- dest="target/asm-unzipped" />
- </target>
- </configuration>
+ <id>unzip-dependency-sources</id>
<goals>
- <goal>run</goal>
+ <goal>unpack-dependencies</goal>
</goals>
- </execution>
-
- <execution>
- <id>unzipjdt</id>
<phase>prepare-package</phase>
<configuration>
- <target>
- <echo message="unzip patched jdtcore" />
- <unzip
- src="${project.basedir}/../lib/jdtcore-aj/jdtcore-for-aspectj.jar"
- dest="target/jdtcore-unzipped" />
- </target>
- </configuration>
- <goals>
- <goal>run</goal>
- </goals>
- </execution>
-
- <execution>
- <id>unzipjdtsrc</id>
- <phase>prepare-package</phase>
- <configuration>
- <target>
- <echo message="unzip patched jdtcore sources" />
- <unzip
- src="${project.basedir}/../lib/jdtcore-aj/jdtcore-for-aspectj-src.zip"
- dest="target/jdtcore-unzipped-src" />
- </target>
+ <classifier>sources</classifier>
+ <!--<failOnMissingClassifierArtifact>false</failOnMissingClassifierArtifact>-->
+ <includeArtifactIds>org.eclipse.jdt.core,asm-renamed</includeArtifactIds>
+ <outputDirectory>${project.build.directory}/unzipped-sources</outputDirectory>
+ <!-- Avoid accidentally shading test-scoped dependencies like JUnit -->
+ <includeScope>runtime</includeScope>
</configuration>
- <goals>
- <goal>run</goal>
- </goals>
</execution>
</executions>
</plugin>
@@ -176,4 +134,21 @@
</plugins>
</build>
+
+ <dependencies>
+ <dependency>
+ <groupId>org.aspectj</groupId>
+ <artifactId>org.aspectj.ajdt.core</artifactId>
+ <version>${project.version}</version>
+ </dependency>
+ <dependency>
+ <groupId>org.aspectj</groupId>
+ <artifactId>org.eclipse.jdt.core</artifactId>
+ </dependency>
+ <dependency>
+ <groupId>org.aspectj</groupId>
+ <artifactId>asm-renamed</artifactId>
+ </dependency>
+ </dependencies>
+
</project>