aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTeemu Suo-Anttila <teemusa@vaadin.com>2016-03-22 17:19:19 +0200
committerTeemu Suo-Anttila <teemusa@vaadin.com>2016-03-27 22:15:02 +0300
commit7833b3540228251ef0eef23a85403e85bbcb571b (patch)
treebd932f7a5098f44475b40d48d9a213a0e1f36c19
parent7b1a91f9ece0d38c74886383df3ee29d354592f8 (diff)
downloadvaadin-framework-7833b3540228251ef0eef23a85403e85bbcb571b.tar.gz
vaadin-framework-7833b3540228251ef0eef23a85403e85bbcb571b.zip
Build vaadin-client-compiled with maven
Change-Id: I91ef39fec1244fdeff1ee269be39ae7800a495b3
-rw-r--r--.gitignore1
-rw-r--r--client-compiled/build.xml150
-rw-r--r--client-compiled/pom.xml180
-rw-r--r--ivysettings.xml2
-rw-r--r--liferay/ivy.xml2
-rw-r--r--pom.xml1
-rw-r--r--uitest/ivy.xml2
7 files changed, 185 insertions, 153 deletions
diff --git a/.gitignore b/.gitignore
index aae0204ab7..9237104b65 100644
--- a/.gitignore
+++ b/.gitignore
@@ -90,6 +90,7 @@ server/target/
client/target/
client-compiler/target/
buildhelpers/target/
+client-compiled/target/
.sass-cache
phantomjsdriver.log
diff --git a/client-compiled/build.xml b/client-compiled/build.xml
deleted file mode 100644
index bbcfc7bf4a..0000000000
--- a/client-compiled/build.xml
+++ /dev/null
@@ -1,150 +0,0 @@
-<?xml version="1.0"?>
-
-<project name="vaadin-client-compiled" basedir="." default="publish-local"
- xmlns:ivy="antlib:org.apache.ivy.ant">
- <description>
- Compiled (JS+HTML) version of client side
- </description>
-
- <include file="../common.xml" as="common" />
- <include file="../build.xml" as="vaadin" />
- <include file="../gwt-files.xml" as="gwtfiles" />
-
- <!-- global properties -->
- <property name="module.name" value="vaadin-client-compiled" />
- <property name="module.symbolic" value="com.vaadin.client-compiled" />
- <property name="result.dir" value="result" />
- <property name="gwtar.dir" location="${result.dir}/gwtar" />
- <property name="work.dir" location="${result.dir}/work" />
- <property name="module.output.dir" location="${result.dir}/VAADIN/widgetsets" />
- <property name="compiled.jar"
- location="${result.dir}/lib/${module.name}-${vaadin.version}.jar" />
- <property name="compiled-cache.jar"
- location="${result.dir}/lib/${module.name}-cache-${vaadin.version}.jar" />
-
- <union id="jar.includes">
- <fileset dir="${result.dir}">
- <include name="VAADIN/widgetsets/com.vaadin*/**" />
- </fileset>
- </union>
-
- <target name="default-widgetset-cache">
- <antcall target="compile-module-cache">
- <param name="module" value="com.vaadin.DefaultWidgetSet" />
- </antcall>
- </target>
-
- <target name="default-widgetset">
- <antcall target="compile-module">
- <param name="module" value="com.vaadin.DefaultWidgetSet" />
- </antcall>
- </target>
-
-
- <target name="compile-module-cache">
- <fail unless="module"
- message="You must give the module to compile in the 'module' parameter" />
- <ivy:resolve log="download-only" resolveid="common"
- conf="compile-module" />
- <ivy:cachepath pathid="classpath.compile.widgetset"
- conf="compile-module" />
- <echo>Creating gwtar files for ${module} in ${gwtar.dir}</echo>
-
- <!-- Produce gwtar files for the separate JAR -->
- <java classname="com.google.gwt.dev.CompileModule"
- classpathref="classpath.compile.widgetset" failonerror="yes"
- fork="yes" maxmemory="512m">
- <arg value="-out" />
- <arg value="${gwtar.dir}" />
- <arg value="-strict" />
- <arg value="${module}" />
-
- <jvmarg value="-Xss8M" />
- <jvmarg value="-XX:MaxPermSize=256M" />
- <jvmarg value="-Djava.awt.headless=true" />
- </java>
- </target>
-
- <target name="compile-module">
- <fail unless="module"
- message="You must give the module to compile in the 'module' parameter" />
- <property name="style" value="OBF" />
- <property name="localWorkers" value="6" />
- <property name="extraParams" value="" />
-
- <ivy:resolve log="download-only" resolveid="common"
- conf="compile-module" />
- <ivy:cachepath pathid="classpath.compile.widgetset"
- conf="compile-module" />
-
- <mkdir dir="${module.output.dir}" />
-
- <echo>Compiling ${module} to ${module.output.dir}</echo>
-
- <!-- compile the module -->
- <java classname="com.google.gwt.dev.Compiler" classpathref="classpath.compile.widgetset"
- failonerror="yes" fork="yes" maxmemory="512m">
- <classpath location="${compiled-cache.jar}" />
- <arg value="-workDir" />
- <arg value="${work.dir}" />
- <arg value="-logLevel" />
- <arg value="TRACE" />
- <arg value="-war" />
- <arg value="${module.output.dir}" />
- <arg value="-style" />
- <arg value="${style}" />
-
- <arg value="-localWorkers" />
- <arg value="${localWorkers}" />
- <arg value="-strict" />
- <!-- Disabled for now as it breaks code, e.g. ButtonWithShortcutNotRendered -->
- <!-- <arg value="-XenableClosureCompiler" /> -->
- <arg line="${extraParams}" />
- <arg value="${module}" />
-
- <sysproperty key="vFailIfNotSerializable" value="true" />
-
- <jvmarg value="-Xss8M" />
- <jvmarg value="-XX:MaxPermSize=256M" />
- <jvmarg value="-Djava.awt.headless=true" />
- </java>
-
- </target>
-
- <target name="client-compiled-cache.jar" depends="default-widgetset-cache">
- <jar file="${compiled-cache.jar}" compress="true">
- <fileset dir="${gwtar.dir}">
- <include name="**/*.gwtar" />
- </fileset>
- <union refid="client-compiled-cache.gwt.includes" />
- <!-- <fileset dir="${common.jarfiles.dir}" /> -->
- </jar>
- </target>
-
- <target name="jar" depends="default-widgetset">
- <antcall target="common.jar">
- <param name="osgi.extra.package.prefixes" value="VAADIN/widgetsets/" />
- <param name="osgi.includeNumberPackages" value="1" />
- <reference torefid="extra.jar.includes" refid="jar.includes" />
- </antcall>
- </target>
-
- <target name="publish-local" depends="jar">
- <antcall target="common.publish-local">
- <param name="conf" value="build" />
- </antcall>
- </target>
-
- <target name="clean">
- <antcall target="common.clean" />
- </target>
-
- <target name="checkstyle">
- <echo>No java files in module</echo>
- </target>
- <target name="test" depends="checkstyle">
- <!--<antcall target="common.test.run" /> -->
- <echo>WHAT? No tests for ${module.name}!</echo>
- </target>
-
-</project>
diff --git a/client-compiled/pom.xml b/client-compiled/pom.xml
new file mode 100644
index 0000000000..da664fb938
--- /dev/null
+++ b/client-compiled/pom.xml
@@ -0,0 +1,180 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<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">
+ <modelVersion>4.0.0</modelVersion>
+ <parent>
+ <groupId>com.vaadin</groupId>
+ <artifactId>vaadin-root</artifactId>
+ <version>7.7.0-SNAPSHOT</version>
+ </parent>
+ <groupId>com.vaadin</groupId>
+ <artifactId>vaadin-client-compiled</artifactId>
+ <name>vaadin-client-compiled</name>
+ <packaging>jar</packaging>
+
+ <properties>
+ <widgetset.name>com.vaadin.DefaultWidgetSet</widgetset.name>
+ <widgetset.style>OBF</widgetset.style>
+ <widgetset.local.workers>6</widgetset.local.workers>
+ </properties>
+
+ <organization>
+ <name>Vaadin Ltd</name>
+ </organization>
+ <url>https://vaadin.com/</url>
+ <description>Vaadin client compiled</description>
+
+ <dependencies>
+ <dependency>
+ <groupId>${project.groupId}</groupId>
+ <artifactId>vaadin-server</artifactId>
+ <version>${project.version}</version>
+ <scope>provided</scope>
+ </dependency>
+
+ <dependency>
+ <groupId>${project.groupId}</groupId>
+ <artifactId>vaadin-client</artifactId>
+ <version>${project.version}</version>
+ <scope>provided</scope>
+ </dependency>
+
+ <dependency>
+ <groupId>${project.groupId}</groupId>
+ <artifactId>vaadin-client-compiler</artifactId>
+ <version>${project.version}</version>
+ <scope>provided</scope>
+ </dependency>
+
+ <dependency>
+ <groupId>${project.groupId}</groupId>
+ <artifactId>vaadin-buildhelpers</artifactId>
+ <version>${project.version}</version>
+ <scope>provided</scope>
+ </dependency>
+ </dependencies>
+
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.codehaus.mojo</groupId>
+ <artifactId>exec-maven-plugin</artifactId>
+ <version>1.4.0</version>
+ <executions>
+ <execution>
+ <phase>generate-resources</phase>
+ <goals>
+ <goal>exec</goal>
+ </goals>
+ <configuration>
+ <classpathScope>compile</classpathScope>
+ <executable>${java.home}/bin/java</executable>
+ <arguments>
+ <!-- TODO: Do we need these? -->
+ <!-- <jvmarg value="-Xss8M" /> -->
+ <!-- <jvmarg value="-XX:MaxPermSize=256M" /> -->
+ <!-- <jvmarg value="-Djava.awt.headless=true" /> -->
+ <argument>-Dgwt.persistentunitcachedir=${project.build.directory}/compile</argument>
+ <argument>-DvFailIfNotSerializable=true</argument>
+
+ <argument>-classpath</argument>
+ <classpath />
+
+ <argument>com.google.gwt.dev.Compiler</argument>
+
+ <argument>-workDir</argument>
+ <argument>${project.build.directory}/compile</argument>
+ <argument>-logLevel</argument>
+ <argument>TRACE</argument>
+ <argument>-war</argument>
+ <!-- This will write the result directly to target/classes for packaging -->
+ <argument>${project.build.outputDirectory}/VAADIN/widgetsets/</argument>
+ <argument>-style</argument>
+ <argument>${widgetset.style}</argument>
+ <argument>-localWorkers</argument>
+ <argument>${widgetset.local.workers}</argument>
+
+ <argument>-strict</argument>
+
+ <!-- Move unnecessary stuff to compile folder -->
+ <argument>-deploy</argument>
+ <argument>${project.build.directory}/compile</argument>
+ <argument>-extra</argument>
+ <argument>${project.build.directory}/compile</argument>
+
+ <argument>${widgetset.name}</argument>
+ </arguments>
+ </configuration>
+ </execution>
+
+ <execution>
+ <id>generate-export-package</id>
+ <phase>package</phase>
+ <goals>
+ <goal>exec</goal>
+ </goals>
+ <configuration>
+ <classpathScope>compile</classpathScope>
+ <executable>${java.home}/bin/java</executable>
+ <arguments>
+ <argument>-Dvaadin.version=${project.version}</argument>
+ <argument>-DincludeNumberPackages=1</argument>
+
+ <argument>-classpath</argument>
+ <classpath />
+
+ <argument>com.vaadin.buildhelpers.GeneratePackageExports</argument>
+
+ <argument>${project.build.directory}/${project.build.finalName}.${project.packaging}</argument>
+ <argument>VAADIN/widgetsets</argument>
+ </arguments>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+
+
+ <plugin>
+ <groupId>org.apache.felix</groupId>
+ <artifactId>maven-bundle-plugin</artifactId>
+ <extensions>true</extensions>
+ <configuration>
+ <instructions>
+ <Bundle-RequiredExecutionEnvironment>JavaSE-1.6</Bundle-RequiredExecutionEnvironment>
+ <!-- Export package is handled in exec plugin -->
+ <Export-Package></Export-Package>
+ <Import-Package></Import-Package>
+ </instructions>
+ </configuration>
+ <executions>
+ <execution>
+ <id>bundle-manifest</id>
+ <phase>prepare-package</phase>
+ <goals>
+ <goal>manifest</goal>
+ </goals>
+ </execution>
+ </executions>
+ </plugin>
+
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-jar-plugin</artifactId>
+ <version>2.6</version>
+ <configuration>
+ <archive>
+ <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
+ <index>false</index>
+ <manifest>
+ <addDefaultImplementationEntries>true</addDefaultImplementationEntries>
+ </manifest>
+ </archive>
+ <excludes>
+ <exclude>VAADIN/widgetsets/WEB-INF</exclude>
+ </excludes>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+
+</project>
diff --git a/ivysettings.xml b/ivysettings.xml
index 9cf0e75720..860d39fa75 100644
--- a/ivysettings.xml
+++ b/ivysettings.xml
@@ -48,7 +48,7 @@
<module organisation="com.vaadin" name="vaadin-client-compiler"
resolver="local-maven" />
<module organisation="com.vaadin" name="vaadin-client-compiled"
- resolver="build-temp" />
+ resolver="local-maven" />
<module organisation="com.vaadin" name="vaadin-themes"
resolver="build-temp" />
<module organisation="com.vaadin" name="vaadin-push"
diff --git a/liferay/ivy.xml b/liferay/ivy.xml
index 9a26f80b4e..1a1427a723 100644
--- a/liferay/ivy.xml
+++ b/liferay/ivy.xml
@@ -18,7 +18,7 @@
<dependencies>
<dependency org="com.vaadin" name="vaadin-client-compiled"
- rev="${vaadin.version}" conf="deps -> build" transitive="false"/>
+ rev="${vaadin.version}" conf="deps -> default" transitive="false"/>
<dependency org="com.vaadin" name="vaadin-themes"
rev="${vaadin.version}" conf="deps -> build" transitive="false"/>
<dependency org="com.vaadin" name="vaadin-push"
diff --git a/pom.xml b/pom.xml
index 300d7d75d4..86f7676d9c 100644
--- a/pom.xml
+++ b/pom.xml
@@ -58,6 +58,7 @@
<module>server</module>
<module>client</module>
<module>client-compiler</module>
+ <module>client-compiled</module>
</modules>
<build>
diff --git a/uitest/ivy.xml b/uitest/ivy.xml
index 7a7df5a81f..6ae49b7d94 100644
--- a/uitest/ivy.xml
+++ b/uitest/ivy.xml
@@ -46,7 +46,7 @@
<exclude type="pom" />
</dependency>
<dependency org="com.vaadin" name="vaadin-client-compiled"
- rev="${vaadin.version}" conf="build->build">
+ rev="${vaadin.version}" conf="build->default">
<exclude type="pom" />
</dependency>
<dependency org="com.vaadin" name="vaadin-themes"