blob: e9cd52916a18f8de45bd2bd8ad972a0df28dadac [file] [log] [blame]
<?xml version="1.0" encoding="UTF-8"?>
<!--
Copyright (c) 1997, 2021 Oracle and/or its affiliates. All rights reserved.
This program and the accompanying materials are made available under the
terms of the Eclipse Public License v. 2.0, which is available at
http://www.eclipse.org/legal/epl-2.0.
This Source Code may also be made available under the following Secondary
Licenses when the conditions for such availability set forth in the
Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
version 2 with the GNU Classpath Exception, which is available at
https://www.gnu.org/software/classpath/license.html.
SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
-->
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><!--
This module builds the free-standing JAR file for the app client
container which can be run without using an OSGi implementation.
This module contains little source of its own but mostly packages a JAR
with a manifest Class-Path that specifies all the OSGi JARs on which
it directly or indirectly depends.
Note that additional JARs which clients might need but which are not
declared as dependencies are added by updating the generated manifest's
Class-Path using some ant tasks. The nicer way to do this would be to
create a custom plug-in which would delegate most of the work to the
archiver but would augment the generated Class-Path with the extra JARs.
Perhaps later.
-->
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.glassfish.main.appclient</groupId>
<artifactId>client</artifactId>
<version>6.2.1-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>
</parent>
<artifactId>gf-client</artifactId>
<packaging>glassfish-jar</packaging>
<name>Client library (including ACC)</name>
<developers>
<developer>
<id>tjquinn</id>
<name>Tim Quinn</name>
<url>http://blogs.sun.com/quinn</url>
<organization>Oracle, Inc.</organization>
<roles>
<role>lead</role>
<role>developer</role>
</roles>
</developer>
</developers>
<properties>
<classpath.file>${project.build.directory}/tmp/classpath.txt</classpath.file>
<!--
Property settings used for adding parts to the Class-Path used to
be defined here. They are now in the fixup.xml file instead so
the pom is less changeable.
-->
</properties>
<dependencies>
<!--
We specify the ACC's OSGi JAR as a dependency.
The maven-jar-plugin will do the work of finding the transitive
closure of it and the modules on which it depends to build the
accurate Class-Path for the manifest.
-->
<dependency>
<groupId>org.glassfish.main.appclient</groupId>
<artifactId>gf-client-module</artifactId>
<version>${project.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<!--
Create a text file containing the generated class path. This
file is used in the ant tasks when the original Class-Path is
augmented. Note: we force the path separator to be a colon
because the plug-in will use the platform-specific separator
otherwise. The ant logic replaces colons with spaces to
reformat the contents of the file so it's useful in the manifest.
-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>generate-classpath-file</id>
<phase>process-sources</phase>
<goals>
<goal>build-classpath</goal>
</goals>
<configuration>
<outputFile>${classpath.file}</outputFile>
<outputFilterFile>true</outputFilterFile>
<pathSeparator>:</pathSeparator>
<fileSeparator>/</fileSeparator>
<prefix>../modules</prefix>
<stripVersion>true</stripVersion>
<excludeArtifactIds>jakarta.json</excludeArtifactIds>
<excludeArtifactIds>jakarta.inject</excludeArtifactIds>
</configuration>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<!--
Includes only the agent class. All the rest are in
the OSGi module.
-->
<archive>
<!-- We need the index eventually but until the plug-in itself knows the correct
classpath we must comment this out, or else the index reflects nothing in
this or the downstream JARs and so attempts to find things fail.
<index>true</index>
-->
<manifest>
<mainClass>org.glassfish.appclient.client.AppClientFacade</mainClass>
<packageName>org.glassfish.appclient.client.acc</packageName>
<addClasspath>true</addClasspath>
<classpathLayoutType>custom</classpathLayoutType>
<customClasspathLayout>../modules/$${artifact.artifactId}$${dashClassifier?}.$${artifact.extension}</customClasspathLayout>
</manifest>
<manifestEntries>
<PreMain-Class>org.glassfish.appclient.client.acc.agent.AppClientContainerAgent</PreMain-Class>
<GlassFish-ServerExcluded>true</GlassFish-ServerExcluded>
</manifestEntries>
</archive>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-antrun-plugin</artifactId>
<executions>
<execution>
<id>fixup-jar-classpath</id>
<phase>package</phase>
<goals>
<goal>run</goal>
</goals>
<configuration>
<target>
<property name="output.file" value="${project.build.finalName}.jar" />
<property name="output.dir" value="${project.build.directory}" />
<property name="stage.dir" value="${project.build.directory}/stage" />
<property name="classpath.file" value="${classpath.file}" />
<ant antfile="${basedir}/fixup.xml" />
</target>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>