|
|
#!/bin/sh # --- SDE-COPYRIGHT-NOTE-BEGIN --- # This copyright note is auto-generated by ./scripts/Create-CopyPatch. # # Filename: package/.../java-dirtree/java-conf.in # Copyright (C) 2008 The OpenSDE Project # Copyright (C) 2004 - 2006 The T2 SDE Project # # More information can be found in the files COPYING and README. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; version 2 of the License. A copy of the # GNU General Public License can be found in the file COPYING. # --- SDE-COPYRIGHT-NOTE-END ---
# Common java configuration is needed as well. . $base/package/*/*/java-common-conf.in
# Defaults auto_detect=on build_type=
# Prevent executing normal make and install build steps. # Java packages have custom make and install. makeopt= makeinstopt=
# Set variables used for building java sources to there default values. # builddocdir - Location where documentation can be found after building. # buildjardir - Location where build results (jarfiles) can be found. # buildtarget - target(Ant)/goal(Maven) to be used for building. # buildfile - buildfile containing the build rules. builddocdir=dist/docs buildjardir=dist buildtarget=dist buildfile=
# ------------------------------------------------------------------------- # # ------------------------------------------------------------------------- maven1_build() { echo_status "Java buildstyle: Maven (version 1)"
# Maven 2 needs to be installed to be able to use it. pkgprefix -t maven1
# Invoke maven to start building. However, we strictly # forbid downloading dependancies from remote repositories. # All dependancies should be build locally and added to # the local repository. $root/$(pkgprefix bindir maven1)/maven \ -Dmaven.repo.remote.enabled=false \ $mavengoals --pom $1 }
# ------------------------------------------------------------------------- # # ------------------------------------------------------------------------- maven2_build() { echo_status "Java buildstyle: Maven (version 2)"
# Maven 2 needs to be installed to be able to use it. pkgprefix -t maven
abort "MAVEN2 building NOT yet implemented." }
# ------------------------------------------------------------------------- # ant_build: Starts the apache ant build tool. # # Besides starting the apache build tool. The results of building are # gathered and moved to right place. For this two things are considered. # dist/docs for documentation. # dist/*.jar for java jar files/libraries. # # IMPORTANT VARIABLES: # builddocdir - Location where documentation will be. # buildjardir - Location where build result will be. # buildtarget - Ant target to be used for building. # ------------------------------------------------------------------------- ant_build() { echo_status "Java buildstyle: Apache Ant"
# Ant needs to be installed to be able to use it. pkgprefix -t apache-ant
# Invoke Ant to start building. $root/$(pkgprefix bindir apache-ant)/ant -buildfile $1 \ -lib $(pkgprefix libdir java-dirtree) \ $antopt $buildtarget
# Copy all created jar files to the package libdir. echo "Trying to copy package jar files." if ls $buildjardir/*.jar 2> /dev/null ; then cp -v $buildjardir/*.jar $root/$libdir else # Strange. No jar files available? echo "Package $pkg produces no jar files in $buildjardir/." fi
# Copy all documentation to the package docdir. echo "Trying to copy package documentaion." tempdir=$builddocdir if [ -d $tempdir ] ; then ( cd $tempdir; tar -c * | tar -x -C $root/$docdir ) fi unset tempdir }
# ------------------------------------------------------------------------- # set_build_type: Sets the java build type. # # Sets the java build type to be used for building the current package. # ------------------------------------------------------------------------- set_build_type() { local builder_func=
# Build type can only be set once per package, check if it # has already been set. if [ -n "$build_type" ] ; then echo "Buildtype already set ($build_type), can't set it to '$1'" Abort "java-conf.in: Buildtype can only be set once." fi build_type="$1"
case "$build_type" in ANT) builder_func="ant_build ${buildfile:-build.xml}" ;; MAVEN) todo ;; SCRIPT) todo ;; *) abort "java-conf.in: Unknown buildtype $1 specified." ;; esac
# Since the built type is set, auto detection is no longer needed. auto_detect=off
# Set the inmake hook to use the given builder type. hook_add inmake 5 "$builder_func" }
# Before we continue lets process all command line options. while [ "$1" ] ; do case "$1" in NO_AUTO_DETECT) auto_detect=off ; echo_status "Java buildstyle: Autodetect disabled." ;; BUILD_TYPE=*) set_build_type ${1#*=} ;; BUILD_FILE=*) buildfile=${1#*=} ;; *) abort "java-conf.in: Unknown arguments" ;; esac shift done
# Check if at least one of the jdk's is available right now. if [ -z $JAVA_HOME ]; then # No jdk available, continueing is pointless. abort "At least one of the JDK's need to be installed." fi
# This function determines the maven version to be used on # the given input file. # param: pom/project filename # return: the pom/project file major version number. detect_maven_version() { # Todo: look inside the file to determine the version. echo "3" }
# We know how to build Ant, Maven and Maven 2 style projects. # build and build.sh scripts are ignored on purpose. By controlling # the build in here we might make it easier to build packages using # exotic compilers like gcj or jikes. determine_build_type() { local buildtype=
# Check if the Ant build.xml file is available. if [ -f build.xml ]; then # Package can be build using Ant. However this might be # overruled by any of the others. buildtype="ANT" fi
# Check if the Maven pom.xml or project.xml file is available. for mavenfile in pom.xml project.xml; do # Check if the maven file exists if [ -f $mavenfile ]; then # A maven file is available, but what maven # version should be used? The projectfile # version can tell us. pomversion=`detect_maven_version $mavenfile` case "$pomversion" in 4*) builder_func="maven2_build $mavenfile" ;; # In all other cases we use maven 1. *) builder_func="maven1_build $mavenfile" ;; esac fi done
# Check if we have found an appropriate java builder. if [ -n "$buildtype" ]; then # Set the selected build type. set_build_type $buildtype else # Auto detection of the build style resulted into # nothing. So from here on it is up to the package # to decide how to continue building the package. echo_status "Java buildstyle: Unknown buildstyle" fi }
# Check if autodetection of the build process is required. if [ "$auto_detect" == "on" ] ; then # We use a postpatch hook to determine what kind of build process # is needed. When we know we set the inmake hook appropriately. hook_add postpatch 5 determine_build_type fi
|