diff options
author | Alexander Kriegisch <Alexander@Kriegisch.name> | 2021-04-16 12:14:31 +0700 |
---|---|---|
committer | Alexander Kriegisch <Alexander@Kriegisch.name> | 2021-04-16 12:14:31 +0700 |
commit | d35885bc5faef4936aa5c4207da8f9a3a855630a (patch) | |
tree | 60a0679ccfe0b74e29f118d7c9894dbc1631f391 /aspectjtools | |
parent | 2f981bdde6263a1ab9f5e26ce202cbd8ed51ca70 (diff) | |
download | aspectj-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.xml | 34 | ||||
-rw-r--r-- | aspectjtools/aspectjtools-sources-assembly.xml | 22 | ||||
-rw-r--r-- | aspectjtools/pom.xml | 77 |
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> |