aboutsummaryrefslogblamecommitdiff
path: root/repl-bin/pom.xml
blob: 7c4e722cc157ea72a73c86b64022ff3999fa1b6a (plain) (tree)
1
                                      
















                                                                            



                                                                                                                                                                                                            
                                         
                                     









                                                  

                                                                       








































































































































                                                                                                                               


































                                                 
                                



                                                  
                                



                                                     
                                
                     




                                                     


                     





























                                                              
                                                                                                                 












































                                                                                                                             
<?xml version="1.0" encoding="UTF-8"?>
<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~    http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  -->

<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>org.spark-project</groupId>
    <artifactId>spark-parent</artifactId>
    <version>0.8.0-SNAPSHOT</version>
    <relativePath>../pom.xml</relativePath>
  </parent>

  <groupId>org.spark-project</groupId>
  <artifactId>spark-repl-bin</artifactId>
  <packaging>pom</packaging>
  <name>Spark Project REPL binary packaging</name>
  <url>http://spark-project.org/</url>

  <properties>
    <deb.pkg.name>spark-${classifier}</deb.pkg.name>
    <deb.install.path>/usr/share/spark-${classifier}</deb.install.path>
    <deb.user>root</deb.user>
  </properties>

  <build>
    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-shade-plugin</artifactId>
        <configuration>
          <shadedArtifactAttached>false</shadedArtifactAttached>
          <outputFile>${project.build.directory}/${project.artifactId}-${project.version}-shaded-${classifier}.jar</outputFile>
          <artifactSet>
            <includes>
              <include>*:*</include>
            </includes>
          </artifactSet>
          <filters>
            <filter>
              <artifact>*:*</artifact>
              <excludes>
                <exclude>META-INF/*.SF</exclude>
                <exclude>META-INF/*.DSA</exclude>
                <exclude>META-INF/*.RSA</exclude>
              </excludes>
            </filter>
          </filters>
        </configuration>
        <executions>
          <execution>
            <phase>package</phase>
            <goals>
              <goal>shade</goal>
            </goals>
            <configuration>
              <transformers>
                <transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer"/>
                <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                  <resource>reference.conf</resource>
                </transformer>
                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                  <mainClass>spark.repl.Main</mainClass>
                </transformer>
              </transformers>
            </configuration>
          </execution>
        </executions>
      </plugin>
    </plugins>
  </build>

  <profiles>
    <profile>
      <id>hadoop1</id>
      <properties>
        <classifier>hadoop1</classifier>
      </properties>
      <dependencies>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-core</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop1</classifier>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-bagel</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop1</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-examples</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop1</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-repl</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop1</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.apache.hadoop</groupId>
          <artifactId>hadoop-core</artifactId>
          <scope>runtime</scope>
        </dependency>
      </dependencies>
    </profile>
    <profile>
      <id>hadoop2</id>
      <properties>
        <classifier>hadoop2</classifier>
      </properties>
      <dependencies>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-core</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2</classifier>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-bagel</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-examples</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-repl</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.apache.hadoop</groupId>
          <artifactId>hadoop-core</artifactId>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.apache.hadoop</groupId>
          <artifactId>hadoop-client</artifactId>
          <scope>runtime</scope>
        </dependency>
      </dependencies>
    </profile>
    <profile>
      <id>hadoop2-yarn</id>
      <properties>
        <classifier>hadoop2-yarn</classifier>
      </properties>
      <dependencies>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-core</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2-yarn</classifier>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-bagel</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2-yarn</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-examples</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2-yarn</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.spark-project</groupId>
          <artifactId>spark-repl</artifactId>
          <version>${project.version}</version>
          <classifier>hadoop2-yarn</classifier>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.apache.hadoop</groupId>
          <artifactId>hadoop-client</artifactId>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.apache.hadoop</groupId>
          <artifactId>hadoop-yarn-api</artifactId>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.apache.hadoop</groupId>
          <artifactId>hadoop-yarn-common</artifactId>
          <scope>runtime</scope>
        </dependency>
        <dependency>
          <groupId>org.apache.hadoop</groupId>
          <artifactId>hadoop-yarn-client</artifactId>
          <scope>runtime</scope>
        </dependency>
      </dependencies>
    </profile>
    <profile>
      <id>deb</id>
      <build>
        <plugins>
          <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>buildnumber-maven-plugin</artifactId>
            <version>1.1</version>
            <executions>
              <execution>
                <phase>validate</phase>
                <goals>
                  <goal>create</goal>
                </goals>
                <configuration>
                  <shortRevisionLength>8</shortRevisionLength>
                </configuration>
              </execution>
            </executions>
          </plugin>
          <plugin>
            <groupId>org.vafer</groupId>
            <artifactId>jdeb</artifactId>
            <version>0.11</version>
            <executions>
              <execution>
                <phase>package</phase>
                <goals>
                  <goal>jdeb</goal>
                </goals>
                <configuration>
                  <deb>${project.build.directory}/${deb.pkg.name}_${project.version}-${buildNumber}_all.deb</deb>
                  <attach>false</attach>
                  <compression>gzip</compression>
                  <dataSet>
                    <data>
                      <src>${project.build.directory}/${project.artifactId}-${project.version}-shaded-${classifier}.jar</src>
                      <type>file</type>
                      <mapper>
                        <type>perm</type>
                        <user>${deb.user}</user>
                        <group>${deb.user}</group>
                        <prefix>${deb.install.path}</prefix>
                      </mapper>
                    </data>
                    <data>
                      <src>${basedir}/src/deb/bin</src>
                      <type>directory</type>
                      <mapper>
                        <type>perm</type>
                        <user>${deb.user}</user>
                        <group>${deb.user}</group>
                        <prefix>${deb.install.path}</prefix>
                        <filemode>744</filemode>
                      </mapper>
                    </data>
                    <data>
                      <src>${basedir}/../conf</src>
                      <type>directory</type>
                      <mapper>
                        <type>perm</type>
                        <user>${deb.user}</user>
                        <group>${deb.user}</group>
                        <prefix>${deb.install.path}/conf</prefix>
                        <filemode>744</filemode>
                      </mapper>
                    </data>
                  </dataSet>
                </configuration>
              </execution>
            </executions>
          </plugin>
        </plugins>
      </build>
    </profile>
  </profiles>
</project>