<?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/maven-v4_0_0.xsd">
  <parent>
    <artifactId>flink-examples_2.11</artifactId>
    <groupId>org.apache.flink</groupId>
    <version>1.2.0</version>
    <relativePath>../../pom.xml</relativePath>
  </parent>
  <modelVersion>4.0.0</modelVersion>
  <artifactId>flink-examples-batch_2.11</artifactId>
  <name>flink-examples-batch</name>
  <build>
    <plugins>
      <plugin>
        <groupId>net.alchim31.maven</groupId>
        <artifactId>scala-maven-plugin</artifactId>
        <version>3.1.4</version>
        <executions>
          <execution>
            <id>scala-compile-first</id>
            <phase>process-resources</phase>
            <goals>
              <goal>compile</goal>
            </goals>
          </execution>
        </executions>
        <configuration>
          <jvmArgs>
            <jvmArg>-Xms128m</jvmArg>
            <jvmArg>-Xmx512m</jvmArg>
          </jvmArgs>
        </configuration>
      </plugin>
      <plugin>
        <artifactId>maven-eclipse-plugin</artifactId>
        <version>2.8</version>
        <configuration>
          <downloadSources>true</downloadSources>
          <projectnatures>
            <projectnature>org.scala-ide.sdt.core.scalanature</projectnature>
            <projectnature>org.eclipse.jdt.core.javanature</projectnature>
          </projectnatures>
          <buildcommands>
            <buildcommand>org.scala-ide.sdt.core.scalabuilder</buildcommand>
          </buildcommands>
          <classpathContainers>
            <classpathContainer>org.scala-ide.sdt.launching.SCALA_CONTAINER</classpathContainer>
            <classpathContainer>org.eclipse.jdt.launching.JRE_CONTAINER</classpathContainer>
          </classpathContainers>
          <excludes>
            <exclude>org.scala-lang:scala-library</exclude>
            <exclude>org.scala-lang:scala-compiler</exclude>
          </excludes>
          <sourceIncludes>
            <sourceInclude>**/*.scala</sourceInclude>
            <sourceInclude>**/*.java</sourceInclude>
          </sourceIncludes>
        </configuration>
      </plugin>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>build-helper-maven-plugin</artifactId>
        <version>1.7</version>
        <executions>
          <execution>
            <id>add-source</id>
            <phase>generate-sources</phase>
            <goals>
              <goal>add-source</goal>
            </goals>
            <configuration>
              <sources>
                <source>src/main/scala</source>
              </sources>
            </configuration>
          </execution>
          <execution>
            <id>add-test-source</id>
            <phase>generate-test-sources</phase>
            <goals>
              <goal>add-test-source</goal>
            </goals>
            <configuration>
              <sources>
                <source>src/test/scala</source>
              </sources>
            </configuration>
          </execution>
        </executions>
      </plugin>
      <plugin>
        <groupId>org.scalastyle</groupId>
        <artifactId>scalastyle-maven-plugin</artifactId>
        <configuration>
          <configLocation>${project.basedir}/../../tools/maven/scalastyle-config.xml</configLocation>
        </configuration>
      </plugin>
      <plugin>
        <artifactId>maven-jar-plugin</artifactId>
        <executions>
          <execution>
            <id>KMeans</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>KMeans</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.clustering.KMeans</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/clustering/KMeans.class</include>
                <include>**/java/clustering/KMeans$*.class</include>
                <include>**/java/clustering/util/KMeansDataGenerator.class</include>
                <include>**/java/clustering/util/KMeansData.class</include>
              </includes>
            </configuration>
          </execution>
          <execution>
            <id>TransitiveClosure</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>TransitiveClosure</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.graph.TransitiveClosureNaive</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/graph/TransitiveClosureNaive.class</include>
                <include>**/java/graph/TransitiveClosureNaive$*.class</include>
                <include>**/java/graph/util/ConnectedComponentsData.class</include>
              </includes>
            </configuration>
          </execution>
          <execution>
            <id>ConnectedComponents</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>ConnectedComponents</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.graph.ConnectedComponents</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/graph/ConnectedComponents.class</include>
                <include>**/java/graph/ConnectedComponents$*.class</include>
                <include>**/java/graph/util/ConnectedComponentsData.class</include>
              </includes>
            </configuration>
          </execution>
          <execution>
            <id>EnumTriangles</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>EnumTriangles</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.graph.EnumTriangles</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/graph/EnumTriangles.class</include>
                <include>**/java/graph/EnumTriangles$*.class</include>
                <include>**/java/graph/util/EnumTrianglesDataTypes.class</include>
                <include>**/java/graph/util/EnumTrianglesDataTypes$*.class</include>
                <include>**/java/graph/util/EnumTrianglesData.class</include>
              </includes>
            </configuration>
          </execution>
          <execution>
            <id>PageRank</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>PageRank</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.graph.PageRank</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/graph/PageRank.class</include>
                <include>**/java/graph/PageRank$*.class</include>
                <include>**/java/graph/util/PageRankData.class</include>
              </includes>
            </configuration>
          </execution>
          <execution>
            <id>WebLogAnalysis</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>WebLogAnalysis</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.relational.WebLogAnalysis</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/relational/WebLogAnalysis.class</include>
                <include>**/java/relational/WebLogAnalysis$*.class</include>
                <include>**/java/relational/util/WebLogData.class</include>
                <include>**/java/relational/util/WebLogDataGenerator.class</include>
              </includes>
            </configuration>
          </execution>
          <execution>
            <id>WordCount</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>WordCount</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.wordcount.WordCount</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/wordcount/WordCount.class</include>
                <include>**/java/wordcount/WordCount$*.class</include>
                <include>**/java/wordcount/util/WordCountData.class</include>
              </includes>
            </configuration>
          </execution>
          <execution>
            <id>DistCp</id>
            <phase>package</phase>
            <goals>
              <goal>jar</goal>
            </goals>
            <configuration>
              <classifier>DistCp</classifier>
              <archive>
                <manifestEntries>
                  <program-class>org.apache.flink.examples.java.distcp.DistCp</program-class>
                </manifestEntries>
              </archive>
              <includes>
                <include>**/java/distcp/*</include>
              </includes>
            </configuration>
          </execution>
        </executions>
      </plugin>
      <plugin>
        <artifactId>maven-antrun-plugin</artifactId>
        <version>1.7</version>
        <executions>
          <execution>
            <id>rename</id>
            <phase>package</phase>
            <goals>
              <goal>run</goal>
            </goals>
            <configuration>
              <target>
                <copy />
                <copy />
                <copy />
                <copy />
                <copy />
                <copy />
                <copy />
                <copy />
              </target>
            </configuration>
          </execution>
        </executions>
      </plugin>
    </plugins>
  </build>
  <dependencies>
    <dependency>
      <groupId>org.apache.flink</groupId>
      <artifactId>flink-java</artifactId>
      <version>1.2.0</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.apache.flink</groupId>
      <artifactId>flink-scala_2.11</artifactId>
      <version>1.2.0</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.apache.flink</groupId>
      <artifactId>flink-core</artifactId>
      <version>1.2.0</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.apache.flink</groupId>
      <artifactId>flink-clients_2.11</artifactId>
      <version>1.2.0</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.7</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.17</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>1.7.7</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>com.google.code.findbugs</groupId>
      <artifactId>jsr305</artifactId>
      <version>1.3.9</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>test</scope>
      <exclusions>
        <exclusion>
          <artifactId>hamcrest-core</artifactId>
          <groupId>org.hamcrest</groupId>
        </exclusion>
      </exclusions>
    </dependency>
    <dependency>
      <groupId>org.mockito</groupId>
      <artifactId>mockito-all</artifactId>
      <version>1.10.19</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.powermock</groupId>
      <artifactId>powermock-module-junit4</artifactId>
      <version>1.6.5</version>
      <scope>test</scope>
      <exclusions>
        <exclusion>
          <artifactId>powermock-module-junit4-common</artifactId>
          <groupId>org.powermock</groupId>
        </exclusion>
      </exclusions>
    </dependency>
    <dependency>
      <groupId>org.powermock</groupId>
      <artifactId>powermock-api-mockito</artifactId>
      <version>1.6.5</version>
      <scope>test</scope>
      <exclusions>
        <exclusion>
          <artifactId>mockito-core</artifactId>
          <groupId>org.mockito</groupId>
        </exclusion>
        <exclusion>
          <artifactId>powermock-api-mockito-common</artifactId>
          <groupId>org.powermock</groupId>
        </exclusion>
        <exclusion>
          <artifactId>hamcrest-core</artifactId>
          <groupId>org.hamcrest</groupId>
        </exclusion>
      </exclusions>
    </dependency>
    <dependency>
      <groupId>org.hamcrest</groupId>
      <artifactId>hamcrest-all</artifactId>
      <version>1.3</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>com.data-artisans</groupId>
      <artifactId>flakka-testkit_2.11</artifactId>
      <version>2.3-custom</version>
      <scope>provided</scope>
    </dependency>
  </dependencies>
</project>

